:root{
  --paper:#FCFBF9;
  --ink:#16150F;
  --ink-2:#2A2820;
  --muted:#6E6A60;
  --line:#E6E1D6;
  --line-2:#D8D2C4;
  --stone:#F1EDE3;
  --gold:#B8934A;
  --gold-light:#F5EDD8;
  --r:2px;
  --shadow:0 40px 80px -40px rgba(28,24,12,.35);
  --ease:cubic-bezier(.19,1,.22,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:"DM Sans",sans-serif;background:var(--paper);color:var(--ink);
  line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.serif{font-family:"Bebas Neue",sans-serif;font-weight:400;letter-spacing:.04em;line-height:.95}
h1,h2,h3,h4{font-family:"Bebas Neue",sans-serif;font-weight:400;line-height:.95;letter-spacing:.04em}
h1 em,h2 em,h3 em,h4 em{font-style:normal;font-family:"DM Sans",sans-serif;font-weight:300;letter-spacing:-.01em;font-size:.72em;display:block;line-height:1.1;opacity:.75}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.section{padding:clamp(70px,9vw,150px) 0}
.kicker{
  font-size:.68rem;font-weight:700;letter-spacing:.38em;text-transform:uppercase;
  color:var(--muted);display:inline-flex;align-items:center;gap:12px;
  font-family:"DM Sans",sans-serif;
}
.kicker .dash{width:30px;height:1px;background:var(--ink)}
.kicker img{width: 190px;}
.rule-top{border-top:1px solid var(--line)}
.lnk{
  display:inline-flex;align-items:center;gap:.7rem;font-weight:600;font-size:.9rem;
  letter-spacing:.02em;position:relative;padding-bottom:4px;transition:.4s var(--ease);
}
.lnk::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--ink);transform-origin:right;transition:transform .5s var(--ease)}
.lnk:hover::after{transform:scaleX(0);transform-origin:left}
.lnk .c{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--ink);border-radius:50%;font-size:.8rem;transition:.4s var(--ease)}
.lnk:hover .c{background:var(--ink);color:var(--paper);transform:rotate(-45deg)}
.btn-pill{
  display:inline-flex;align-items:center;gap:.7rem;font-weight:600;font-size:.9rem;letter-spacing:.02em;
  padding:1rem 1.9rem;border:1px solid var(--ink);border-radius:100px;background:var(--ink);color:var(--paper);
  transition:.45s var(--ease);
}
.btn-pill:hover{background:transparent;color:var(--ink)}
.btn-line{
  display:inline-flex;align-items:center;gap:.7rem;font-weight:600;font-size:.9rem;letter-spacing:.02em;
  padding:1rem 1.9rem;border:1px solid var(--line-2);border-radius:100px;background:transparent;color:var(--ink);
  transition:.45s var(--ease);
}
.btn-line:hover{border-color:var(--ink)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.45s var(--ease)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:24px 32px;width:75%;margin:0 auto;transition:.45s var(--ease)}
.nav.scrolled{background:rgba(252,251,249,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav.scrolled .nav-in{padding:16px 32px}
.logo img{height:35px;}
.menu{display:flex;gap:36px;list-style:none;margin:0;padding:0}
.menu a{font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);transition:.3s;opacity:.65;font-family:"DM Sans",sans-serif}
.menu a:hover{opacity:1}
.nav-r{display:flex;align-items:center;gap:20px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.burger span{width:24px;height:1.5px;background:var(--ink);transition:.3s}
.mob{position:fixed;inset:0;background:var(--paper);z-index:1100;transform:translateY(-100%);transition:.55s var(--ease);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px}
.mob.open{transform:translateY(0)}
.mob a{font-family:"Bebas Neue";font-size:2.8rem;padding:.3rem;letter-spacing:.06em}
.mob-x{position:absolute;top:28px;right:32px;font-size:2.2rem;background:none;border:none;cursor:pointer}

/* HERO */
.hero{padding-top:140px;text-align:center}
.hero-meta{display:flex;justify-content:center;gap:34px;flex-wrap:wrap;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:40px}
.hero-meta span{display:inline-flex;align-items:center;gap:12px}
.hero-meta span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--ink);opacity:.4}
.hero h1{font-size:clamp(4rem,6.5vw,6.5rem);font-weight:400;letter-spacing:.03em}
.hero h1 em{font-size:.38em;letter-spacing:.22em;text-transform:uppercase;opacity:.5;display:block;font-weight:700;margin-bottom:-8px}
.hero-sub{font-size:1.12rem;color:var(--muted);max-width:520px;margin:28px auto 36px;font-weight:400;line-height:1.7}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-figure{margin-top:clamp(50px,7vw,90px);position:relative;border-radius:var(--r);overflow:hidden}
.hero-figure img{width:100%;height:clamp(360px,62vh,640px);object-fit:cover;transform:scale(1.06);transition:1.6s var(--ease)}
.hero-figure.in img{transform:scale(1)}
.hero-tab{
  position:absolute;left:0;bottom:0;background:var(--paper);padding:22px 30px;border-top-right-radius:14px;
  display:flex;align-items:baseline;gap:14px;
}
.hero-tab .n{font-family:"Bebas Neue";font-size:2.6rem;line-height:1;letter-spacing:.06em}
.hero-tab .t{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);max-width:160px;font-family:"DM Sans"}

