/* ===========================================================
   SHINE STAR CTC — Production stylesheet
   Shared across all pages
   =========================================================== */
:root{
  --cream:#F4EFE4; --cream-2:#ECE5D6; --sand:#E4DBC8;
  --ink:#12110F; --ink-2:#1b1916;
  --gold:#E0A11A; --gold-deep:#A9780F; --gold-soft:rgba(224,161,26,.12);
  --line:rgba(18,17,15,.14); --line-d:rgba(244,239,228,.16);
  --muted:#6f685c; --r:16px; --maxw:1320px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:'Archivo',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--gold);color:var(--ink)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 36px}
.mono{font-family:'Space Mono',monospace;text-transform:uppercase;letter-spacing:.22em;font-size:11px}
.serif-it{font-family:'Playfair Display',serif;font-style:italic}
.gold{color:var(--gold)}

/* cursor */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:10001;mix-blend-mode:difference}
.cursor-dot{width:7px;height:7px;background:#fff;transform:translate(-50%,-50%)}
.cursor-ring{width:38px;height:38px;border:1.5px solid rgba(255,255,255,.6);transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,border-color .25s}
.cursor-ring.hov{width:64px;height:64px;background:rgba(224,161,26,.18);border-color:transparent;mix-blend-mode:normal}
@media(hover:none){.cursor-dot,.cursor-ring{display:none}}
.grain{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.045;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold));z-index:10000;transition:width .1s linear}

