@font-face {
  font-family: 'Cannelpang Serif';
  src: url('assets/fonts/noto-serif-sc-subset.woff2') format('woff2');
  font-weight: 200 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Cannelpang Sans';
  src: url('assets/fonts/noto-sans-sc-subset.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Cannelpang Mono';
  src: url('assets/fonts/jetbrains-mono-latin.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --page-bg: #070a0e;
  --card-bg: #0f151b;
  --surface-soft: #0b1016;
  --text-main: #eee8dc;
  --text-sub: #9a9284;
  --line: #202832;
  --highlight: #c6a35a;
  --highlight-10: color-mix(in oklch, var(--highlight) 14%, transparent);
  --text-10: color-mix(in oklch, var(--text-main) 6%, transparent);

  --font-serif: 'Cannelpang Serif','Noto Serif SC','Noto Serif CJK SC','Source Han Serif SC','Songti SC','STSong','SimSun','Noto Serif JP',Georgia,serif;
  --font-sans: 'Cannelpang Sans','Noto Sans SC','Noto Sans CJK SC','Source Han Sans SC','PingFang SC','Microsoft YaHei',system-ui,sans-serif;
  --font-mono: 'Cannelpang Mono','JetBrains Mono','SF Mono',ui-monospace,Menlo,monospace;

  --fs-h1: 72px; --fs-h2: 44px; --fs-h3: 22px;
  --fs-lead: 19px; --fs-body: 16px; --fs-meta: 13px;

  --gap-xs: 8px; --gap-sm: 12px; --gap-md: 20px; --gap-lg: 32px;
  --gap-xl: 56px; --gap-2xl: 96px;
  --container: 1120px; --gutter: 32px;
  --radius: 6px; --radius-lg: 8px;
  --shadow-soft: 0 20px 80px rgba(0,0,0,0.28);
  --motion: 180ms cubic-bezier(.2,.7,.2,1);
}
@media(max-width:920px){
  :root{--fs-h1:52px;--fs-h2:36px;--fs-lead:18px;--gutter:26px}
}
@media(max-width:560px){
  :root{--fs-h1:42px;--fs-h2:30px;--fs-h3:20px;--fs-lead:17px;--gutter:22px;--gap-xl:40px;--gap-2xl:64px}
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
body{margin:0;background:linear-gradient(180deg,#09070a 0,#070a0e 22%,#080c11 100%);color:var(--text-main);font-family:var(--font-sans);font-size:var(--fs-body);font-weight:350;line-height:1.82;-webkit-font-smoothing:antialiased;overflow-x:clip;line-break:strict;font-kerning:normal;font-feature-settings:"palt" 1}
html[lang="en"] body{line-break:auto;font-feature-settings:normal}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
p,h1,h2,h3,h4{text-wrap:pretty}
p{font-weight:350}
::selection{background:var(--highlight);color:var(--page-bg)}

.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--gap-2xl);position:relative}
.section+.section{border-top:1px solid color-mix(in oklch,var(--line) 84%,transparent)}
.stack{display:flex;flex-direction:column}.stack>*+*{margin-top:var(--gap-md)}
.row{display:flex;align-items:center;gap:var(--gap-md);flex-wrap:wrap}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-md);flex-wrap:wrap}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-lg)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-lg)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-md)}
.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:var(--gap-xl);align-items:start}
.grid-1-2{display:grid;grid-template-columns:1fr 2fr;gap:var(--gap-xl);align-items:start}
@media(max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-2,.grid-2-1,.grid-1-2{grid-template-columns:1fr}}
@media(max-width:640px){.grid-3,.grid-4{grid-template-columns:1fr}}

.h1,h1{font-family:var(--font-serif);font-size:var(--fs-h1);line-height:1.32;letter-spacing:0;margin:0;font-weight:420}
.h2,h2{font-family:var(--font-serif);font-size:var(--fs-h2);line-height:1.38;letter-spacing:0;margin:0;font-weight:420}
.h3,h3{font-size:var(--fs-h3);font-weight:430;line-height:1.48;letter-spacing:0;margin:0}
.lead{font-size:var(--fs-lead);font-weight:330;line-height:1.95;color:var(--text-sub);max-width:44ch;margin:0}
.lead+.lead{margin-top:16px}
.eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:400;letter-spacing:0;text-transform:uppercase;color:var(--highlight);margin:0 0 36px}
.meta{font-family:var(--font-mono);font-size:var(--fs-meta);color:var(--text-sub)}
.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}

