:root{
  --ink:#101b29;
  --ink-soft:#26354a;
  --paper:#f7f5f1;
  --paper-2:#efece5;
  --gold:#b08d57;
  --gold-d:#9a784599;
  --text:#2c3744;
  --muted:#6d7884;
  --white:#ffffff;
  --maxw:1280px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--text);background:var(--paper);
  font-weight:300;font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;color:var(--ink);margin:0 0 .4em;line-height:1.1}
.serif{font-family:var(--serif)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.btn{
  display:inline-block;font-family:var(--sans);font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;font-size:12px;padding:14px 30px;border:1px solid currentColor;
  transition:.3s;background:transparent;cursor:pointer;
}
.btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-gold{border-color:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.btn-light{color:#fff;border-color:rgba(255,255,255,.7)}
.btn-light:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;transition:.35s ease;
  background:transparent;
}
.site-header.solid{background:rgba(247,245,241,.96);box-shadow:0 1px 0 rgba(16,27,41,.08);backdrop-filter:saturate(1.2) blur(6px)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{font-family:var(--serif);font-size:25px;letter-spacing:.12em;color:#fff;transition:.35s;white-space:nowrap}
.brand small{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.5em;font-weight:300;text-transform:uppercase;margin-top:-2px;opacity:.85}
.solid .brand{color:var(--ink)}
.nav-links{display:flex;gap:30px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{font-size:13px;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.92);font-weight:300;padding:6px 0;position:relative}
.nav-links a:after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:.3s}
.nav-links a:hover:after,.nav-links a.active:after{width:100%}
.solid .nav-links a{color:var(--ink-soft)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:34px;height:26px;position:relative}
.nav-toggle span{position:absolute;left:0;height:2px;width:100%;background:#fff;transition:.3s}
.solid .nav-toggle span{background:var(--ink)}
.nav-toggle span:nth-child(1){top:2px}.nav-toggle span:nth-child(2){top:12px}.nav-toggle span:nth-child(3){top:22px}
.nav-toggle.open span:nth-child(1){top:12px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:12px;transform:rotate(-45deg)}

/* sub-pages have light header by default (no hero) */
.subpage .site-header{background:rgba(247,245,241,.96);box-shadow:0 1px 0 rgba(16,27,41,.08)}
.subpage .brand{color:var(--ink)}
.subpage .nav-links a{color:var(--ink-soft)}
.subpage .nav-toggle span{background:var(--ink)}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,27,41,.35),rgba(16,27,41,.45))}
.hero-inner{position:relative;z-index:2;padding:0 20px;animation:rise 1.4s ease both}
.hero h1{color:#fff;font-size:clamp(46px,9vw,118px);letter-spacing:.04em;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero .tagline{letter-spacing:.55em;text-transform:uppercase;font-size:clamp(12px,1.6vw,17px);font-weight:300;margin:6px 0 34px;padding-left:.55em}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;opacity:.8;font-size:11px;letter-spacing:.3em;text-transform:uppercase}
.scroll-cue:before{content:"";display:block;width:1px;height:46px;background:#fff;margin:0 auto 10px;animation:cue 1.8s infinite}
@keyframes cue{0%{transform:scaleY(.2);transform-origin:top;opacity:.3}50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(.2);transform-origin:bottom;opacity:.3}}

/* ---------- Sections ---------- */
section{padding:96px 0}
.section-head{text-align:center;max-width:760px;margin:0 auto 60px}
.eyebrow{letter-spacing:.42em;text-transform:uppercase;font-size:12px;color:var(--gold);margin-bottom:14px}
.section-head h2{font-size:clamp(34px,5vw,56px)}
.section-head .rule{width:60px;height:1px;background:var(--gold);margin:22px auto 0}
.lead{font-size:19px;color:var(--ink-soft)}
.page-title{padding:150px 0 30px;text-align:center}
.page-title h1{font-size:clamp(40px,7vw,82px);letter-spacing:.04em}
.page-title .eyebrow{margin-bottom:18px}
.back-link{display:inline-block;margin-top:8px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.back-link:hover{color:var(--gold)}

/* intro split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.split .media{min-height:520px;background-size:cover;background-position:center}
.split .body{padding:70px clamp(28px,6vw,90px);display:flex;flex-direction:column;justify-content:center;background:var(--white)}
.split .body.dark{background:var(--ink);color:#cdd6e0}
.split .body.dark h2,.split .body.dark h3{color:#fff}
.split p+p{margin-top:1.1em}

/* feature tiles (portfolio index) */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tile{position:relative;aspect-ratio:3/4;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center}
.tile .tbg{position:absolute;inset:0;background-size:cover;background-position:center;transition:.7s ease}
.tile:after{content:"";position:absolute;inset:0;background:rgba(16,27,41,.4);transition:.4s}
.tile:hover .tbg{transform:scale(1.08)}
.tile:hover:after{background:rgba(16,27,41,.25)}
.tile .tinner{position:relative;z-index:2}
.tile h3{color:#fff;font-size:30px;letter-spacing:.14em;text-transform:uppercase}
.tile .btn{margin-top:14px}

/* galleries */
.gallery{columns:3;column-gap:16px}
.gallery .g-item{break-inside:avoid;margin:0 0 16px;position:relative;cursor:pointer;overflow:hidden;background:var(--paper-2)}
.gallery .g-item img{width:100%;transition:.6s ease;display:block}
.gallery .g-item:hover img{transform:scale(1.05)}
.gallery .g-item:after{content:"";position:absolute;inset:0;background:rgba(16,27,41,0);transition:.35s}
.gallery .g-item:hover:after{background:rgba(16,27,41,.12)}

/* video grid */
.vgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.vcard{position:relative;aspect-ratio:16/9;overflow:hidden;background:#0b1521;display:block}
.vcard img{width:100%;height:100%;object-fit:cover;opacity:.9;transition:.6s}
.vcard:hover img{transform:scale(1.05);opacity:1}
.vcard:after{content:"";position:absolute;inset:0;background:rgba(11,21,33,.25)}
.play{position:absolute;z-index:3;top:50%;left:50%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:50%;border:2px solid rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;transition:.3s}
.vcard:hover .play{background:var(--gold);border-color:var(--gold)}
.play:before{content:"";border-left:18px solid #fff;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}

/* blog */
.posts{display:grid;gap:46px;max-width:920px;margin:0 auto}
.post-card{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;overflow:hidden;box-shadow:0 14px 40px rgba(16,27,41,.07);transition:.4s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 22px 56px rgba(16,27,41,.12)}
.post-card .pc-img{min-height:280px;background-size:cover;background-position:center}
.post-card .pc-body{padding:40px}
.post-meta{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.post-card h3{font-size:32px}
.post-card p{color:var(--muted)}
.article{max-width:760px;margin:0 auto}
.article .cover{width:100%;max-height:560px;object-fit:cover;margin-bottom:40px}
.article h1{font-size:clamp(34px,6vw,60px);text-align:center}
.article .sub{text-align:center;font-style:italic;color:var(--muted);font-family:var(--serif);font-size:23px;margin-bottom:10px}
.article .meta{text-align:center;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:46px}
.article p{margin:0 0 1.3em}
.article h2{font-size:30px;margin:1.4em 0 .5em}
.article .caption{font-style:italic;color:var(--muted);font-family:var(--serif);font-size:20px}

/* contact */
.contact-split{display:grid;grid-template-columns:1fr 1fr;min-height:80vh}
.contact-split .media{background-size:cover;background-position:center;min-height:420px}
.contact-split .body{padding:clamp(40px,6vw,90px);display:flex;flex-direction:column;justify-content:center}
.contact-list{margin:24px 0 8px;font-size:18px}
.contact-list a{border-bottom:1px solid var(--gold);padding-bottom:1px}
.contact-list div{margin-bottom:10px}
.field{margin-bottom:16px}
.field label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field textarea{width:100%;padding:13px 14px;border:1px solid #d8d3c8;background:#fff;font-family:var(--sans);font-size:15px;color:var(--text)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.socials{display:flex;gap:16px;margin-top:26px}
.socials a{width:42px;height:42px;border:1px solid #d2cabb;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
.socials a:hover{background:var(--ink);border-color:var(--ink)}
.socials a:hover svg{fill:#fff}
.socials svg{width:18px;height:18px;fill:var(--ink-soft);transition:.3s}

/* footer */
.site-footer{background:var(--ink);color:#9fb0c2;padding:70px 0 34px;text-align:center}
.site-footer .brand{color:#fff;justify-content:center;margin-bottom:18px;display:inline-block}
.footer-nav{list-style:none;display:flex;flex-wrap:wrap;gap:22px;justify-content:center;padding:0;margin:22px 0;font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.footer-nav a:hover{color:var(--gold)}
.footer-socials{display:flex;gap:14px;justify-content:center;margin:24px 0}
.footer-socials a svg{fill:#9fb0c2;width:18px;height:18px;transition:.3s}
.footer-socials a:hover svg{fill:var(--gold)}
.copyright{font-size:12px;letter-spacing:.08em;color:#5d6e80;margin-top:18px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:.9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(8,13,20,.95);z-index:200;display:none;align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:90vw;max-height:88vh;box-shadow:0 10px 60px rgba(0,0,0,.5)}
.lb .x{position:absolute;top:22px;right:30px;color:#fff;font-size:34px;cursor:pointer;font-family:var(--serif);line-height:1}
.lb .nav-arrow{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:50px;cursor:pointer;padding:0 22px;user-select:none;opacity:.7}
.lb .nav-arrow:hover{opacity:1}
.lb .prev{left:6px}.lb .next{right:6px}

@media(max-width:980px){
  .gallery{columns:2}
  .nav-links{position:fixed;inset:0 0 0 auto;width:78%;max-width:340px;background:var(--ink);flex-direction:column;justify-content:center;gap:26px;transform:translateX(100%);transition:.4s;padding:40px}
  .nav-links.open{transform:none}
  .nav-links a{color:#fff !important;font-size:16px}
  .nav-toggle{display:block;z-index:60}
  .split,.contact-split,.post-card{grid-template-columns:1fr}
  .tiles{grid-template-columns:1fr}
  .tile{aspect-ratio:16/10}
  .vgrid{grid-template-columns:1fr}
  .post-card .pc-img{min-height:240px}
}
@media(max-width:560px){
  .gallery{columns:1}
  section{padding:64px 0}
}

/* course CTA + blog extras */
.course-cta{background:var(--ink);color:#cfd8e2;border-radius:4px;padding:46px clamp(24px,5vw,60px);text-align:center;margin:56px 0 10px}
.course-cta h3{color:#fff;font-size:34px;margin:.1em 0 .4em}
.course-cta p{max-width:560px;margin:0 auto 22px}
.posts + .course-cta{margin-top:64px}
.article blockquote{border-left:2px solid var(--gold);margin:1.4em 0;padding:.2em 0 .2em 22px;font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-soft)}
.article ul{margin:1.1em 0;padding-left:1.2em}
.article li{margin:.4em 0}
.nav-links a.course-link{color:var(--gold);border:1px solid var(--gold);border-radius:3px;padding:7px 14px}
.nav-links a.course-link:after{display:none}
.solid .nav-links a.course-link,.subpage .nav-links a.course-link{color:var(--gold)}

/* ===== menu v2 + course buttons + home blog ===== */
.site-header::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,27,41,.55),rgba(16,27,41,0));z-index:0;pointer-events:none;transition:.35s}
.site-header.solid::before{opacity:0}
.subpage .site-header::before{opacity:0}
.nav-inner{position:relative;z-index:1}
.brand{text-shadow:0 1px 14px rgba(0,0,0,.4)}
.solid .brand,.subpage .brand{text-shadow:none}
.nav-links > li > a{text-shadow:0 1px 10px rgba(0,0,0,.35)}
.solid .nav-links a,.subpage .nav-links a{text-shadow:none}
.nav-links .has-sub{position:relative}
.nav-links .caret{font-size:9px;margin-left:6px;opacity:.85;display:inline-block}
.submenu{list-style:none;margin:0;padding:10px 0;position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);min-width:200px;background:var(--paper);box-shadow:0 16px 44px rgba(16,27,41,.18);border-top:2px solid var(--gold);opacity:0;visibility:hidden;transition:.25s}
.nav-links .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.submenu li{display:block}
.submenu a{display:block;padding:10px 24px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft) !important;white-space:nowrap;text-shadow:none !important}
.submenu a:after{display:none}
.submenu a:hover{background:var(--paper-2);color:var(--ink) !important}
.btn-course{background:#c99b45;border:1px solid #c99b45;color:#1c1304;font-weight:500}
.btn-course:hover{background:#e3b955;border-color:#e3b955;color:#1c1304}
.nav-links a.course-link{background:#c99b45;color:#1c1304 !important;border:1px solid #c99b45;border-radius:3px;padding:9px 16px;font-weight:500;text-shadow:none !important}
.nav-links a.course-link:after{display:none}
.nav-links a.course-link:hover{background:#e3b955;border-color:#e3b955}
.home-banner{background:var(--ink);color:#cfd8e2;padding:66px clamp(24px,6vw,80px);text-align:center}
.home-banner h2{color:#fff;font-size:clamp(32px,5vw,52px);margin:.1em 0 .35em}
.home-banner p{max-width:600px;margin:0 auto 26px;font-size:18px}
.blog-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.bcard{background:#fff;box-shadow:0 12px 34px rgba(16,27,41,.07);overflow:hidden;display:flex;flex-direction:column;transition:.4s}
.bcard:hover{transform:translateY(-5px);box-shadow:0 22px 52px rgba(16,27,41,.13)}
.bcard-img{height:210px;background-size:cover;background-position:center}
.bcard-body{padding:22px 24px 28px}
.bcard h3{font-size:23px;line-height:1.16;margin:.15em 0 .4em}
.bcard p{color:var(--muted);font-size:15px;margin:0}
@media(max-width:980px){
  .submenu{position:static;transform:none;opacity:1;visibility:visible;background:transparent;box-shadow:none;border:0;padding:2px 0 6px 14px}
  .submenu a{color:#fff !important;text-transform:none;font-size:15px;letter-spacing:.04em;padding:9px 0}
  .nav-links .caret{display:none}
  .nav-links a.course-link{display:inline-block;margin-top:6px}
  .site-header::before{display:none}
  .blog-cards{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){ .blog-cards{grid-template-columns:1fr} }