/* STAT RIBBON */
.ribbon{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:8px}
.ribbon .cell{padding:40px 26px;border-right:1px solid var(--line)}
.ribbon .cell:last-child{border-right:none}
.ribbon .n{font-family:"Bebas Neue";font-size:clamp(2.8rem,4.5vw,4rem);line-height:1;letter-spacing:.04em}
.ribbon .l{font-size:.84rem;color:var(--muted);margin-top:10px;max-width:210px;font-weight:400}

/* ============================================
   MAINLAND PHILOSOPHY SECTION — NEW
   ============================================ */
.philosophy{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.philosophy::before{
  content:"MAINLAND";position:absolute;left:-20px;top:50%;transform:translateY(-50%);
  font-family:"Bebas Neue";font-size:clamp(8rem,18vw,22rem);
  color:rgba(255,255,255,.03);white-space:nowrap;line-height:1;pointer-events:none;letter-spacing:.05em;
}
.phil-grid{display:grid;gap:clamp(40px,6vw,100px);align-items:start}
.phil-left .kicker{color:rgba(255,255,255,.5)}
.phil-left .kicker .dash{background:rgba(255,255,255,.4)}
.phil-left h2{font-size:clamp(2.4rem,3.5vw,3.5rem);line-height: 1.1;margin:20px 0 28px;color:var(--paper);max-width:520px}
.phil-left h2 em{font-style:italic;color:var(--gold)}
.phil-left > p{color:rgba(255,255,255,.65);font-size:1rem;max-width:480px;margin-bottom:36px;line-height:1.75}
.phil-pillars{display:flex;flex-direction:column;gap:0;margin-top:48px;border-top:1px solid rgba(255,255,255,.12)}
.pillar{display:grid;grid-template-columns:60px 1fr;gap:24px;align-items:start;padding:28px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.pillar-num{font-family:"Bebas Neue";font-size:1.4rem;color:var(--gold);opacity:.7;padding-top:4px;letter-spacing:.06em}
.pillar h4{font-size:1.15rem;color:var(--paper);margin:0 0 8px;font-family:"DM Sans";font-weight:700;letter-spacing:.01em;text-transform:uppercase;font-size:.88rem}
.pillar p{font-size:.88rem;color:rgba(255,255,255,.55);margin:0;line-height:1.7}
.phil-right{position:sticky;top:120px}
.phil-quote-block{border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:40px;margin-bottom:24px;position:relative}
/* .phil-quote-block::before{content:"\201C";position:absolute;top:-30px;left:28px;font-family:"Bebas Neue";font-size:6rem;color:var(--gold);opacity:.4;line-height:1} */
.phil-quote{font-family:"DM Sans";font-style:italic;font-size:clamp(1rem,1vw,1rem);color:var(--paper);line-height:1.65;margin-bottom:20px;font-weight:300}
.phil-attr{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.phil-values{display:grid;grid-template-columns: repeat(4, 1fr);gap:12px;margin-top:24px}
.pval{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:20px 22px}
.pval .vl{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pval .vt{font-family:"Bebas Neue";font-size:1.5rem;color:var(--paper);letter-spacing:.05em}
.pval .vd{font-size:.82rem;color:rgba(255,255,255,.45);margin-top:6px;line-height:1.5}

/* LEGACY */
.legacy{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(40px,6vw,90px);align-items:center}
.legacy-fig{position:relative}
.legacy-fig img{width:100%;height:680px;object-fit:cover;border-radius:var(--r)}
.legacy-fig .mark{position:absolute;top:-30px;left:-10px;font-family:"Bebas Neue";font-size:9rem;color:var(--ink);opacity:.06;line-height:1;letter-spacing:.02em}
.legacy h2{font-size:clamp(2.2rem,4.4vw,3.5rem);margin:22px 0 28px;max-width:520px}
.legacy h2 em{font-style:italic}
.legacy p{color:var(--muted);margin-bottom:18px;max-width:520px}
.legacy-meta{display:flex;gap:46px;margin-top:36px;padding-top:32px;border-top:1px solid var(--line)}
.legacy-meta .n{font-family:"Bebas Neue";font-size:2.8rem;line-height:1;letter-spacing:.04em}
.legacy-meta .l{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* PROJECTS */
#about{padding-top:0;padding-bottom:0;}
.shead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:50px}
.shead h2{font-size:clamp(2.4rem,3.5vw,3.5rem);margin-top:16px}
.shead h2 em{font-style:italic}
.showcase{position:relative}
.track{display:flex;gap:30px;cursor:grab;user-select:none;padding:4px 0 8px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
.track::-webkit-scrollbar{display:none}
.track.drag{cursor:grabbing}
.slide{flex:0 0 clamp(300px,40vw,520px);scroll-snap-align:start}
.slide-fig{position:relative;border-radius:var(--r);overflow:hidden;}
.slide-fig img{width:100%;height:100%;object-fit:cover;transition:1.2s var(--ease);pointer-events:none}
.slide:hover .slide-fig img{transform:scale(1.05)}
.slide-idx{position:absolute;top:22px;left:22px;font-family:"Bebas Neue";font-size:1.6rem;color:#fff;mix-blend-mode:difference;letter-spacing:.06em}
.slide-info{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding-top:22px;border-top:1px solid var(--line);margin-top:22px}
.slide-info h3{font-size:2rem;letter-spacing:.03em}
.slide-info .loc{font-size:.88rem;color:var(--muted);margin-top:6px}
.slide-info .tag{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.slide-info .sq{font-family:"Bebas Neue";font-size:1.5rem;white-space:nowrap;text-align:right;letter-spacing:.04em}
.showcase-foot{display:flex;align-items:center;gap:24px;margin-top:40px}
.progress{flex:1;height:1px;background:var(--line);position:relative}
.progress .bar{position:absolute;left:0;top:0;height:1px;background:var(--ink);width:20%;transition:width .25s var(--ease)}
.arrows{display:flex;gap:12px}
.arrows button{width:50px;height:50px;border:1px solid var(--line-2);border-radius:50%;background:transparent;cursor:pointer;transition:.4s var(--ease);font-size:1rem}
.arrows button:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.drag-hint{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* WHAT WE BUILD */
.build-sec{background:var(--paper); padding-bottom: 40px;}
.bwrap{border-top:1px solid var(--line)}
.brow{display:grid;grid-template-columns:90px 1fr auto;gap:30px;align-items:center;padding:clamp(28px,4vw,46px) 6px;border-bottom:1px solid var(--line);cursor:pointer;transition:.5s var(--ease)}
.brow:hover{padding-left:24px}
.brow .bn{font-family:"Bebas Neue";font-size:1.8rem;color:var(--muted);letter-spacing:.05em}
.brow .bt h3{font-size:clamp(1.6rem,1.8vw,1.8rem)}
.brow .bt p{font-size:.96rem;color:var(--muted);max-width:640px;margin:14px 0 0;max-height:0;overflow:hidden;opacity:0;transition:.6s var(--ease)}
.brow:hover .bt p,.brow.open .bt p{max-height:140px;opacity:1}
.brow .bic{width:62px;height:62px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.5s var(--ease)}
.brow .bic img{width:32px;height:32px;object-fit:contain}
.brow:hover .bic{background:var(--ink)}
.brow:hover .bic img{filter:brightness(0) invert(1)}

/* VANSHVANA */
.vansh{position:relative;min-height:620px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;border-radius:var(--r);overflow:hidden}
.vansh-bg{position:absolute;inset:0}
.vansh-bg img{width:100%;height:100%;object-fit:cover}
.vansh-bg::after{content:"";position:absolute;inset:0;background:rgba(20,22,15,.5)}
.vansh-c{position:relative;z-index:2;max-width:680px;padding:40px}
.vansh-c .kicker{color:rgba(255,255,255,.85)}
.vansh-c .kicker .dash{background:rgba(255,255,255,.85)}
.vansh-c h2{font-size:clamp(2.8rem,3.5vw,3.5rem);margin:20px 0 22px}
.vansh-c h2 em{font-style:italic}
.vansh-c p{color:rgba(255,255,255,.86);max-width:500px;margin:0 auto 30px}
.vansh-c .btn-pill{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.vansh-c .btn-pill:hover{background:transparent;color:#fff}
.vchips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:30px}
.vchips span{font-size:.76rem;padding:.4rem .9rem;border:1px solid rgba(255,255,255,.35);border-radius:100px;color:rgba(255,255,255,.85)}

/* PROCESS */
.timeline{position:relative;margin-top:56px;padding-left:0}
.tline{position:absolute;left:11px;top:6px;bottom:6px;width:1px;background:var(--line)}
.tline .fill{position:absolute;left:0;top:0;width:1px;background:var(--ink);height:0;transition:height .2s linear}
.tstep{position:relative;padding-left:64px;padding-bottom:clamp(34px,4vw,56px)}
.tstep:last-child{padding-bottom:0}
.tdot{position:absolute;left:0;top:2px;width:24px;height:24px;border-radius:50%;border:1px solid var(--line-2);background:var(--paper);display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:600;transition:.4s var(--ease)}
.tstep.on .tdot{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tstep h4{font-size:clamp(1.8rem,3vw,2.8rem);letter-spacing:.04em}
.tstep p{color:var(--muted);max-width:560px;margin:12px 0 0}

/* ============================================
   LINKEDIN ARTICLES SECTION — NEW
   ============================================ */
/* .articles-sec{background:var(--stone)} */

.linkde-section{padding-top: 0;}

.art-intro{max-width:600px;margin-bottom:clamp(40px,5vw,80px)}
.art-intro h2{font-size:clamp(2.4rem,3.5vw,3.5rem);margin:16px 0 22px}
.art-intro h2 em{font-style:italic}
.art-intro p{color:var(--muted);font-size:1.05rem}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.art-card{background:var(--paper);padding:clamp(28px,3.5vw,46px);display:flex;flex-direction:column;transition:.5s var(--ease);position:relative;overflow:hidden}
.art-card::before{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:.5s var(--ease)}
.art-card:hover::before{transform:scaleX(1)}
.art-card:hover{background:var(--ink);color:var(--paper)}
.art-card:hover .art-cat,.art-card:hover .art-date{color:rgba(255,255,255,.45)}
.art-card:hover .art-read{border-color:rgba(255,255,255,.25);color:var(--paper)}
.art-card:hover .art-read:hover{background:var(--paper);color:var(--ink)}
.art-cat{font-size:.68rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;transition:.3s}
.art-num{font-family:"Bebas Neue";font-size:5.5rem;line-height:1;color:var(--line);margin-bottom:16px;transition:.3s;letter-spacing:.06em}
.art-card:hover .art-num{color:rgba(255,255,255,.08)}
.art-card h3{font-size:clamp(1.4rem,2.2vw,1.9rem);margin-bottom:16px;flex:1;transition:.3s;line-height:1.1}
.art-card:hover h3{color:var(--paper)}
.art-excerpt{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:28px;transition:.3s}
.art-card:hover .art-excerpt{color:rgba(255,255,255,.55)}
.art-date{font-size:.76rem;letter-spacing:.1em;color:var(--muted);margin-bottom:20px;transition:.3s}
.art-read{
  display:inline-flex;align-items:center;gap:.6rem;font-weight:600;font-size:.82rem;
  padding:.7rem 1.3rem;border:1px solid var(--line-2);border-radius:100px;
  transition:.4s var(--ease);align-self:flex-start;
}

/* ============================================
   VIDEO REELS SECTION — NEW
   ============================================ */
.reels-sec{background:var(--ink);overflow:hidden;position:relative}
.reels-sec::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(184,147,74,.4),transparent)}
.reels-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:clamp(40px,5vw,70px);gap:24px;flex-wrap:wrap}
.reels-head h2{font-size:clamp(2.4rem,3.5vw,3.5rem);color:var(--paper);margin-top:14px}
.reels-head h2 em{font-style:italic;color:var(--gold)}
.reels-head .kicker{color:rgba(255,255,255,.45)}
.reels-head .kicker .dash{background:rgba(255,255,255,.3)}
.reels-track-wrap{position:relative}
.reels-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding-bottom:4px;cursor:grab}
.reels-track::-webkit-scrollbar{display:none}
.reels-track.drag{cursor:grabbing}
.reel{flex:0 0 220px;scroll-snap-align:start;position:relative;border-radius:14px;overflow:hidden;aspect-ratio:9/16;background:#1a1916;cursor:pointer}
.reel-thumb{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease);display:block}
.reel:hover .reel-thumb{transform:scale(1.04)}
.reel-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.25) 50%, rgba(0,0,0,.05) 100%);transition:.4s var(--ease)}
.reel:hover .reel-overlay{background:linear-gradient(to top, rgba(0,0,0,.95) 0%, rgba(0,0,0,.4) 50%, rgba(0,0,0,.1) 100%)}
.reel-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  transition:.4s var(--ease);
}
.reel:hover .reel-play{background:var(--paper);transform:translate(-50%,-50%) scale(1.1)}
.reel:hover .reel-play svg{fill:var(--ink)}
.reel-play svg{width:18px;height:18px;fill:white;margin-left:3px;transition:.3s}
.reel-cat{position:absolute;top:16px;left:16px;font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);background:rgba(0,0,0,.5);backdrop-filter:blur(8px);padding:.3rem .7rem;border-radius:100px;border:1px solid rgba(184,147,74,.3)}
.reel-info{position:absolute;bottom:0;left:0;right:0;padding:20px 16px 18px}
.reel-ts{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:6px}
.reel-title{font-family:"DM Sans";font-weight:600;font-size:.88rem;color:var(--paper);line-height:1.3}
.reels-foot{display:flex;align-items:center;gap:24px;margin-top:32px}
.reels-progress{flex:1;height:1px;background:rgba(255,255,255,.1);position:relative}
.reels-bar{position:absolute;left:0;top:0;height:1px;background:var(--gold);width:20%;transition:width .25s var(--ease)}
.reels-arrows{display:flex;gap:10px}
.reels-arrows button{
  width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.18);
  background:transparent;cursor:pointer;color:var(--paper);font-size:.9rem;
  transition:.4s var(--ease);
}
.reels-arrows button:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.reels-src{font-size:.74rem;color:rgba(255,255,255,.3);letter-spacing:.1em;margin-top:8px}
.reels-src a{color:rgba(255,255,255,.45);text-decoration:underline;text-underline-offset:3px}
.reels-src a:hover{color:var(--paper)}

