/* ACEHIGH — premium static site */

/* ========================================================================
   Design system
   ======================================================================== */
:root{
  --navy:#0c1c2c; --navy-2:#14283d; --navy-3:#1e344b;
  --gold:#c4a15a; --gold-2:#b08734; --gold-3:#e0c889;
  --ink:#14202b; --ink-2:#3a4550; --ink-3:#5a6672;
  --muted:#8a94a0;
  --cream:#faf7f1; --cream-2:#f3ede1; --cream-3:#ebe3d1;
  --border:#e4dfd3; --border-2:#c9c0ac;
  --shadow-sm:0 2px 8px rgba(12,28,44,.04);
  --shadow-md:0 12px 36px rgba(12,28,44,.08);
  --shadow-lg:0 20px 60px rgba(12,28,44,.12);
  --serif:"Noto Serif SC","Noto Serif JP","Songti SC","Hiragino Mincho ProN","Yu Mincho",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","Meiryo","Microsoft YaHei",Roboto,Helvetica,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{margin:0;font-family:var(--sans);color:var(--ink-2);line-height:1.8;background:#fff;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
a{color:var(--gold-2);text-decoration:none;transition:color .2s;}
a:hover{color:var(--gold);}
img{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4,h5{color:var(--ink);margin:0;line-height:1.4;font-weight:600;}
h1,h2{font-family:var(--serif);font-weight:700;letter-spacing:.05em;}
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.container.narrow{max-width:900px;}
/* Fade-in on scroll */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1);}
[data-reveal].in{opacity:1;transform:none;}
/* ========================================================================
   Header
   ======================================================================== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--border);transition:padding .3s;}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;max-width:1400px;margin:0 auto;}
.site-logo{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--ink);}
.site-logo img{height:44px;width:auto;display:block;}
.logo-fallback{font-family:var(--serif);font-weight:700;font-size:24px;letter-spacing:.2em;color:var(--navy);}
.site-nav{display:flex;gap:36px;}
.site-nav a{color:var(--ink-2);font-size:14px;font-weight:500;letter-spacing:.15em;padding:10px 0;position:relative;text-transform:uppercase;}
.site-nav a::after{content:"";position:absolute;left:50%;bottom:0;width:0;height:2px;background:var(--gold);transition:all .3s;transform:translateX(-50%);}
.site-nav a:hover,.site-nav a.active{color:var(--navy);}
.site-nav a:hover::after,.site-nav a.active::after{width:24px;}
.nav-toggle{display:none;background:transparent;border:0;padding:10px;cursor:pointer;}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);margin:5px 0;transition:.2s;}
/* Language switcher */
.lang-switch{display:flex;align-items:center;gap:7px;margin-left:20px;padding-left:20px;border-left:1px solid var(--border);}
.lang-switch .lang-cur{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--navy);text-transform:uppercase;background:var(--navy);color:#fff;padding:3px 8px;border-radius:3px;}
.lang-switch .lang-sep{color:var(--border);font-size:11px;display:none;}
.lang-switch .lang-other{font-size:11px;font-weight:600;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;text-decoration:none;border:1px solid var(--gold);padding:3px 8px;border-radius:3px;transition:background .2s,color .2s;}
.lang-switch .lang-other:hover{background:var(--gold);color:#fff;}
@media (max-width:920px){
  .site-header-inner{padding:14px 20px;}
  .site-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;gap:0;padding:0;border-top:1px solid var(--border);box-shadow:var(--shadow-md);}
  .site-nav.open{display:flex;}
  .site-nav a{padding:16px 24px;border-bottom:1px solid var(--border);letter-spacing:.1em;}
  .site-nav a::after{display:none;}
  .nav-toggle{display:block;}
  .lang-switch{margin-left:0;padding:14px 24px;border-left:0;border-top:1px solid var(--border);justify-content:center;}
}

/* ========================================================================
   Hero (home)
   ======================================================================== */
.hero{position:relative;min-height:680px;overflow:hidden;background:var(--navy);color:#fff;display:flex;align-items:center;}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.38;}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,28,44,.55) 0%,rgba(12,28,44,.82) 100%),linear-gradient(90deg,rgba(12,28,44,.5),transparent 60%);pointer-events:none;}
.hero-inner{position:relative;z-index:2;width:100%;max-width:1400px;margin:0 auto;padding:80px 48px;display:grid;grid-template-columns:1fr;align-items:center;}
.hero-eyebrow{display:inline-block;font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-3);margin:0 0 28px;padding:8px 18px;border:1px solid rgba(196,161,90,.5);border-radius:2px;}
.hero-title,.hero-title-2{font-family:var(--serif);font-size:clamp(30px,5.5vw,64px);font-weight:700;letter-spacing:.06em;margin:0;color:#fff;line-height:1.25;}
.hero-title-2{margin:8px 0 32px;color:var(--gold-3);}
.hero-sub{font-size:clamp(14px,1.6vw,18px);letter-spacing:.25em;opacity:.86;margin:0 0 48px;color:#fff;font-weight:400;}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 38px;font-size:13px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;transition:all .25s;border:0;cursor:pointer;font-family:inherit;border-radius:2px;}
.btn-primary{background:var(--gold);color:var(--navy);}
.btn-primary:hover{background:var(--gold-3);color:var(--navy);transform:translateY(-2px);box-shadow:0 10px 24px rgba(196,161,90,.4);}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4);}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff;color:#fff;}
.btn svg{width:14px;height:14px;}
@media (max-width:640px){.hero{min-height:560px;}.hero-inner{padding:56px 24px;}}