.section-head{max-width:42ch;margin-bottom:var(--gap-xl)}
.section-head .eyebrow{margin-bottom:22px}
.section-head.compact{margin-bottom:var(--gap-lg)}
.section-head-row{max-width:none;display:flex;align-items:flex-end;justify-content:space-between;gap:var(--gap-md);flex-wrap:wrap}
.section-title{margin:0}
.section-lead{font-size:var(--fs-lead);font-weight:330;line-height:1.95;color:var(--text-sub);max-width:44ch;margin:16px 0 0}
.content-measure{max-width:42ch}
.content-measure-wide{max-width:52ch}
.copy{margin:0;color:var(--text-sub);font-size:15px;font-weight:350;line-height:1.88;max-width:46ch}
.copy+.copy{margin-top:12px}
.copy-sm{margin:6px 0 0;color:var(--text-sub);font-size:14px;line-height:1.78}
.meta-label{font-family:var(--font-mono);font-size:12px;line-height:1.4;color:var(--highlight);text-transform:uppercase;margin:0 0 4px}
.kicker-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.tag-row .meta-label,.kicker-row .meta-label{margin:0}
.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-row .btn{min-height:34px;padding:6px 14px;font-size:13px}
.footer-links{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-links a{color:var(--text-sub);transition:color var(--motion)}
.footer-links a:hover{color:var(--highlight)}
.align-center{text-align:center}
.align-center .lead,.align-center .section-lead{margin-inline:auto}
.cta-narrow{max-width:600px;text-align:center}
.cta-narrow .lead{margin:16px auto 32px}
.link-spaced{margin-top:20px}
.card-caption{margin:12px 0 0;color:var(--text-sub);font-size:14px;line-height:1.72}
.media-card-title{margin-top:16px}
.social-title{font-weight:600;line-height:1.45}
.social-meta{font-size:13px;line-height:1.62;color:var(--text-sub)}
.contact-list{gap:20px}
.stack.contact-list>*+*{margin-top:0}
.contact-list p:not(.meta-label){margin:0}
.qr-block{margin-top:32px}
.qr-placeholder{max-width:180px}
.form-stack .field+.field{margin-top:16px}
.form-stack .field.message-field{margin-top:24px}
.select-input{cursor:pointer}
.form-submit{width:100%;justify-content:center}
.form-stack .form-submit{margin-top:24px}
.portrait-card{max-width:400px;margin-inline:auto}

.topnav{position:sticky;top:0;z-index:20;background:rgba(8,7,10,0.82);backdrop-filter:blur(18px);border-bottom:1px solid color-mix(in oklch,var(--line) 78%,transparent)}
.topnav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:78px;padding-block:12px}
.topnav .logo{font-family:var(--font-serif);font-size:19px;font-weight:520;letter-spacing:0;white-space:nowrap}
.nav-panel{display:flex;align-items:center;justify-content:space-between;gap:32px;flex:1}
.topnav nav,.topnav .site-nav{display:flex;align-items:center;justify-content:center;gap:30px}
.topnav nav a{font-size:14px;color:var(--text-sub);transition:color var(--motion)}
.topnav nav a:hover{color:var(--text-main)}
.topnav nav .nav-admin{color:var(--highlight)}
.nav-actions{margin-left:auto;gap:12px}
.topnav .lang-toggle{font-family:var(--font-mono);font-size:12px;color:var(--text-sub);background:transparent;border:1px solid var(--line);border-radius:999px;padding:4px 12px}
.topnav .lang-toggle:hover{color:var(--text-main);border-color:var(--text-main)}
.topnav .nav-actions .btn-primary{background:transparent;color:var(--text-sub);border-color:transparent;font-size:14px;min-height:34px;padding:5px 8px}
.topnav .nav-actions .btn-primary:hover{background:transparent;color:var(--highlight);border-color:transparent}
.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:999px;background:color-mix(in oklch,var(--card-bg) 78%,transparent);color:var(--text-main);place-items:center;padding:0}
.nav-toggle span{width:16px;height:1px;background:currentColor;display:block;transition:transform var(--motion),opacity var(--motion)}
.nav-toggle span+span{margin-top:5px}
body.nav-open .nav-toggle span:first-child{transform:translateY(3px) rotate(45deg)}
body.nav-open .nav-toggle span:last-child{transform:translateY(-3px) rotate(-45deg)}
.pagefoot{padding-block:var(--gap-xl);color:var(--text-sub);font-size:13px;border-top:1px solid var(--line)}
.pagefoot .row-between{flex-wrap:wrap;gap:var(--gap-md)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 18px;border-radius:var(--radius);border:1px solid transparent;font-size:15px;font-weight:420;letter-spacing:0;transition:transform .05s ease,background var(--motion),border-color var(--motion),color var(--motion)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--highlight);color:var(--page-bg);border-color:var(--highlight)}
.btn-primary:hover{background:color-mix(in oklch,var(--highlight) 88%,white)}
.btn-secondary{background:transparent;color:var(--text-main);border-color:var(--line)}
.btn-secondary:hover{border-color:var(--text-main)}
.btn-ghost{background:transparent;color:var(--text-main);border-color:transparent;padding-inline:8px}
.btn-ghost:hover{color:var(--highlight)}
.btn-arrow::after{content:'→';transition:transform .15s ease}
.btn-arrow:hover::after{transform:translateX(2px)}