/* ===== NAV ===== */
header.nav{position:fixed;top:0;left:0;right:0;z-index:9000;transition:transform .5s var(--ease)}
header.nav.hide{transform:translateY(-100%)}
.utility{display:flex;justify-content:space-between;align-items:center;padding:9px 36px;background:var(--ink);color:rgba(244,239,228,.72);font-size:12px}
.utility .u-l,.utility .u-r{display:flex;gap:26px;align-items:center}
.utility a{transition:.25s;display:inline-flex;align-items:center;gap:7px}
.utility a:hover{color:var(--gold)}
.utility .gld{color:var(--gold)}
.nav-main{display:flex;justify-content:space-between;align-items:center;padding:18px 36px;transition:.4s var(--ease);border-bottom:1px solid transparent}
.nav.scrolled .nav-main{background:rgba(244,239,228,.9);backdrop-filter:blur(16px) saturate(1.2);border-bottom:1px solid var(--line);padding:13px 36px}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{width:40px;height:40px;border:1.5px solid var(--ink);border-radius:11px;display:flex;align-items:center;justify-content:center;transition:.5s var(--ease)}
.brand .mark svg{width:22px;height:22px;color:var(--gold);transition:transform .7s var(--ease)}
.brand .mark img{width:26px;height:26px;object-fit:contain;transition:transform .7s var(--ease)}
.brand:hover .mark{background:var(--ink);border-color:var(--ink)}
.brand:hover .mark svg,.brand:hover .mark img{transform:rotate(144deg)}
.brand .bt b{font-family:'Anton';font-size:22px;letter-spacing:.5px;display:block;line-height:1}
.brand .bt small{font-family:'Space Mono';font-size:8.5px;letter-spacing:.34em;color:var(--muted)}
.brand-logo{height:50px;width:auto;display:block;transition:height .4s var(--ease)}
.nav.scrolled .brand-logo{height:44px}
.nav-c{display:flex;align-items:center;gap:4px;background:rgba(18,17,15,.04);border:1px solid var(--line);padding:6px;border-radius:40px}
.nav-c a{font-weight:600;font-size:13.5px;padding:9px 17px;border-radius:30px;transition:.3s;color:#2a2823}
.nav-c a:hover{color:var(--ink)}
.nav-c a.active{background:var(--ink);color:var(--cream)}
.nav-r{display:flex;align-items:center;gap:14px}
.magnetic{position:relative;will-change:transform}
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--cream);padding:13px 24px;border-radius:40px;font-weight:700;font-size:14px;border:1px solid var(--ink);overflow:hidden;position:relative;transition:color .35s;cursor:pointer}
.btn span{position:relative;z-index:2}
.btn::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .45s var(--ease);z-index:1}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost::before{background:var(--ink)}
.btn.ghost:hover{color:var(--cream)}
.btn.light{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn.light::before{background:var(--gold)}
.burger{display:none;flex-direction:column;gap:6px;cursor:pointer;z-index:9500}
.burger span{width:28px;height:2px;background:var(--ink);transition:.4s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:9400;display:flex;flex-direction:column;justify-content:center;padding:0 40px;clip-path:circle(0% at 100% 0);transition:clip-path .7s var(--ease);visibility:hidden}
.mobile-menu.open{clip-path:circle(150% at 100% 0);visibility:visible}
.mobile-menu a{color:var(--cream);font-family:'Anton';font-size:clamp(30px,8vw,42px);text-transform:uppercase;padding:9px 0;opacity:0;transform:translateY(20px);transition:.5s var(--ease)}
.mobile-menu a .i{color:var(--gold);font-family:'Space Mono';font-size:13px;margin-right:14px}
.mobile-menu.open a{opacity:1;transform:none}
.mobile-menu.open a:nth-child(1){transition-delay:.15s}.mobile-menu.open a:nth-child(2){transition-delay:.21s}.mobile-menu.open a:nth-child(3){transition-delay:.27s}.mobile-menu.open a:nth-child(4){transition-delay:.33s}.mobile-menu.open a:nth-child(5){transition-delay:.39s}.mobile-menu.open a:nth-child(6){transition-delay:.45s}.mobile-menu.open a:nth-child(7){transition-delay:.51s}

/* brackets */
.bracket{position:absolute;width:36px;height:36px;border:2px solid var(--gold);opacity:.5;z-index:5;pointer-events:none}
.bracket.tl{top:26px;left:26px;border-right:0;border-bottom:0}
.bracket.tr{top:26px;right:26px;border-left:0;border-bottom:0}
.bracket.bl{bottom:26px;left:26px;border-right:0;border-top:0}
.bracket.br{bottom:26px;right:26px;border-left:0;border-top:0}

/* reveal */
.reveal{opacity:0;transform:translateY(46px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

/* char split */
.char{display:inline-block;transform:translateY(110%) rotate(8deg);opacity:0;animation:charrise .9s var(--ease) forwards}
@keyframes charrise{to{transform:none;opacity:1}}

/* ===== HERO (home) ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:170px 0 90px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(900px 600px at 82% 8%,rgba(224,161,26,.16),transparent 60%),radial-gradient(900px 700px at 12% 92%,rgba(18,17,15,.06),transparent 55%),linear-gradient(160deg,var(--cream),var(--cream-2))}
.hero-bg::after{content:'';position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:70px 70px;-webkit-mask-image:radial-gradient(circle at 60% 45%,#000,transparent 72%);mask-image:radial-gradient(circle at 60% 45%,#000,transparent 72%)}
#stars{position:absolute;inset:0;z-index:1}
.hero-inner{position:relative;z-index:3;width:100%}
.hero-top{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:42px;flex-wrap:wrap;gap:12px}
.hero-top .mono{color:var(--gold-deep)}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;color:var(--gold-deep);margin-bottom:24px}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(224,161,26,.2);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 5px rgba(224,161,26,.2)}50%{box-shadow:0 0 0 9px rgba(224,161,26,0)}}
.hero h1{font-family:'Anton';font-weight:400;line-height:.86;letter-spacing:-1px;font-size:clamp(46px,12vw,184px);text-transform:uppercase}
.hero h1 .ln{display:block;overflow:hidden}
.hero-rotor{display:inline-flex;align-items:center;height:1em;overflow:hidden;vertical-align:bottom}
.hero-rotor .rl{display:flex;flex-direction:column;transition:transform .7s var(--ease)}
.hero-rotor .rl span{height:1em;line-height:1;color:var(--gold)}
.hero-sub{display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:end;margin-top:40px}
.hero-sub .lead{font-size:clamp(18px,1.8vw,23px);line-height:1.5;color:#3a352d;max-width:560px}
.hero-sub .lead b{color:var(--ink);font-weight:700}
.hero-sub .lead .serif-it{color:var(--gold-deep)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-side{display:flex;flex-direction:column;gap:18px}
.mini-stat{border:1px solid var(--line);border-radius:14px;padding:18px 20px;background:rgba(244,239,228,.5);backdrop-filter:blur(4px)}
.mini-stat .n{font-family:'Anton';font-size:40px;line-height:1;color:var(--ink)}
.mini-stat .n em{color:var(--gold);font-style:normal}
.mini-stat .l{color:var(--muted);font-size:12.5px;margin-top:6px;font-weight:500}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:4;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:9px}
.scroll-cue .mouse{width:25px;height:40px;border:2px solid var(--muted);border-radius:14px;position:relative}
.scroll-cue .mouse::after{content:'';position:absolute;top:7px;left:50%;transform:translateX(-50%);width:4px;height:9px;border-radius:3px;background:var(--gold);animation:wheel 1.5s infinite}
@keyframes wheel{0%{opacity:1;top:7px}70%{opacity:0;top:20px}100%{opacity:0}}

/* ===== PAGE HERO (subpages) ===== */
.page-hero{position:relative;padding:200px 0 80px;overflow:hidden;background:radial-gradient(900px 600px at 80% 10%,rgba(224,161,26,.16),transparent 60%),linear-gradient(160deg,var(--cream),var(--cream-2))}
.page-hero::after{content:'';position:absolute;inset:0;opacity:.4;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:70px 70px;-webkit-mask-image:radial-gradient(circle at 70% 40%,#000,transparent 68%);mask-image:radial-gradient(circle at 70% 40%,#000,transparent 68%)}
.page-hero .inner{position:relative;z-index:3}
.page-hero .crumb{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:38px;flex-wrap:wrap;gap:10px}
.page-hero .crumb .mono{color:var(--gold-deep)}
.page-hero .eyebrow{display:inline-flex;align-items:center;gap:12px;color:var(--gold-deep);margin-bottom:20px}
.page-hero .eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(224,161,26,.2)}
.page-hero h1{font-family:'Anton';font-weight:400;text-transform:uppercase;line-height:.86;letter-spacing:-1px;font-size:clamp(54px,10vw,150px)}
.page-hero p.lead{font-size:clamp(18px,1.8vw,23px);max-width:600px;margin-top:26px;color:#3a352d;line-height:1.55}
.page-hero p.lead .serif-it{color:var(--gold-deep)}

/* marquee */
.marquee{background:var(--ink);color:var(--cream);padding:24px 0;overflow:hidden}
.marquee-track{display:flex;gap:60px;white-space:nowrap;width:max-content;animation:scrollx 30s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:'Anton';font-size:24px;letter-spacing:1px;opacity:.6;display:flex;align-items:center;gap:60px}
.marquee-track span::after{content:'★';color:var(--gold);font-size:14px}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* sections */
.sec{padding:130px 0;position:relative}
.sec.sm{padding:90px 0}
.sec-dark{background:var(--ink);color:var(--cream)}
.sec-dark .mono{color:var(--gold)}
.sec-tint{background:linear-gradient(var(--cream-2),var(--cream))}
.sechead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:60px}
.sec-dark .sechead{border-color:var(--line-d)}
.sechead .left .mono{color:var(--gold-deep);display:block;margin-bottom:16px}
.sec-dark .sechead .left .mono{color:var(--gold)}
.sechead h2{font-family:'Anton';font-weight:400;text-transform:uppercase;line-height:.92;font-size:clamp(40px,6.5vw,92px)}
.sechead .right{text-align:right;max-width:430px;color:var(--muted);font-size:15px;line-height:1.6;padding-bottom:6px}
.sec-dark .sechead .right{color:rgba(244,239,228,.62)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.about-grid .lead{font-size:clamp(22px,2.4vw,32px);line-height:1.4;font-weight:500}
.about-grid .lead b{color:var(--gold-deep)}
.about-grid p.body{margin-top:22px;color:#4a443b;line-height:1.75;font-size:16px}
.tagrow{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.tagrow span{border:1px solid var(--line);border-radius:40px;padding:9px 16px;font-size:12px;font-weight:600;letter-spacing:.04em;transition:.3s}
.tagrow span:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.about-card{background:var(--ink);color:var(--cream);border-radius:var(--r);padding:42px;position:relative;overflow:hidden}
.about-card::before{content:'★';position:absolute;right:-26px;top:-40px;font-size:220px;color:rgba(224,161,26,.08);font-family:'Anton'}
.about-card .q{font-family:'Playfair Display';font-style:italic;font-size:24px;line-height:1.5;position:relative;z-index:2}
.about-card .q b{color:var(--gold)}
.about-card .by{margin-top:24px;color:var(--gold);font-weight:700;letter-spacing:.04em}

/* image figure */
.figure{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.figure img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.figure:hover img{transform:scale(1.05)}
.figure .cap{position:absolute;left:0;bottom:0;z-index:2;padding:18px 20px;color:var(--cream);font-family:'Space Mono';font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.figure::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(18,17,15,.7));z-index:1}
.figure.tall{aspect-ratio:3/4}
.figure.wide{aspect-ratio:16/10}
.figure.sq{aspect-ratio:1/1}

/* image showcase band */
.showcase{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:150px;gap:18px}
.showcase .figure:nth-child(1){grid-column:span 5;grid-row:span 2}
.showcase .figure:nth-child(2){grid-column:span 4;grid-row:span 2}
.showcase .figure:nth-child(3){grid-column:span 3;grid-row:span 2}
.showcase .figure:nth-child(4){grid-column:span 4;grid-row:span 2}
.showcase .figure:nth-child(5){grid-column:span 4;grid-row:span 2}
.showcase .figure:nth-child(6){grid-column:span 4;grid-row:span 2}

/* VISION/MISSION */
.vm{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vm .panel{border:1px solid var(--line);border-radius:var(--r);padding:42px;position:relative;overflow:hidden;background:var(--cream);transition:.4s var(--ease)}
.vm .panel:hover{transform:translateY(-6px);box-shadow:0 34px 70px -34px rgba(18,17,15,.32)}
.vm .panel .big{font-family:'Anton';font-size:90px;color:var(--gold-soft);position:absolute;right:24px;top:8px;line-height:1}
.vm .panel .mono{color:var(--gold-deep);display:block;margin-bottom:18px}
.vm .panel h3{font-family:'Anton';font-weight:400;font-size:34px;text-transform:uppercase;margin-bottom:16px}
.vm .panel p{color:#4a443b;line-height:1.7;font-size:15.5px;position:relative;z-index:2}
.vm .panel .ft{margin-top:22px;font-family:'Playfair Display';font-style:italic;color:var(--gold-deep);font-size:18px}

/* CORE VALUES */
.cv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cv{border:1px solid var(--line);border-radius:var(--r);padding:38px;background:var(--cream);transition:.4s var(--ease);position:relative;overflow:hidden}
.cv:hover{background:var(--ink);color:var(--cream);transform:translateY(-6px)}
.cv .n{font-family:'Anton';font-size:56px;color:var(--gold);line-height:1}
.cv h4{font-family:'Anton';font-weight:400;font-size:26px;text-transform:uppercase;margin:14px 0 12px}
.cv p{color:#4a443b;line-height:1.65;font-size:14.5px;transition:.4s}
.cv:hover p{color:rgba(244,239,228,.72)}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat .num{font-family:'Anton';font-size:clamp(54px,7vw,92px);line-height:1;color:var(--gold)}
.stat .lbl{margin-top:12px;color:rgba(244,239,228,.7);font-weight:500}

/* SERVICES cards */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc{position:relative;border:1px solid var(--line);border-radius:var(--r);padding:42px;background:var(--cream);overflow:hidden;transition:transform .25s ease,box-shadow .4s ease;transform-style:preserve-3d;will-change:transform}
.svc::before{content:'';position:absolute;left:0;top:0;height:100%;width:4px;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .45s var(--ease)}
.svc:hover{box-shadow:0 34px 70px -30px rgba(18,17,15,.3)}
.svc:hover::before{transform:scaleY(1)}
.svc .idx{font-family:'Space Mono';color:var(--gold-deep);font-size:13px;letter-spacing:.2em}
.svc h3{font-family:'Anton';font-weight:400;text-transform:uppercase;font-size:clamp(28px,3vw,42px);margin:14px 0 12px;line-height:.98;transform:translateZ(40px)}
.svc p{color:#4a443b;line-height:1.6;font-size:15px;max-width:88%;transform:translateZ(20px)}
.svc .icon{position:absolute;right:34px;top:34px;width:54px;height:54px;color:var(--gold);transition:.4s;transform:translateZ(60px)}
.svc:hover .icon{transform:translateZ(60px) rotate(-8deg) scale(1.08)}
.svc .more{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-weight:700;font-size:13px;letter-spacing:.03em;transition:gap .3s,color .3s}
.svc:hover .more{gap:14px;color:var(--gold-deep)}
.svc .ghostnum{position:absolute;right:-10px;bottom:-44px;font-family:'Anton';font-size:180px;color:rgba(18,17,15,.035);line-height:1;pointer-events:none}

/* SERVICE card with image */
.svc-img{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;color:var(--cream);background-size:cover;background-position:center;transition:.5s var(--ease)}
.svc-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,17,15,.1),rgba(18,17,15,.9));z-index:1;transition:.5s}
.svc-img:hover::after{background:linear-gradient(180deg,rgba(224,161,26,.18),rgba(18,17,15,.94))}
.svc-img:hover{transform:translateY(-6px)}
.svc-img>*{position:relative;z-index:2}
.svc-img .idx{color:var(--gold);font-family:'Space Mono';font-size:12px;letter-spacing:.18em}
.svc-img h3{font-family:'Anton';font-weight:400;font-size:30px;text-transform:uppercase;margin:10px 0}
.svc-img p{font-size:14px;line-height:1.55;color:rgba(244,239,228,.85)}
.svc-img .more{display:inline-flex;gap:8px;margin-top:16px;font-weight:700;font-size:13px;color:var(--gold);transition:gap .3s}
.svc-img:hover .more{gap:14px}

/* SERVICE detail row */
.detail{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:60px 0;border-bottom:1px solid var(--line)}
.detail:last-child{border-bottom:0}
.detail.rev .txt{order:2}
.detail .txt .idx{font-family:'Space Mono';color:var(--gold-deep);font-size:13px;letter-spacing:.2em}
.detail .txt h3{font-family:'Anton';font-weight:400;font-size:clamp(30px,4vw,52px);text-transform:uppercase;margin:14px 0 18px;line-height:.98}
.detail .txt p{color:#4a443b;line-height:1.75;font-size:16px}
.detail .txt ul{list-style:none;margin-top:22px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.detail .txt li{font-size:14px;font-weight:600;display:flex;gap:9px;align-items:flex-start}
.detail .txt li::before{content:'▸';color:var(--gold)}
.detail .figure{aspect-ratio:4/3}

/* CAPABILITIES */
.captabs{display:flex;gap:10px;margin-bottom:30px;flex-wrap:wrap}
.captab{border:1px solid var(--line);background:transparent;border-radius:40px;padding:11px 22px;font-family:'Archivo';font-weight:700;font-size:13px;cursor:pointer;transition:.3s;color:var(--ink)}
.captab.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.cap{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 30px;transition:.35s;position:relative}
.cap:hover{background:var(--ink);color:var(--cream)}
.cap .n{font-family:'Space Mono';color:var(--gold-deep);font-size:12px;letter-spacing:.16em}
.cap:hover .n{color:var(--gold)}
.cap h4{font-family:'Archivo';font-weight:800;font-size:18px;margin:12px 0 8px}
.cap p{font-size:13.5px;line-height:1.55;color:var(--muted)}
.cap:hover p{color:rgba(244,239,228,.7)}
.capset{display:none}.capset.on{display:contents}

/* HONEYWELL */
.hw-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.hw{border:1px solid var(--line-d);border-radius:10px;padding:18px;font-size:13.5px;line-height:1.4;display:flex;gap:10px;transition:.35s;color:rgba(244,239,228,.85)}
.hw::before{content:'▸';color:var(--gold)}
.hw:hover{background:rgba(224,161,26,.1);border-color:var(--gold);transform:translateY(-3px)}
.hw-feature{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-bottom:46px}
.hw-feature .figure{aspect-ratio:16/11}

/* GENERAL SUPPLY */
.sup-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.sup{border:1px solid var(--line);border-radius:14px;padding:28px;background:var(--cream);transition:.4s var(--ease)}
.sup:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(18,17,15,.3);border-color:var(--gold)}
.sup .br{font-family:'Anton';font-size:20px;text-transform:uppercase;color:var(--ink);letter-spacing:.5px}
.sup .br em{color:var(--gold);font-style:normal}
.sup p{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.55}

/* CSR */
.csr-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line-d);border-radius:var(--r);overflow:hidden}
.csr{padding:36px 30px;border-right:1px solid var(--line-d);transition:.4s}
.csr:last-child{border-right:0}
.csr:hover{background:rgba(224,161,26,.08)}
.csr .n{font-family:'Space Mono';color:var(--gold);font-size:12px;letter-spacing:.16em}
.csr h4{font-family:'Anton';font-weight:400;font-size:22px;text-transform:uppercase;margin:14px 0 12px;color:var(--cream)}
.csr p{color:rgba(244,239,228,.68);font-size:14px;line-height:1.6}

/* HSE + ISO */
.dual{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.hse-row{display:flex;flex-direction:column;gap:16px;margin-top:8px}
.hse{border:1px solid var(--line);border-radius:14px;padding:24px 26px;transition:.35s;background:var(--cream)}
.hse:hover{border-color:var(--gold);transform:translateX(6px)}
.hse .t{display:flex;justify-content:space-between;align-items:baseline}
.hse .t b{font-family:'Anton';font-weight:400;font-size:20px;text-transform:uppercase}
.hse .t .mono{color:var(--gold-deep)}
.hse p{margin-top:8px;color:var(--muted);font-size:14px;line-height:1.55}
.iso-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:8px}
.iso{border:1px solid var(--line);border-radius:14px;padding:26px 18px;text-align:center;transition:.4s var(--ease);background:var(--cream)}
.iso:hover{background:var(--ink);color:var(--cream);transform:translateY(-6px)}
.iso .big{font-family:'Anton';font-size:46px;color:var(--gold);line-height:1}
.iso .k{font-family:'Space Mono';font-size:10px;letter-spacing:.16em;color:var(--gold-deep);margin:6px 0 10px}
.iso:hover .k{color:var(--gold)}
.iso p{font-size:12.5px;color:var(--muted);line-height:1.5}
.iso:hover p{color:rgba(244,239,228,.72)}
.zero{margin-top:26px;background:var(--ink);color:var(--cream);border-radius:14px;padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:18px}
.zero b{font-family:'Anton';font-weight:400;font-size:26px;color:var(--gold);text-transform:uppercase}
.zero .serif-it{color:rgba(244,239,228,.8)}

/* PROJECTS */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.proj{border-radius:var(--r);overflow:hidden;position:relative;min-height:400px;display:flex;flex-direction:column;justify-content:flex-end;color:var(--cream);padding:32px;background-size:cover;background-position:center;transition:.5s var(--ease)}
.proj::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,17,15,.12),rgba(18,17,15,.92));z-index:1;transition:.5s}
.proj:hover::after{background:linear-gradient(180deg,rgba(224,161,26,.2),rgba(18,17,15,.94))}
.proj:hover{transform:translateY(-6px)}
.proj>*{position:relative;z-index:2}
.proj .ploc{color:var(--gold);font-family:'Space Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.proj h3{font-family:'Anton';font-weight:400;font-size:30px;text-transform:uppercase;margin:10px 0;line-height:1}
.proj p{font-size:14px;line-height:1.55;color:rgba(244,239,228,.85)}
.proj p b{color:#fff}
.proj.soon{background:var(--cream-2);color:var(--muted);border:1px dashed var(--line);align-items:center;justify-content:center;text-align:center}
.proj.soon::after{display:none}
.proj.soon .so{font-family:'Anton';font-size:30px;color:var(--ink);opacity:.22;text-transform:uppercase}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tm{border:1px solid var(--line);border-radius:var(--r);padding:34px;background:var(--cream);transition:.4s var(--ease)}
.tm:hover{transform:translateY(-6px);box-shadow:0 34px 70px -34px rgba(18,17,15,.3)}
.tm .av{width:66px;height:66px;border-radius:50%;background:var(--ink);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Anton';font-size:24px;margin-bottom:22px}
.tm h4{font-family:'Archivo';font-weight:800;font-size:20px}
.tm .role{color:var(--gold-deep);font-weight:700;font-size:13px;letter-spacing:.03em;margin:4px 0 14px;text-transform:uppercase}
.tm p{color:#4a443b;font-size:14px;line-height:1.6}

/* CTA */
.cta{position:relative;text-align:center;padding:140px 0;overflow:hidden;background:radial-gradient(800px 500px at 50% 0%,var(--cream-2),var(--cream))}
.cta h2{font-family:'Anton';font-weight:400;text-transform:uppercase;font-size:clamp(48px,9vw,140px);line-height:.9}
.cta p{max-width:560px;margin:24px auto 36px;color:#4a443b;font-size:18px;line-height:1.6}
.cta .btn{font-size:16px;padding:17px 34px}

/* FOOTER */
footer{background:var(--ink);color:var(--cream);padding:90px 0 0}
.foot-top{display:grid;grid-template-columns:1.5fr .8fr .8fr 1fr;gap:40px;padding-bottom:54px;border-bottom:1px solid var(--line-d)}
.foot-top h5{font-family:'Space Mono';font-size:12px;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;margin-bottom:22px}
.foot-top ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.foot-top a{color:rgba(244,239,228,.8);transition:.3s;font-size:15px}
.foot-top a:hover{color:var(--gold);padding-left:6px}
.foot-brand .mark{width:46px;height:46px;border:1.5px solid var(--gold);border-radius:12px;display:flex;align-items:center;justify-content:center}
.foot-brand .mark svg{width:26px;height:26px;color:var(--gold)}
.foot-brand .mark img{width:30px;height:30px;object-fit:contain}
.foot-brand .bn{font-family:'Anton';font-size:30px;margin:16px 0 12px}
.foot-brand p{color:rgba(244,239,228,.6);line-height:1.6;max-width:330px;font-size:14px}
.foot-marq{overflow:hidden;padding:32px 0;border-bottom:1px solid var(--line-d)}
.foot-marq .t{display:flex;gap:40px;width:max-content;animation:scrollx 32s linear infinite;font-family:'Anton';font-size:66px;color:transparent;-webkit-text-stroke:1px rgba(244,239,228,.16)}
.foot-marq .t span{display:flex;gap:40px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:26px 0;color:rgba(244,239,228,.55);font-size:13px;flex-wrap:wrap;gap:12px}
.foot-bottom .serif-it{color:var(--gold);font-size:16px}

/* CONTACT */
.c-main{padding:40px 0 130px}
.c-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:64px;align-items:start}
.info-card{border:1px solid var(--line);border-radius:14px;padding:26px 28px;background:var(--cream);margin-bottom:16px;transition:.4s var(--ease);display:flex;gap:18px;align-items:flex-start}
.info-card:hover{transform:translateX(6px);border-color:var(--gold);box-shadow:0 24px 50px -34px rgba(18,17,15,.3)}
.info-card .ic{width:50px;height:50px;border-radius:12px;background:var(--ink);color:var(--gold);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-card .ic svg{width:24px;height:24px}
.info-card .mono{color:var(--gold-deep);display:block;margin-bottom:8px}
.info-card .v{font-family:'Archivo';font-weight:700;font-size:18px;line-height:1.35}
.info-card .v a:hover{color:var(--gold-deep)}
.info-card .sub{color:var(--muted);font-size:13px;margin-top:4px}
.hours{border:1px solid var(--line);border-radius:14px;padding:24px 28px;background:var(--ink);color:var(--cream)}
.hours .mono{color:var(--gold);display:block;margin-bottom:14px}
.hours .row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line-d);font-size:14px}
.hours .row:last-child{border-bottom:0}.hours .row span:last-child{color:rgba(244,239,228,.7)}
.form-wrap{border:1px solid var(--line);border-radius:var(--r);padding:44px;background:linear-gradient(160deg,var(--cream),var(--cream-2));position:relative;overflow:hidden}
.form-wrap::before{content:'★';position:absolute;right:-30px;top:-46px;font-size:220px;color:rgba(224,161,26,.07);font-family:'Anton'}
.form-wrap h2{font-family:'Anton';font-weight:400;text-transform:uppercase;font-size:34px;position:relative;z-index:2}
.form-wrap .fsub{color:var(--muted);margin:8px 0 30px;font-size:15px;position:relative;z-index:2}
form{position:relative;z-index:2}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{position:relative;margin-bottom:22px}
.field label{display:block;font-family:'Space Mono';font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:9px}
.field input,.field select,.field textarea{width:100%;background:rgba(244,239,228,.7);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-family:'Archivo';font-size:15px;color:var(--ink);transition:.3s;outline:none}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 4px rgba(224,161,26,.12)}
.field.err input,.field.err select,.field.err textarea{border-color:#c0392b;box-shadow:0 0 0 4px rgba(192,57,43,.1)}
.field .msg{font-size:12px;color:#c0392b;margin-top:6px;display:none}
.field.err .msg{display:block}
.submit-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:6px}
.submit-row .note{color:var(--muted);font-size:12.5px}
.success{display:none;text-align:center;padding:30px 10px}
.success.show{display:block;animation:pop .5s var(--ease)}
@keyframes pop{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}
.success .ok{width:74px;height:74px;border-radius:50%;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:38px}
.success h3{font-family:'Anton';font-weight:400;font-size:30px;text-transform:uppercase}
.success p{color:var(--muted);margin-top:10px}
.mapsec{padding:0 0 130px}
.map{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:420px;background:var(--ink);display:flex;align-items:center;justify-content:center}
.map::before{content:'';position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-d) 1px,transparent 1px),linear-gradient(90deg,var(--line-d) 1px,transparent 1px);background-size:48px 48px}
.map .pin{position:relative;z-index:2;text-align:center;color:var(--cream)}
.map .pin .dot{width:22px;height:22px;border-radius:50%;background:var(--gold);margin:0 auto 16px;position:relative}
.map .pin .dot::after{content:'';position:absolute;inset:-10px;border-radius:50%;border:2px solid var(--gold);animation:ping 1.8s infinite}
@keyframes ping{0%{transform:scale(.6);opacity:1}100%{transform:scale(1.8);opacity:0}}
.map .pin b{font-family:'Anton';font-size:28px;text-transform:uppercase;display:block}
.map .pin span{color:rgba(244,239,228,.7);font-size:14px}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .nav-c{display:none}.burger{display:flex}
  .hero-sub,.about-grid,.svc-grid,.vm,.dual,.detail,.hw-feature,.c-grid{grid-template-columns:1fr}
  .detail.rev .txt{order:0}
  .cap-grid,.cv-grid,.hw-grid,.sup-grid,.csr-grid,.proj-grid,.team-grid,.foot-top,.iso-row,.stats{grid-template-columns:1fr 1fr}
  .sechead{flex-direction:column;align-items:flex-start}.sechead .right{text-align:left}
  .cap-grid{border-left:0}
  .csr{border-right:0;border-bottom:1px solid var(--line-d)}
  .showcase{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .showcase .figure{grid-column:span 1 !important;grid-row:span 1 !important}
}
@media(max-width:600px){
  .wrap{padding:0 20px}.nav-main{padding:13px 20px}.utility{padding:8px 20px}.utility .u-l span:nth-child(2){display:none}
  .svc-grid,.cap-grid,.cv-grid,.hw-grid,.sup-grid,.csr-grid,.proj-grid,.team-grid,.foot-top,.stats,.iso-row,.frow,.detail .txt ul{grid-template-columns:1fr}
  .hero{padding-top:150px}.page-hero{padding-top:170px}.form-wrap{padding:28px 22px}
  .foot-bottom{flex-direction:column;align-items:flex-start}
  .showcase{grid-template-columns:1fr}
}
/* team avatar photo */
.tm .av{overflow:hidden}
.tm .av img{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* partner logo wall */
.logo-marq{background:var(--ink);padding:22px 0;overflow:hidden}
.logo-marq .track{display:flex;gap:16px;width:max-content;animation:scrollx 34s linear infinite;align-items:center}
.logo-marq:hover .track{animation-play-state:paused}
.logo-marq .chip{height:42px;background:transparent;display:flex;align-items:center;justify-content:center;padding:0 30px;flex:0 0 auto}
.logo-marq .chip img{max-height:100%;max-width:130px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.6;transition:opacity .3s}
.logo-marq .chip:hover img{opacity:1}

/* floating action buttons */
.fab-wa{position:fixed;right:22px;bottom:22px;z-index:9100;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 30px -8px rgba(37,211,102,.6);transition:transform .3s var(--ease)}
.fab-wa:hover{transform:scale(1.08) translateY(-2px)}
.fab-wa svg{width:30px;height:30px}
.to-top{position:fixed;right:24px;bottom:88px;z-index:9100;width:46px;height:46px;border-radius:50%;background:var(--ink);color:var(--cream);display:flex;align-items:center;justify-content:center;border:1px solid var(--ink);cursor:pointer;opacity:0;pointer-events:none;transform:translateY(10px);transition:.3s var(--ease)}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.to-top svg{width:20px;height:20px}

/* download profile button row */
.dl-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* honeypot */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

@media(max-width:600px){.fab-wa{width:50px;height:50px;right:16px;bottom:16px}.to-top{right:18px;bottom:74px}}
/* nav buttons collapse into the burger menu on tablet/mobile */
@media(max-width:1024px){ .nav-r .btn{display:none} .nav-r{gap:0} }
.mobile-menu{overflow-y:auto}
@media(max-width:600px){
  .brand .bt small{display:none}
  .brand-logo{height:40px}
  .nav.scrolled .brand-logo{height:36px}
  .utility{font-size:10.5px;padding:7px 16px}
  .utility .u-l span,.utility .u-l a:last-child{display:none}   /* hide separator + email, keep phone */
  .utility .u-r span{display:none}                              /* hide BASRA label, keep social */
  .utility .u-l,.utility .u-r{gap:16px}
  .sec{padding:74px 0}
  .hero{padding-top:140px;min-height:0}
  .sechead{margin-bottom:38px}
  .detail{padding:34px 0;gap:30px}
}
@media(max-width:380px){ .utility .u-r a:first-of-type{display:none} } /* very small: drop LinkedIn, keep WhatsApp */
/* ===================== ARABIC / RTL ===================== */
[dir=rtl] body{font-family:'Tajawal','Archivo',system-ui,sans-serif}
[dir=rtl] .hero h1,[dir=rtl] .page-hero h1,[dir=rtl] .sechead h2,[dir=rtl] .cta h2,
[dir=rtl] .svc h3,[dir=rtl] .svc-img h3,[dir=rtl] .proj h3,[dir=rtl] .vm .panel h3,
[dir=rtl] .detail .txt h3,[dir=rtl] .hw-feature h2,[dir=rtl] .form-wrap h2,
[dir=rtl] .cv h4,[dir=rtl] .csr h4,[dir=rtl] .hse .t b,[dir=rtl] .success h3,
[dir=rtl] .map .pin b{font-family:'Tajawal','Archivo',sans-serif;font-weight:800;letter-spacing:0}
[dir=rtl] .stat .num,[dir=rtl] .mini-stat .n,[dir=rtl] .cv .n,[dir=rtl] .vm .panel .big,
[dir=rtl] .iso .big,[dir=rtl] .proj.soon .so,[dir=rtl] .zero b,[dir=rtl] .nf .code,
[dir=rtl] .tm .av{font-family:'Tajawal',sans-serif;font-weight:800}
/* Arabic headings need room — Latin display sizes/clipping don't suit Arabic */
[dir=rtl] .hero h1{font-size:clamp(38px,7.5vw,104px);line-height:1.22;letter-spacing:0}
[dir=rtl] .hero h1 .ln{overflow:visible;padding-block:.04em}
[dir=rtl] .page-hero h1{font-size:clamp(38px,7.5vw,98px);line-height:1.18}
[dir=rtl] .sechead h2{line-height:1.14}
[dir=rtl] .cta h2{font-size:clamp(40px,8vw,104px);line-height:1.14}
[dir=rtl] .svc-img h3,[dir=rtl] .proj h3,[dir=rtl] .detail .txt h3,[dir=rtl] .vm .panel h3{line-height:1.2}
[dir=rtl] .rotor-ar{display:inline-block;transition:opacity .4s var(--ease),transform .4s var(--ease)}
[dir=rtl] .mono{font-family:'Tajawal',sans-serif;letter-spacing:.04em}
[dir=rtl] .serif-it{font-family:'Tajawal',sans-serif;font-style:normal}
/* mirror decorative offsets */
[dir=rtl] .svc::before{left:auto;right:0}
[dir=rtl] .svc .ghostnum{right:auto;left:-10px}
[dir=rtl] .vm .panel .big{right:auto;left:24px}
[dir=rtl] .about-card::before{right:auto;left:-26px}
[dir=rtl] .form-wrap::before{right:auto;left:-30px}
[dir=rtl] .fab-wa{right:auto;left:22px}
[dir=rtl] .to-top{right:auto;left:24px}
[dir=rtl] .hse:hover{transform:translateX(-6px)}
[dir=rtl] .info-card:hover{transform:translateX(-6px)}
[dir=rtl] .foot-top a:hover{padding-left:0;padding-right:6px}
[dir=rtl] .sechead .right{text-align:left}
[dir=rtl] .detail .txt li::before{content:'◂'}
[dir=rtl] .scroll-cue{left:auto;right:50%;transform:translateX(50%)}
/* language toggle */
.lang{display:inline-flex;border:1px solid var(--line);border-radius:30px;overflow:hidden;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.08em}
.lang a{padding:8px 12px;color:var(--muted);transition:.25s}
.lang a.on{background:var(--ink);color:var(--cream)}
.lang a:hover{color:var(--ink)}
.lang a.on:hover{color:var(--cream)}
[dir=rtl] .lang{font-family:'Tajawal',sans-serif}
@media(max-width:1024px){ .lang{display:none} }

@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}.char{opacity:1!important;transform:none!important}}