/* ========================================================================
   Stats ribbon (below hero)
   ======================================================================== */
.stats-ribbon{background:var(--navy-2);color:#fff;padding:36px 0;border-top:1px solid rgba(196,161,90,.2);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1200px;margin:0 auto;padding:0 24px;text-align:center;}
.stats-grid .stat{position:relative;}
.stats-grid .stat + .stat{border-left:1px solid rgba(255,255,255,.12);}
.stats-grid .num{font-family:var(--serif);font-size:clamp(28px,4vw,44px);font-weight:700;color:var(--gold-3);line-height:1;}
.stats-grid .num small{font-size:.55em;color:var(--gold-3);margin-left:4px;}
.stats-grid .label{font-size:12px;letter-spacing:.25em;color:rgba(255,255,255,.7);margin-top:12px;text-transform:uppercase;}
@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:24px 16px;}.stats-grid .stat:nth-child(odd){border-left:0;}.stats-grid .stat:nth-child(3){border-top:1px solid rgba(255,255,255,.12);padding-top:24px;}.stats-grid .stat:nth-child(4){border-top:1px solid rgba(255,255,255,.12);padding-top:24px;}}

/* ========================================================================
   Page banner (inner pages)
   ======================================================================== */
.page-banner{position:relative;height:340px;background:linear-gradient(135deg,var(--navy-2) 0%,var(--navy) 100%);color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;}
.page-banner::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 100%,rgba(196,161,90,.18),transparent 50%),radial-gradient(circle at 80% 0%,rgba(196,161,90,.12),transparent 50%);}
.page-banner-text{position:relative;z-index:2;}
.page-banner-text .en{display:block;font-family:var(--serif);font-size:clamp(36px,5.5vw,64px);font-weight:700;letter-spacing:.22em;margin:0;}
.page-banner-text .jp{display:block;font-size:14px;letter-spacing:.4em;opacity:.82;margin:16px 0 0;text-transform:uppercase;color:var(--gold-3);}

/* ========================================================================
   Section scaffold
   ======================================================================== */
section.block{padding:100px 0;}
section.block.alt{background:var(--cream);}
section.block.dark{background:var(--navy);color:rgba(255,255,255,.88);}
section.block.dark h1,section.block.dark h2,section.block.dark h3{color:#fff;}
@media (max-width:640px){section.block{padding:64px 0;}}
.eyebrow{display:block;font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-2);margin:0 0 16px;font-weight:600;}
.section-title{text-align:center;margin-bottom:64px;}
.section-title .en{display:block;font-family:var(--serif);font-size:clamp(30px,4vw,44px);font-weight:700;letter-spacing:.08em;color:var(--ink);}
.section-title .jp{display:block;font-size:13px;letter-spacing:.3em;color:var(--muted);margin-top:12px;text-transform:uppercase;}
.section-title .line{display:block;width:48px;height:2px;background:var(--gold);margin:22px auto 0;}
section.block.dark .section-title .en{color:#fff;}
section.block.dark .section-title .jp{color:var(--gold-3);}

/* ========================================================================
   About preview (home)
   ======================================================================== */
.about-preview{max-width:820px;margin:0 auto;text-align:center;}
.about-preview p{font-size:17px;color:var(--ink-2);margin:0 0 20px;line-height:1.9;}
.btn-more{display:inline-flex;align-items:center;gap:10px;margin-top:28px;padding:14px 40px;border:1px solid var(--gold);color:var(--gold-2);font-weight:600;letter-spacing:.3em;font-size:12px;text-transform:uppercase;transition:all .25s;background:transparent;border-radius:2px;}
.btn-more:hover{background:var(--gold);color:#fff;letter-spacing:.35em;}
.btn-more svg{width:12px;height:12px;}
/* ========================================================================
   Service grid
   ======================================================================== */
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;align-items:stretch;}
.service-card{background:#fff;border:1px solid var(--border);overflow:hidden;transition:all .35s cubic-bezier(.22,.61,.36,1);display:flex;flex-direction:column;min-height:480px;position:relative;}
.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-3));transform:scaleX(0);transform-origin:left center;transition:transform .35s;z-index:2;}
.service-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:var(--gold-3);}
.service-card:hover::before{transform:scaleX(1);}
.service-card .cover{aspect-ratio:16/10;background:var(--cream-2);overflow:hidden;flex-shrink:0;position:relative;}
.service-card .cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(12,28,44,.18) 100%);pointer-events:none;}
.service-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.22,.61,.36,1);}
.service-card:hover .cover img{transform:scale(1.08);}
.service-card .cover.cover-contain{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-2) 100%);display:flex;align-items:center;justify-content:center;}
.service-card .cover.cover-contain img{object-fit:contain;padding:24px;}
.service-card .cover.cover-contain::after{display:none;}
/* Tall portrait source image framed in a 16:10 card: fill the frame but anchor */
/* to the top edge so the logo / focal subject stays visible after the crop. */
.service-card .cover.cover-focus-top img{object-fit:cover;object-position:center 18%;}
.service-card .body{padding:32px 28px;flex:1;display:flex;flex-direction:column;}
.service-card .eyebrow-gold{display:block;font-size:11px;color:var(--gold-2);font-weight:700;letter-spacing:.3em;margin:0 0 14px;text-transform:uppercase;}
.service-card .catch{font-size:13px;color:var(--gold-2);font-weight:500;margin:0 0 14px;letter-spacing:.03em;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:3em;}
.service-card .name{font-family:var(--serif);font-size:22px;font-weight:700;margin:0 0 16px;color:var(--ink);letter-spacing:.02em;}
.service-card .desc{font-size:14px;color:var(--ink-3);margin:0;flex:1;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;line-height:1.85;}
.service-card .arrow{margin-top:20px;font-size:12px;color:var(--gold-2);letter-spacing:.25em;font-weight:600;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;transition:gap .25s;}
.service-card .arrow svg{width:14px;height:14px;flex-shrink:0;}
.service-card:hover .arrow{gap:14px;}
/* ========================================================================
   Why Us — feature grid
   ======================================================================== */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px;}