.card{background:linear-gradient(180deg,color-mix(in oklch,var(--card-bg) 92%,white),var(--card-bg));border:1px solid color-mix(in oklch,var(--line) 88%,transparent);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-soft)}
.card-flat{background:transparent;border:0;padding:0}
.card-rule{background:transparent;border:0;border-top:1px solid var(--text-main);padding:24px 0 0;border-radius:0}

.feature .feature-mark{width:36px;height:36px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--highlight) 36%,var(--line));border-radius:var(--radius);color:var(--highlight);margin-bottom:var(--gap-md);background:var(--highlight-10)}
.feature .feature-mark svg{width:18px;height:18px}
.feature h3{margin-bottom:6px}
.feature p{margin:0;color:var(--text-sub);font-size:15px}

.stat{border-top:1px solid color-mix(in oklch,var(--text-main) 34%,var(--line));padding-top:20px}
.stat .stat-num{font-family:var(--font-serif);font-size:88px;line-height:0.95;letter-spacing:0;color:var(--highlight);font-weight:520}
.stat .stat-label{color:var(--text-sub);font-size:14px;margin-top:12px;max-width:32ch}
.stat .stat-unit{font-size:0.5em;opacity:0.7;margin-left:2px}
@media(max-width:920px){.stat .stat-num{font-size:72px}}
@media(max-width:560px){.stat .stat-num{font-size:58px}}

.quote{font-family:var(--font-serif);font-size:clamp(24px,2.6vw,32px);line-height:1.5;letter-spacing:0;max-width:28ch}
.quote-author{color:var(--text-sub);font-size:14px;margin-top:var(--gap-md)}
.quote-mark{font-family:var(--font-serif);font-size:140px;line-height:0.7;color:var(--highlight);opacity:0.18;margin-bottom:-28px}

.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--highlight-10);color:var(--highlight);border-radius:999px;font-family:var(--font-mono);font-size:11px;letter-spacing:0;text-transform:uppercase}
.tag{display:inline-flex;align-items:center;padding:4px 10px;background:transparent;color:var(--text-sub);border:1px solid var(--line);border-radius:999px;font-size:12px}

.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;color:var(--text-sub)}
.input,.textarea{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--card-bg);color:var(--text-main);font:inherit;font-size:15px}
.input:focus,.textarea:focus{outline:2px solid var(--highlight-10);border-color:var(--highlight)}
.textarea{min-height:96px;resize:vertical;line-height:1.7}

.ds-table{width:100%;border-collapse:collapse;font-size:14px}
.ds-table th,.ds-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line)}
.ds-table th{color:var(--text-sub);font-weight:500;font-family:var(--font-mono);font-size:12px;letter-spacing:0;text-transform:uppercase}
.ds-table tbody tr:hover{background:var(--text-10)}
.ds-table .num-col{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}