/* VIDEO MODAL */
.vmodal{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.4s var(--ease);backdrop-filter:blur(6px)}
.vmodal.open{opacity:1;pointer-events:all}
.vmodal-inner{position:relative;width:min(400px,90vw);aspect-ratio:9/16}
.vmodal-inner iframe{width:100%;height:100%;border:none;border-radius:14px}
.vmodal-close{position:absolute;top:-48px;right:0;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:transparent;color:white;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s}
.vmodal-close:hover{background:white;color:black}

/* NEWS */
.nlist{border-top:1px solid var(--line)}
.nrow{display:grid;grid-template-columns:140px 1fr 130px auto;gap:28px;align-items:center;padding:30px 6px;border-bottom:1px solid var(--line);transition:.5s var(--ease);position:relative}
.nrow:hover{padding-left:22px}
.nrow .ncat{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.nrow h4{font-size:clamp(1.3rem,2.4vw,1.9rem)}
.nrow .ndate{font-size:.84rem;color:var(--muted)}
.nrow .narr{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.4s var(--ease)}
.nrow:hover .narr{background:var(--ink);color:var(--paper);transform:rotate(-45deg)}
.npeek{position:fixed;width:240px;height:300px;border-radius:var(--r);overflow:hidden;pointer-events:none;opacity:0;transform:scale(.92);transition:.3s var(--ease);z-index:60;box-shadow:var(--shadow)}
.npeek img{width:100%;height:100%;object-fit:cover}

/* MARQUEE */
.marq{padding:30px 0;overflow:hidden;white-space:nowrap;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marq-tr{display:inline-flex;gap:46px;animation:scroll 30s linear infinite}
.marq span{font-family:"Bebas Neue";font-size:2.4rem;letter-spacing:.08em}
.marq .s{font-style:normal;opacity:.4}
@keyframes scroll{to{transform:translateX(-50%)}}

/* CTA */
.cta{text-align:center}
.cta .kicker{justify-content:center}
.cta h2{font-size:clamp(2.4rem,3.5vw,3.5rem);max-width:920px;margin:24px auto 32px}
.cta h2 em{font-style:italic}

/* FOOTER */
footer{background:var(--ink);color:rgba(255,255,255,.62);padding:88px 0 34px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:46px}
.flogo img{height:35px; margin-bottom:22px}
.fintro{font-size:.96rem;max-width:300px;margin-bottom:24px}
footer h5{color:#fff;font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px}
footer ul{list-style:none;padding:0;margin:0}
footer li{margin-bottom:13px}
footer li a{font-size:.94rem;transition:.3s}
footer li a:hover{color:#fff;padding-left:5px}
footer .btn-line{border-color:rgba(255,255,255,.3);color:#fff}
footer .btn-line:hover{border-color:#fff}
.fbot{border-top:1px solid rgba(255,255,255,.12);margin-top:64px;padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.84rem}

/* REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:1s var(--ease)}
.reveal.in{opacity:1;transform:none}

.p-top-0{padding-top:0 !important}

/* RESPONSIVE */
@media(max-width:991px){
  .menu,.nav-r .btn-pill{display:none}
  .burger{display:flex}
  .ribbon{grid-template-columns:1fr 1fr}
  .ribbon .cell:nth-child(2){border-right:none}
  .legacy{grid-template-columns:1fr;gap:40px}
  .legacy-fig img{height:480px}
  .nrow{grid-template-columns:1fr auto;gap:14px}
  .nrow .ncat,.nrow .ndate{display:none}
  .fgrid{grid-template-columns:1fr 1fr}
  .phil-grid{grid-template-columns:1fr}
  .phil-right{position:static}
  .art-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  .ribbon{grid-template-columns:1fr}
  .ribbon .cell{border-right:none}
  .hero-meta{gap:18px}
  .slide{flex:0 0 82vw}
  .brow{grid-template-columns:50px 1fr;gap:16px}
  .brow .bic{display:none}
  .fgrid{grid-template-columns:1fr}
  .marq span{font-size:1.5rem}
  .legacy-fig .mark{font-size:6rem}
  .art-grid{grid-template-columns:1fr}
  .phil-values{grid-template-columns:1fr}
  .reel{flex:0 0 160px}
}

@media only screen and (min-width: 1024px) and (max-width: 1500px) {
  .nav-in{width: 95%;}
  .wrap{max-width: 1170px;}
}
/* ============================================================
   HOMEPAGE ENQUIRY FORM (#enquiry)
   Built on the site design tokens — sits between the Legacy and
   Articles sections on a stone band for gentle separation.
   ============================================================ */
/* .enq{background:var(--stone)} */
.enq-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(40px,5vw,90px);align-items:start}

/* intro column */
.enq-intro .kicker{margin-bottom:22px}
.enq-intro h2{font-size:clamp(2.2rem,3.6vw,3.4rem);margin:0 0 22px;line-height:.98}
.enq-intro > p{color:var(--muted);font-size:1.05rem;line-height:1.8;max-width:420px;margin:0 0 clamp(28px,3.5vw,40px)}
.enq-points{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:20px}
.enq-points li{display:flex;gap:16px;align-items:flex-start}
.enq-points .ep-ic{flex:none;width:44px;height:44px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);background:var(--paper)}
.enq-points .ep-ic svg{width:21px;height:21px}
.enq-points strong{display:block;font-family:"DM Sans",sans-serif;font-weight:700;font-size:1rem;letter-spacing:.01em;margin-bottom:2px}
.enq-points span{color:var(--muted);font-size:.92rem;line-height:1.6}

/* form card */
/* .enq-card{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:clamp(26px,3.6vw,48px);box-shadow:var(--shadow)} */
.enq-field{margin-bottom:22px}
.enq-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.enq-label{display:block;font-size:.66rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:11px}

/* radio options */
.enq-options{display:flex;flex-wrap:wrap;gap:10px}
.enq-options input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.enq-opt{display:inline-flex;align-items:center;cursor:pointer;user-select:none;font-size:16px;font-weight:600;color:var(--ink-2);background:var(--paper);border:1px solid #000;border-radius:100px;padding:12px 30px;transition:.3s var(--ease)}
.enq-opt:hover{border-color:var(--ink)}
.enq-options input:checked + .enq-opt{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.enq-options input:focus-visible + .enq-opt{outline:2px solid var(--gold);outline-offset:2px}

/* inputs */
.enq-input,.enq-textarea{width:100%;font-family:"DM Sans",sans-serif;font-size:1rem;color:var(--ink);background:var(--paper);border:1px solid var(--line-2);border-radius:6px;padding:.95rem 1.1rem;transition:.3s var(--ease)}
.enq-textarea{resize:vertical;min-height:140px;line-height:1.6}
.enq-input::placeholder,.enq-textarea::placeholder{color:var(--muted);opacity:.7}
.enq-input:focus,.enq-textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-light)}

/* submit */
.enq-submit{margin-top:4px;border:none;cursor:pointer;font-family:"DM Sans",sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;background:var(--ink);color:var(--paper);padding:1.15rem 2.2rem;border-radius:60px;display:inline-flex;align-items:center;justify-content:center;gap:12px;transition:.4s var(--ease)}
.enq-submit:hover{background:var(--gold);color:#fff}
.enq-submit svg{transition:.4s var(--ease)}
.enq-submit:hover svg{transform:translateX(5px)}

/* alerts */
/* inline field errors + invalid state */
.enq-form .error{display:none;margin-top:7px;font-size:.8rem;color:#c0392b;letter-spacing:.01em}
.enq-input.is-invalid,.enq-textarea.is-invalid{border-color:#d9784f;box-shadow:0 0 0 3px rgba(217,120,79,.12)}

/* submit response message */
.enq-form-message{margin-top:16px;font-size:.95rem;line-height:1.6}
.enq-form-message:empty{margin-top:0}
.enq-form-message.ok{color:#1e7a4d}
.enq-form-message.err{color:#c0392b}

@media(max-width:991px){
  .enq-grid{grid-template-columns:1fr;gap:44px}
}
@media(max-width:560px){
  .enq-row{grid-template-columns:1fr;gap:0}
}