.why-item{text-align:center;padding:16px;}
.why-item .ic{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-3));color:var(--navy);margin-bottom:20px;transition:transform .35s;box-shadow:0 8px 24px rgba(196,161,90,.28);}
.why-item:hover .ic{transform:scale(1.08) rotate(-5deg);}
.why-item .ic svg{width:32px;height:32px;}
.why-item h3{font-family:var(--serif);font-size:19px;color:var(--ink);margin:0 0 12px;letter-spacing:.03em;}
.why-item p{font-size:14px;color:var(--ink-3);margin:0;line-height:1.85;}
section.block.dark .why-item h3{color:#fff;}
section.block.dark .why-item p{color:rgba(255,255,255,.7);}

/* ========================================================================
   Process — step-by-step
   ======================================================================== */
.process-wrap{max-width:1060px;margin:0 auto;position:relative;}
.process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;position:relative;}
.process-grid::before{content:"";position:absolute;top:36px;left:8%;right:8%;height:2px;background:repeating-linear-gradient(90deg,var(--gold) 0,var(--gold) 6px,transparent 6px,transparent 12px);z-index:0;}
.process-step{position:relative;z-index:1;text-align:center;padding:0 8px;}
.process-step .badge{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:#fff;color:var(--gold-2);border:2px solid var(--gold);margin:0 auto 18px;font-family:var(--serif);font-size:26px;font-weight:700;box-shadow:0 6px 18px rgba(196,161,90,.25);transition:all .25s;}
.process-step:hover .badge{background:var(--gold);color:#fff;transform:translateY(-4px);}
.process-step h4{font-size:15px;color:var(--ink);margin:0 0 8px;font-weight:600;letter-spacing:.02em;}
.process-step p{font-size:13px;color:var(--ink-3);margin:0;line-height:1.7;}
@media (max-width:900px){.process-grid{grid-template-columns:repeat(2,1fr);gap:32px 16px;}.process-grid::before{display:none;}}
@media (max-width:520px){.process-grid{grid-template-columns:1fr;}}

/* ========================================================================
   CTA banner
   ======================================================================== */
.cta-banner{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;padding:80px 0;position:relative;overflow:hidden;}
.cta-banner::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 15% 50%,rgba(196,161,90,.2),transparent 45%),radial-gradient(circle at 85% 50%,rgba(196,161,90,.12),transparent 45%);}
.cta-banner-inner{position:relative;z-index:2;text-align:center;max-width:800px;margin:0 auto;padding:0 24px;}
.cta-banner h2{font-family:var(--serif);font-size:clamp(26px,3.5vw,40px);font-weight:700;color:#fff;margin:0 0 18px;letter-spacing:.05em;}
.cta-banner p{font-size:16px;color:rgba(255,255,255,.78);margin:0 0 36px;line-height:1.85;}
.cta-banner .btn-primary{background:var(--gold-3);color:var(--navy);}
.cta-banner .btn-primary:hover{background:#fff;color:var(--navy);}

/* ========================================================================
   Service detail page
   ======================================================================== */
.service-detail{max-width:960px;margin:0 auto;}
.service-detail .cover{aspect-ratio:16/9;overflow:hidden;margin-bottom:40px;background:var(--cream-2);position:relative;}
.service-detail .cover img{width:100%;height:100%;object-fit:cover;}
.service-detail .cover.cover-contain{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-2) 100%);display:flex;align-items:center;justify-content:center;}
.service-detail .cover.cover-contain img{object-fit:contain;padding:24px;}
.service-detail h1{font-family:var(--serif);font-size:clamp(28px,4vw,40px);font-weight:700;margin:0 0 16px;color:var(--ink);letter-spacing:.04em;}
.service-detail .catch{font-size:16px;color:var(--gold-2);font-weight:500;letter-spacing:.03em;margin:0 0 32px;padding-bottom:20px;border-bottom:1px solid var(--border);line-height:1.7;}
.service-detail .service-intro{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-2) 100%);border-left:4px solid var(--gold);padding:28px 32px;margin:0 0 40px;}
.service-detail .service-intro p{margin:0 0 12px;font-size:15px;color:var(--ink-2);line-height:1.9;}
.service-detail .service-intro p:last-child{margin-bottom:0;}
.service-detail .content{font-size:16px;line-height:1.9;}
.service-detail .content p{margin:0 0 18px;color:var(--ink-2);}
.service-detail .content h1{font-family:var(--serif);font-size:22px;margin:48px 0 20px;padding-bottom:14px;border-bottom:2px solid var(--gold);color:var(--ink);letter-spacing:.03em;}
.service-detail .content h2,.service-detail .content h3{font-family:var(--serif);font-size:20px;margin:36px 0 16px;color:var(--ink);}
.service-detail .content img{max-width:100%;height:auto;margin:24px 0;box-shadow:var(--shadow-sm);}
.service-detail .content a{color:var(--gold-2);border-bottom:1px solid transparent;}
.service-detail .content a:hover{border-bottom-color:var(--gold);}