.ph-img{background:linear-gradient(135deg,var(--highlight-10),var(--text-10)),var(--card-bg);border:1px solid var(--line);border-radius:var(--radius-lg);aspect-ratio:16/10;display:grid;place-items:center;color:var(--text-sub);font-family:var(--font-mono);font-size:12px;letter-spacing:0}
.ph-img.square{aspect-ratio:1/1}.ph-img.portrait{aspect-ratio:3/4}.ph-img.wide{aspect-ratio:16/9}

.rule{border:0;border-top:1px solid var(--line);margin:0}
.rule-strong{border:0;border-top:1px solid var(--text-main);margin:0}

.hero{padding-block:128px}
.hero-center{text-align:center;max-width:48ch;margin-inline:auto}
.hero h1{margin-bottom:42px;text-wrap:balance;overflow-wrap:anywhere}.hero .lead{margin-bottom:42px;margin-inline:auto}
.hero-cta{display:inline-flex;gap:var(--gap-sm);flex-wrap:wrap}
.hero-center .hero-cta{justify-content:center}
.hero-split{display:grid;grid-template-columns:5fr 4fr;gap:var(--gap-2xl);align-items:center}
@media(max-width:920px){.hero-split{grid-template-columns:1fr}}

.hero-video{position:relative;overflow:hidden;min-height:calc(100svh - 78px);display:flex;align-items:center}
.hero-video video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-video .video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,rgba(8,7,10,0.46) 0,rgba(8,10,14,0.5) 38%,rgba(7,10,14,0.9) 100%);z-index:1}
.hero-video .container{position:relative;z-index:2}
.hero-video .hero-center{max-width:48ch}
.hero-video h1{text-shadow:0 2px 40px rgba(0,0,0,0.5)}
.hero-video .lead{color:color-mix(in oklch,var(--text-main) 80%,transparent);text-shadow:0 1px 20px rgba(0,0,0,0.4)}
.hero-video .hero-cta .btn-primary{background:rgba(198,163,90,0.2);color:var(--text-main);border-color:color-mix(in oklch,var(--highlight) 46%,transparent);backdrop-filter:blur(8px)}
.hero-video .hero-cta .btn-primary:hover{background:rgba(198,163,90,0.28);border-color:color-mix(in oklch,var(--highlight) 70%,transparent)}
.hero-video .hero-cta .btn-secondary{background:rgba(7,10,14,0.18);border-color:color-mix(in oklch,var(--text-main) 16%,transparent);backdrop-filter:blur(8px)}

.img-cover{width:100%;height:100%;object-fit:cover;display:block}
.img-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid color-mix(in oklch,var(--line) 74%,transparent);background:var(--surface-soft)}
.img-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(198,163,90,0.06),rgba(7,10,14,0.18));pointer-events:none}
.img-card img{transition:transform .6s var(--motion),filter .6s var(--motion);filter:saturate(.86) contrast(1.05)}
.img-card:hover img{transform:scale(1.04)}

.log-row{display:grid;grid-template-columns:120px minmax(0,1fr) 100px;gap:var(--gap-lg);padding:22px 0;border-top:1px solid var(--line);align-items:baseline}
.log-row:first-child{border-top-color:var(--text-main);padding-top:24px}
.log-row .meta{color:var(--text-sub)}.log-row h3{font-size:19px}.log-row .pull{text-align:right}

.gallery-tabs{display:flex;gap:var(--gap-sm);margin-bottom:var(--gap-xl);flex-wrap:wrap}
.gallery-tab{padding:8px 18px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--text-sub);font-size:14px;cursor:pointer}
.gallery-tab.active{background:var(--highlight);color:var(--page-bg);border-color:var(--highlight)}
.gallery-tab:hover:not(.active){border-color:var(--text-main);color:var(--text-main)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-lg)}
.gallery-item{position:relative}.gallery-item .ph-img{transition:transform .2s ease}
.gallery-item:hover .ph-img{transform:translateY(-4px)}
.gallery-caption{margin-top:var(--gap-sm);font-size:14px;color:var(--text-sub)}

.timeline{display:flex;flex-direction:column;gap:var(--gap-lg)}
.timeline-item{display:grid;grid-template-columns:120px 1fr;gap:var(--gap-lg);padding:24px 0;border-top:1px solid var(--line)}
.timeline-item .year{font-family:var(--font-mono);font-size:14px;color:var(--highlight);font-weight:600}
.timeline-item h3{font-size:19px;margin-bottom:6px}
.timeline-item p{margin:0;color:var(--text-sub);font-size:15px}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-lg)}
.blog-card{background:var(--card-bg);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .2s ease}
.blog-card:hover{transform:translateY(-4px)}
.blog-card .ph-img{border-radius:0;border-left:0;border-right:0;border-top:0}
.blog-card-content{padding:24px}
.blog-card-content .tag-row{display:flex;gap:8px;margin-bottom:12px}
.blog-card-content h3{font-size:19px;margin-bottom:8px;line-height:1.4}
.blog-card-content p{color:var(--text-sub);font-size:14px;margin:0}
.blog-card-content .date{font-family:var(--font-mono);font-size:12px;color:var(--text-sub);margin-top:16px}

.featured-post{display:grid;grid-template-columns:5fr 4fr;gap:var(--gap-xl);align-items:center}
@media(max-width:920px){.featured-post{grid-template-columns:1fr}}

.social-link{display:flex;align-items:center;gap:12px;padding:16px 20px;border:1px solid var(--line);border-radius:var(--radius);color:var(--text-main);transition:border-color .15s ease}
.social-link:hover{border-color:var(--highlight);color:var(--highlight)}
.social-link .icon{width:20px;height:20px;color:var(--text-sub)}
.social-link:hover .icon{color:var(--highlight)}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-xl);align-items:start}
@media(max-width:920px){.contact-grid{grid-template-columns:1fr}}

@media(max-width:920px){
  .hero{padding-block:96px}
  .gallery-grid,.blog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:760px){
  body.nav-open{overflow:hidden}
  .topnav-inner{min-height:64px;padding-block:10px}
  .nav-toggle{display:grid;margin-left:auto}
  .nav-panel{position:fixed;top:72px;left:var(--gutter);right:var(--gutter);width:auto;max-width:none;display:grid;gap:22px;padding:22px;background:rgba(11,16,22,0.96);border:1px solid color-mix(in oklch,var(--line) 82%,transparent);border-radius:var(--radius-lg);box-shadow:0 24px 80px rgba(0,0,0,.42);opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity var(--motion),transform var(--motion)}
  body.nav-open .nav-panel{opacity:1;pointer-events:auto;transform:translateY(0)}
  .topnav .site-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px 12px;justify-content:stretch}
  .topnav .site-nav a{padding:10px 0;border-bottom:1px solid color-mix(in oklch,var(--line) 70%,transparent);font-size:15px}
  .nav-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-left:0}
  .topnav .lang-toggle,.nav-actions .btn{width:100%;min-height:44px}
  .topnav .nav-actions .btn-primary{min-height:44px;padding:10px 14px}
  .hero{padding-block:72px}
  .hero-video{min-height:calc(100svh - 64px);padding-block:64px}
  .hero h1{margin-bottom:28px}
  .hero .lead{margin-bottom:28px}
  .hero-cta{width:100%}
  .hero-cta .btn{flex:1 1 140px}
  .log-row{grid-template-columns:1fr;gap:8px;padding:20px 0}
  .log-row .pull{text-align:left;width:auto;max-width:100%}
  .timeline-item{grid-template-columns:1fr;gap:8px}
  .section-head-row{align-items:flex-start}
}

@media(max-width:560px){
  .section{padding-block:var(--gap-2xl)}
  .gallery-grid,.blog-grid{grid-template-columns:1fr}
  .blog-card-content{padding:20px}
  .card{padding:22px}
  .topnav .site-nav{grid-template-columns:1fr}
  .gallery-tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}
  .gallery-tab{flex:0 0 auto}
  .pagefoot .row{width:100%;justify-content:flex-start}
  .footer-links{width:100%;justify-content:flex-start}
}

@media(max-width:760px){
  .topnav .nav-panel{position:fixed !important;left:var(--gutter) !important;right:var(--gutter) !important;width:auto !important;opacity:0 !important;pointer-events:none !important}
  body.nav-open .topnav .nav-panel{opacity:1 !important;pointer-events:auto !important}
  .log-row{grid-template-columns:1fr !important}
  .log-row .pull{text-align:left !important;width:auto !important}
}

@media(max-width:640px){
  .row-between{align-items:flex-start}
  .row-between>.row{width:100%;justify-content:flex-start}
  .row-between>.row .btn{flex:0 0 auto}
  .hero-center{max-width:min(100%,42ch)}
}