/* Feature list (used on service pages) */
.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin:32px 0;}
.feature-list .item{background:#fff;border:1px solid var(--border);padding:24px;display:flex;gap:14px;align-items:flex-start;transition:all .25s;}
.feature-list .item:hover{border-color:var(--gold-3);box-shadow:var(--shadow-sm);}
.feature-list .item .check{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;}
.feature-list .item .check svg{width:14px;height:14px;}
.feature-list .item h4{font-size:15px;margin:0 0 6px;color:var(--ink);font-weight:600;}
.feature-list .item p{font-size:13px;color:var(--ink-3);margin:0;line-height:1.7;}
/* ===== Case grid ===== */
.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.case-card{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden;transition:all .2s;}
.case-card:hover{box-shadow:0 10px 24px rgba(0,0,0,.08);transform:translateY(-4px);}
.case-card .cover{aspect-ratio:4/3;background:#e9e4d4;overflow:hidden;}
.case-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.case-card:hover .cover img{transform:scale(1.06);}
.case-card .body{padding:20px;}
.case-card .name{font-size:17px;font-weight:600;margin:0 0 10px;color:var(--ink);}
.case-card .desc{font-size:13px;color:#666;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
/* ===== News list ===== */
.news-list{display:grid;grid-template-columns:1fr;gap:28px;max-width:900px;margin:0 auto;}
.news-item{display:grid;grid-template-columns:220px 1fr;gap:24px;padding-bottom:28px;border-bottom:1px solid var(--border);}
.news-item .thumb{background:#e9e4d4;border-radius:4px;overflow:hidden;aspect-ratio:16/10;}
.news-item .thumb img{width:100%;height:100%;object-fit:cover;}
.news-item .info h3{font-size:18px;margin:0 0 10px;}
.news-item .info h3 a{color:var(--ink);}
.news-item .info h3 a:hover{color:var(--gold);}
.news-item .info .date{font-size:12px;color:var(--muted);letter-spacing:1px;margin:0 0 10px;}
.news-item .info .excerpt{font-size:14px;color:#666;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
@media (max-width:640px){.news-item{grid-template-columns:1fr;}}
/* ===== Single post wrapper ===== */
.post-wrap{max-width:820px;margin:0 auto;}
.post-wrap h1{font-size:28px;margin:0 0 14px;}
.post-wrap .meta{color:var(--muted);font-size:13px;letter-spacing:1px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:32px;}
.post-wrap .content{font-size:15px;}
.post-wrap .content p{margin:0 0 16px;}
.post-wrap .content a{color:var(--gold);word-break:break-all;}
.post-wrap .content img{margin:24px auto;border-radius:4px;}
.post-wrap .content h2,.post-wrap .content h3{margin:32px 0 16px;}
.post-wrap .content iframe{max-width:100%;display:block;margin:24px auto;}
.post-back{text-align:center;margin-top:48px;}
/* ========================================================================
   Contact
   ======================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:56px;}
@media (max-width:840px){.contact-grid{grid-template-columns:1fr;gap:40px;}}
.contact-info{display:flex;flex-direction:column;gap:16px;}
.contact-info .item{padding:24px 28px;background:#fff;border:1px solid var(--border);border-left:3px solid var(--gold);transition:all .25s;display:flex;gap:16px;align-items:flex-start;}
.contact-info .item:hover{border-color:var(--gold-3);border-left-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateX(4px);}
.contact-info .item .icon{flex-shrink:0;color:var(--gold-2);width:28px;height:28px;}
.contact-info .item .icon svg{width:100%;height:100%;}
.contact-info .label{font-size:11px;letter-spacing:.3em;color:var(--gold-2);font-weight:700;margin:0 0 8px;text-transform:uppercase;}
.contact-info .value{font-size:15px;color:var(--ink);margin:0;line-height:1.7;}
.lark-form-wrap{position:relative;background:#fff;border:1px solid var(--border);}
.lark-form-wrap::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-3));z-index:1;}
.lark-form-iframe{width:100%;height:700px;border:0;display:block;}
.lark-form-footer{padding:14px 24px;border-top:1px solid var(--border);text-align:center;background:var(--cream);}
.btn-lark-open{display:inline-block;padding:11px 28px;background:var(--navy);color:#fff;font-size:11px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;text-decoration:none;transition:all .25s;}
.btn-lark-open:hover{background:var(--gold);color:var(--navy);}
@media(max-width:840px){.lark-form-iframe{height:560px;}}
.map-wrap{margin-top:60px;border:1px solid var(--border);overflow:hidden;}
.map-wrap iframe{width:100%;border:0;display:block;}

/* ========================================================================
   CEO message
   ======================================================================== */
.ceo-heading{text-align:center;font-family:var(--serif);font-size:clamp(26px,3.5vw,36px);letter-spacing:.08em;margin:0;color:var(--ink);}
.ceo-sub{text-align:center;font-size:12px;letter-spacing:.4em;color:var(--muted);margin:16px 0 0;text-transform:uppercase;}
.ceo-sub::after{content:"";display:block;width:48px;height:2px;background:var(--gold);margin:20px auto 0;}
.ceo-body{font-size:16px;line-height:2;color:var(--ink-2);margin:48px auto 0;max-width:760px;position:relative;}
.ceo-body::before{content:"\201C";position:absolute;top:-40px;left:-20px;font-family:var(--serif);font-size:120px;color:var(--gold-3);opacity:.4;line-height:1;pointer-events:none;}
.ceo-body p{margin:0 0 18px;text-align:justify;}
.ceo-signature{text-align:right;margin:40px 0 0;font-size:14px;color:var(--ink-3);line-height:1.8;padding-top:24px;border-top:1px solid var(--border);max-width:760px;margin-left:auto;margin-right:auto;}
.ceo-signature strong{font-family:var(--serif);font-size:20px;color:var(--ink);letter-spacing:.1em;display:block;margin-top:6px;}

/* ========================================================================
   Corporate profile table
   ======================================================================== */
.corp-heading{text-align:center;font-family:var(--serif);font-size:clamp(26px,3.5vw,36px);letter-spacing:.08em;margin:0;color:var(--ink);}
.corp-sub{text-align:center;font-size:12px;letter-spacing:.4em;color:var(--muted);margin:16px 0 0;text-transform:uppercase;}
.corp-sub::after{content:"";display:block;width:48px;height:2px;background:var(--gold);margin:20px auto 48px;}
.corp-table{width:100%;max-width:860px;margin:0 auto;border-collapse:collapse;font-size:15px;}
.corp-table tr{border-bottom:1px solid var(--border);transition:background .2s;}
.corp-table tr:first-child{border-top:1px solid var(--border);}
.corp-table tr:hover{background:var(--cream);}
.corp-table th{text-align:left;padding:22px 24px;font-weight:600;color:var(--navy);width:200px;letter-spacing:.06em;vertical-align:top;font-family:var(--serif);}
.corp-table td{padding:22px 24px;color:var(--ink-2);line-height:1.85;}
@media (max-width:640px){.corp-table th,.corp-table td{display:block;width:100%;padding:16px 8px;}.corp-table th{border-bottom:0;padding-bottom:4px;color:var(--gold-2);font-size:12px;letter-spacing:.2em;text-transform:uppercase;}.corp-table td{padding-top:4px;padding-bottom:18px;}}
.corp-biz{margin:0;padding:0;list-style:none;}
.corp-biz li{padding:6px 0 6px 24px;position:relative;color:var(--ink-2);}
.corp-biz li::before{content:"";position:absolute;left:0;top:14px;width:12px;height:2px;background:var(--gold);}

/* ========================================================================
   About — timeline
   ======================================================================== */
.timeline{max-width:800px;margin:0 auto;position:relative;padding:20px 0;}
.timeline::before{content:"";position:absolute;top:0;bottom:0;left:120px;width:2px;background:var(--gold);opacity:.4;}
.timeline-item{display:grid;grid-template-columns:100px 40px 1fr;gap:24px;align-items:start;padding:20px 0;}
.timeline-item .year{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--navy);text-align:right;line-height:1.2;}
.timeline-item .dot{position:relative;width:16px;height:16px;border-radius:50%;background:var(--gold);margin:8px auto 0;box-shadow:0 0 0 6px var(--cream),0 0 0 7px var(--gold);z-index:1;}
.timeline-item .text{font-size:15px;color:var(--ink-2);line-height:1.85;padding-top:2px;}
.timeline-item .text strong{color:var(--ink);display:block;margin-bottom:4px;font-size:16px;}
@media (max-width:600px){.timeline::before{left:28px;}.timeline-item{grid-template-columns:56px 16px 1fr;gap:12px;}.timeline-item .year{font-size:16px;text-align:left;}.timeline-item .dot{width:12px;height:12px;box-shadow:0 0 0 5px var(--cream),0 0 0 6px var(--gold);}}
/* ===== Business chart ===== */
.biz-chart{display:flex;gap:40px;align-items:center;flex-wrap:wrap;justify-content:center;max-width:900px;margin:48px auto 0;}
.biz-chart .pie{--p1:65;--p2:35;width:220px;height:220px;border-radius:50%;background:conic-gradient(var(--gold) 0 calc(var(--p1)*1%),#0168b5 0 100%);flex-shrink:0;box-shadow:0 6px 24px rgba(0,0,0,.08);position:relative;}
.biz-chart .legend{display:flex;flex-direction:column;gap:16px;}
.biz-chart .legend .item{display:flex;align-items:center;gap:14px;font-size:15px;}
.biz-chart .legend .dot{width:18px;height:18px;border-radius:3px;display:inline-block;}
/* ========================================================================
   Service detail — hero block (editorial split layout)
   ======================================================================== */
.svc-hero{background:linear-gradient(180deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;padding:100px 0 120px;position:relative;overflow:hidden;}
.svc-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 85% 30%,rgba(196,161,90,.18),transparent 50%),radial-gradient(circle at 10% 100%,rgba(196,161,90,.1),transparent 45%);pointer-events:none;}
.svc-hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:72px;align-items:center;position:relative;z-index:2;}
@media (max-width:900px){.svc-hero-grid{grid-template-columns:1fr;gap:48px;}.svc-hero{padding:72px 0 80px;}}
.svc-hero-meta .eyebrow{color:var(--gold-3);margin-bottom:28px;}
.svc-hero-meta h1{font-family:var(--serif);font-size:clamp(34px,5vw,56px);font-weight:700;letter-spacing:.05em;color:#fff;margin:0 0 20px;line-height:1.25;}
.svc-hero-meta .catch{font-size:18px;color:var(--gold-3);letter-spacing:.03em;line-height:1.7;margin:0 0 16px;font-weight:500;}
.svc-hero-meta .sub{font-size:14px;letter-spacing:.18em;color:rgba(255,255,255,.72);margin:0 0 40px;text-transform:uppercase;}
.svc-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;}
.svc-hero-cover{aspect-ratio:4/5;background:var(--navy-3);border:1px solid rgba(196,161,90,.3);overflow:hidden;position:relative;box-shadow:0 40px 80px rgba(0,0,0,.4);}
.svc-hero-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(12,28,44,.3) 100%);pointer-events:none;}
.svc-hero-cover img{width:100%;height:100%;object-fit:cover;}
.svc-hero-cover.cover-contain{aspect-ratio:3/4;background:linear-gradient(135deg,#1e3349,#0c1c2c);display:flex;align-items:center;justify-content:center;}
.svc-hero-cover.cover-contain img{object-fit:contain;padding:32px;}

/* Overview block */
.svc-overview{font-size:17px;line-height:2;color:var(--ink-2);text-align:center;}
.svc-overview p{margin:0 0 16px;}
.svc-overview p:first-letter{font-family:var(--serif);font-size:2em;font-weight:700;color:var(--gold-2);margin-right:6px;line-height:1;float:left;padding:4px 8px 0 0;}

/* ========================================================================
   Module stack — 4 big numbered cards
   ======================================================================== */
.module-stack{display:grid;grid-template-columns:1fr;gap:24px;max-width:1080px;margin:0 auto;}
.module-card{display:grid;grid-template-columns:120px 1fr;gap:32px;background:#fff;border:1px solid var(--border);padding:36px 40px;transition:all .3s;position:relative;}
.module-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(.5);transform-origin:top center;transition:transform .35s;}
.module-card:hover{box-shadow:var(--shadow-md);border-color:var(--gold-3);}
.module-card:hover::before{transform:scaleY(1);}
.module-card .roman{font-family:var(--serif);font-size:72px;font-weight:700;color:var(--gold);line-height:1;letter-spacing:-.05em;}
.module-card .body .module-eyebrow{display:block;font-size:11px;letter-spacing:.3em;color:var(--gold-2);font-weight:700;margin:0 0 10px;text-transform:uppercase;}
.module-card .body h3{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--ink);margin:0 0 12px;letter-spacing:.03em;}
.module-card .body .module-intro{font-size:15px;color:var(--ink-3);margin:0 0 20px;line-height:1.7;font-style:italic;}
.module-card .body ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:10px 32px;}
.module-card .body ul li{position:relative;padding-left:26px;font-size:14px;color:var(--ink-2);line-height:1.7;}
.module-card .body ul li::before{content:"";position:absolute;left:0;top:10px;width:14px;height:2px;background:var(--gold);}
@media (max-width:760px){.module-card{grid-template-columns:1fr;gap:16px;padding:28px 24px;}.module-card .roman{font-size:56px;}.module-card .body ul{grid-template-columns:1fr;}}

/* ========================================================================
   Feature grid — 6 icon cards
   ======================================================================== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto;}
@media (max-width:900px){.feature-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.feature-grid{grid-template-columns:1fr;}}
.feature-card{background:#fff;border:1px solid var(--border);padding:32px 28px;text-align:left;transition:all .3s;position:relative;}
.feature-card:hover{border-color:var(--gold-3);transform:translateY(-4px);box-shadow:var(--shadow-md);}
.feature-card .f-icon{width:44px;height:44px;color:var(--gold-2);margin-bottom:18px;display:flex;align-items:center;justify-content:flex-start;}
.feature-card .f-icon svg{width:36px;height:36px;}
.feature-card h4{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--ink);margin:0 0 10px;letter-spacing:.03em;}
.feature-card p{font-size:14px;color:var(--ink-3);margin:0;line-height:1.75;}

/* ========================================================================
   Handbook — download + PDF preview
   ======================================================================== */
.handbook-section{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%);}
.handbook-grid{display:grid;grid-template-columns:340px 1fr;gap:56px;max-width:1080px;margin:0 auto 48px;align-items:start;}
@media (max-width:840px){.handbook-grid{grid-template-columns:1fr;gap:40px;}}
.handbook-cover{position:sticky;top:100px;}
.cover-frame{aspect-ratio:3/4;background:linear-gradient(150deg,var(--navy) 0%,var(--navy-2) 60%,var(--navy-3) 100%);color:#fff;padding:36px 28px;display:flex;flex-direction:column;position:relative;box-shadow:0 30px 60px rgba(12,28,44,.25);border:1px solid rgba(196,161,90,.3);}
.cover-frame::before{content:"";position:absolute;top:12px;left:12px;right:12px;bottom:12px;border:1px solid rgba(196,161,90,.4);pointer-events:none;}
.cover-frame::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(196,161,90,.18),transparent 60%);pointer-events:none;}
.cover-frame > *{position:relative;z-index:2;}
.cover-frame .cover-eyebrow{font-size:10px;letter-spacing:.3em;color:var(--gold-3);text-transform:uppercase;margin-bottom:auto;padding-bottom:28px;font-weight:600;}
.cover-frame .cover-title{font-family:var(--serif);font-size:28px;font-weight:700;color:#fff;margin:0 0 12px;letter-spacing:.05em;line-height:1.3;}
.cover-frame .cover-meta{font-size:12px;color:rgba(255,255,255,.65);letter-spacing:.1em;display:flex;gap:8px;align-items:center;margin-top:12px;}
.cover-frame .cover-meta .dot{opacity:.4;}
.cover-frame .cover-ornament{width:40px;height:2px;background:var(--gold);margin:28px 0 0;}
.cover-frame .cover-tag{position:absolute;top:24px;right:24px;background:var(--gold);color:var(--navy);font-size:11px;font-weight:700;padding:6px 12px;letter-spacing:.2em;z-index:3;}
.handbook-info{padding:16px 0;}
.handbook-info .handbook-desc{font-size:16px;line-height:1.9;color:var(--ink-2);margin:0 0 28px;}
.handbook-info .toc-title{font-size:13px;letter-spacing:.3em;color:var(--gold-2);font-weight:700;margin:0 0 16px;text-transform:uppercase;}
.handbook-info .handbook-toc{margin:0 0 32px;padding:0;list-style:none;counter-reset:chap;}
.handbook-info .handbook-toc li{counter-increment:chap;padding:14px 0 14px 52px;border-bottom:1px solid var(--border);position:relative;font-size:15px;color:var(--ink-2);}
.handbook-info .handbook-toc li::before{content:counter(chap,decimal-leading-zero);position:absolute;left:0;top:14px;font-family:var(--serif);font-size:16px;color:var(--gold-2);font-weight:700;letter-spacing:.1em;}
.handbook-info .handbook-toc li:last-child{border-bottom:0;}
.handbook-preview{max-width:1080px;margin:0 auto;}
.handbook-preview .preview-label{font-size:12px;letter-spacing:.4em;color:var(--gold-2);font-weight:700;text-transform:uppercase;margin:0 0 16px;text-align:center;}
.handbook-preview iframe{width:100%;height:900px;border:1px solid var(--border);background:#fff;display:block;}
.handbook-preview .preview-note{font-size:13px;color:var(--muted);text-align:center;margin:20px 0 0;font-style:italic;}
@media (max-width:640px){.handbook-preview iframe{height:600px;}}

/* ========================================================================
   Footer
   ======================================================================== */
.site-footer{background:var(--navy);color:rgba(255,255,255,.65);padding:80px 0 32px;font-size:14px;position:relative;}
.site-footer::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--gold);}
.site-footer a{color:rgba(255,255,255,.78);}
.site-footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:56px;}
@media (max-width:840px){.site-footer-inner{grid-template-columns:1fr;gap:36px;text-align:center;}}
.footer-brand h3{font-family:var(--serif);margin:0 0 14px;color:#fff;font-size:28px;letter-spacing:.2em;}
.footer-brand p{margin:0 0 8px;font-size:13px;color:rgba(255,255,255,.6);line-height:1.8;}
.footer-brand .tagline{color:var(--gold-3);font-size:13px;letter-spacing:.1em;margin-bottom:16px;}
.footer-col h4{font-family:var(--serif);font-size:13px;letter-spacing:.3em;color:var(--gold-3);margin:0 0 20px;text-transform:uppercase;}
.footer-col ul{list-style:none;padding:0;margin:0;}
.footer-col li{margin-bottom:12px;font-size:14px;}
.footer-col a{color:rgba(255,255,255,.7);transition:all .2s;}
.footer-col a:hover{color:var(--gold-3);padding-left:6px;}
.copyright{text-align:center;padding-top:32px;margin-top:48px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.2em;}

/* ========================================================================
   Back to top
   ======================================================================== */
.to-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;background:var(--navy);color:#fff;border:1px solid var(--gold);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:99;transition:all .25s;font-size:16px;}
.to-top:hover{background:var(--gold);color:var(--navy);transform:translateY(-4px);}
.to-top.visible{display:flex;}

/* ========================================================================
   News / case list leftovers (kept functional even if hidden from nav)
   ======================================================================== */
.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;}
.case-card{background:#fff;border:1px solid var(--border);overflow:hidden;transition:all .3s;display:flex;flex-direction:column;}
.case-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--gold-3);}
.case-card .cover{aspect-ratio:4/3;background:var(--cream-2);overflow:hidden;}
.case-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.case-card:hover .cover img{transform:scale(1.06);}
.case-card .body{padding:24px;}
.case-card .name{font-family:var(--serif);font-size:18px;font-weight:700;margin:0 0 10px;color:var(--ink);}
.case-card .desc{font-size:13px;color:var(--ink-3);margin:0;line-height:1.75;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.news-list{display:grid;grid-template-columns:1fr;gap:32px;max-width:960px;margin:0 auto;}
.news-item{display:grid;grid-template-columns:240px 1fr;gap:32px;padding-bottom:32px;border-bottom:1px solid var(--border);}
.news-item .thumb{background:var(--cream-2);overflow:hidden;aspect-ratio:16/10;}
.news-item .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.news-item:hover .thumb img{transform:scale(1.04);}
.news-item .info h3{font-family:var(--serif);font-size:20px;margin:0 0 10px;color:var(--ink);}
.news-item .info h3 a{color:var(--ink);}
.news-item .info h3 a:hover{color:var(--gold-2);}
.news-item .info .date{font-size:12px;color:var(--gold-2);letter-spacing:.2em;margin:0 0 12px;font-weight:600;}
.news-item .info .excerpt{font-size:14px;color:var(--ink-3);margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.8;}
@media (max-width:640px){.news-item{grid-template-columns:1fr;gap:16px;}}
.post-wrap{max-width:820px;margin:0 auto;}
.post-wrap h1{font-family:var(--serif);font-size:clamp(24px,3.5vw,36px);margin:0 0 16px;color:var(--ink);}
.post-wrap .meta{color:var(--gold-2);font-size:12px;letter-spacing:.3em;font-weight:600;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:40px;text-transform:uppercase;}
.post-wrap .content{font-size:16px;line-height:1.9;}
.post-wrap .content p{margin:0 0 18px;color:var(--ink-2);}
.post-wrap .content a{color:var(--gold-2);border-bottom:1px solid transparent;word-break:break-all;}
.post-wrap .content a:hover{border-bottom-color:var(--gold);}
.post-wrap .content img{margin:28px auto;}
.post-wrap .content h2,.post-wrap .content h3{font-family:var(--serif);margin:40px 0 18px;}
.post-back{text-align:center;margin-top:60px;}
