/* ═══════════════════════════════════════════════════
   PLANCK VISION CONSULTING — MAIN STYLESHEET
   planckvisionconsulting.com
═══════════════════════════════════════════════════ */

:root {
  --ink:        #080a0d;
  --ink-deep:   #04050a;
  --ink-mid:    #0e1118;
  --fog:        #f2f0ec;
  --fog-light:  #faf8f5;
  --fog-dim:    #d8d4cc;
  --gold:       #c4a35a;
  --gold-light: #dfc07a;
  --gold-dark:  #8a6f38;
  --gold-glow:  rgba(196,163,90,0.12);
  --cyan:       #3fb8c8;
  --cyan-dim:   rgba(63,184,200,0.15);
  --silver:     #7a8a9a;
  --silver-lt:  #a8b8c4;
  --white:      #ffffff;
  --border-gold: rgba(196,163,90,0.18);
  --border-dim:  rgba(196,163,90,0.07);
  --border-light: rgba(242,240,236,0.08);
  --shadow-gold: 0 0 60px rgba(196,163,90,0.12);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Outfit', sans-serif;
  --font-mono:    'DM Mono', monospace;
  --ease-out: cubic-bezier(0.22,1,0.36,1);
  --ease-smooth: cubic-bezier(0.45,0,0.55,1);
  --transition: 0.4s var(--ease-out);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { background:var(--ink); color:var(--fog); font-family:var(--font-body); font-weight:300; line-height:1.65; overflow-x:hidden; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; }
ul { list-style:none; }
::selection { background:var(--gold); color:var(--ink); }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--ink-deep); }
::-webkit-scrollbar-thumb { background:var(--gold-dark); }

/* ── NOISE GRAIN ── */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:0.5;
}

/* ═══ CURSOR ═══ */
.cursor { position:fixed; width:7px; height:7px; background:var(--gold); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); mix-blend-mode:difference; transition:transform 0.15s; }
.cursor-ring { position:fixed; width:34px; height:34px; border:1px solid rgba(196,163,90,0.5); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:all 0.35s var(--ease-out); }
body:has(a:hover) .cursor { transform:translate(-50%,-50%) scale(2.5); }
body:has(a:hover) .cursor-ring { transform:translate(-50%,-50%) scale(1.4); border-color:rgba(196,163,90,0.8); }

/* ═══ PRELOADER ═══ */
.preloader { position:fixed; inset:0; z-index:10000; background:var(--ink-deep); display:flex; align-items:center; justify-content:center; transition:opacity 0.8s var(--ease-out), visibility 0.8s; }
.preloader.hidden { opacity:0; visibility:hidden; }
.preloader-inner { text-align:center; }
.preloader-logo { display:flex; align-items:center; gap:14px; justify-content:center; margin-bottom:40px; }
.preloader-mark { width:40px; height:40px; border:1.5px solid var(--gold); transform:rotate(45deg); position:relative; animation:spin-mark 3s linear infinite; }
.preloader-mark::before { content:''; position:absolute; inset:8px; background:var(--gold); }
@keyframes spin-mark { from{transform:rotate(45deg)} to{transform:rotate(405deg)} }
.preloader-logo span { font-family:var(--font-display); font-size:1.4rem; font-weight:300; letter-spacing:0.15em; text-transform:uppercase; color:var(--fog); }
.preloader-logo em { font-style:normal; color:var(--gold); }
.preloader-bar { width:200px; height:1px; background:rgba(196,163,90,0.2); margin:0 auto 16px; overflow:hidden; }
.preloader-fill { height:100%; background:var(--gold); width:0%; transition:width 0.05s; }
.preloader-pct { font-family:var(--font-mono); font-size:0.7rem; color:var(--silver); letter-spacing:0.2em; }

/* ═══ MOBILE MENU ═══ */
.mobile-menu { display:none; position:fixed; inset:0; z-index:9000; background:rgba(4,5,10,0.98); backdrop-filter:blur(20px); flex-direction:column; align-items:center; justify-content:center; gap:0; opacity:0; transition:opacity 0.4s; }
.mobile-menu.open { display:flex; opacity:1; }
.mobile-close { position:absolute; top:24px; right:28px; font-size:1.5rem; color:var(--silver); transition:color 0.3s; padding:8px; }
.mobile-close:hover { color:var(--gold); }
.mobile-nav { display:flex; flex-direction:column; align-items:center; gap:0; width:100%; }
.mobile-nav-link { font-family:var(--font-display); font-size:clamp(2rem,6vw,3rem); font-weight:300; color:var(--fog-dim); padding:16px 40px; width:100%; text-align:center; border-bottom:1px solid var(--border-dim); transition:all 0.3s; letter-spacing:0.04em; }
.mobile-nav-link:first-child { border-top:1px solid var(--border-dim); }
.mobile-nav-link:hover, .mobile-nav-link.active { color:var(--gold); background:var(--gold-glow); }
.mobile-menu-footer { margin-top:40px; display:flex; flex-direction:column; align-items:center; gap:10px; }
.mobile-menu-footer a { font-size:0.85rem; color:var(--silver); letter-spacing:0.08em; }

/* ═══ HEADER ═══ */
.site-header { position:fixed; top:0; left:0; right:0; z-index:800; height:76px; transition:all 0.4s var(--ease-out); }
.site-header::before { content:''; position:absolute; inset:0; background:rgba(4,5,10,0.75); backdrop-filter:blur(24px) saturate(180%); border-bottom:1px solid var(--border-dim); transition:all 0.4s; }
.site-header.scrolled::before { background:rgba(4,5,10,0.95); border-bottom-color:var(--border-gold); }
.site-header.scrolled { height:62px; box-shadow:0 4px 40px rgba(0,0,0,0.4); }
.header-inner { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; height:100%; padding:0 60px; }

/* Logo */
.site-logo { display:flex; align-items:center; gap:14px; }
.logo-mark { width:38px; height:38px; position:relative; flex-shrink:0; }
.logo-mark-inner { width:22px; height:22px; background:var(--gold); transform:rotate(45deg); position:absolute; top:50%; left:50%; translate:-50% -50%; transition:transform 0.5s var(--ease-out); }
.logo-mark-ring { position:absolute; inset:0; border:1.5px solid rgba(196,163,90,0.4); border-radius:50%; animation:logo-ring 4s linear infinite; }
@keyframes logo-ring { from{transform:rotate(0)} to{transform:rotate(360deg)} }
.site-logo:hover .logo-mark-inner { transform:rotate(45deg) scale(1.15) translate(-38%,-38%); }
.logo-text { display:flex; flex-direction:column; line-height:1.1; }
.logo-name { font-family:var(--font-display); font-size:1.15rem; font-weight:500; letter-spacing:0.14em; text-transform:uppercase; color:var(--fog); }
.logo-sub { font-family:var(--font-mono); font-size:0.58rem; letter-spacing:0.28em; text-transform:uppercase; color:var(--gold); margin-top:2px; }

/* Nav links */
.main-nav ul { display:flex; align-items:center; gap:36px; }
.main-nav a { font-size:0.75rem; font-weight:400; letter-spacing:0.1em; text-transform:uppercase; color:var(--silver-lt); transition:color 0.3s; position:relative; padding-bottom:3px; }
.main-nav a::after { content:''; position:absolute; bottom:0; left:0; right:0; height:1px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform 0.3s var(--ease-out); }
.main-nav a:hover, .main-nav a.active { color:var(--fog); }
.main-nav a:hover::after, .main-nav a.active::after { transform:scaleX(1); }

/* Header right */
.header-right { display:flex; align-items:center; gap:28px; }
.header-phone { font-size:0.72rem; letter-spacing:0.08em; color:var(--silver); display:flex; align-items:center; gap:7px; transition:color 0.3s; }
.header-phone:hover { color:var(--gold); }
.btn-nav-cta { font-size:0.72rem; font-weight:400; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink); background:var(--gold); padding:11px 26px; transition:all 0.3s; display:inline-block; }
.btn-nav-cta:hover { background:var(--fog); transform:translateY(-1px); }
.hamburger { display:none; flex-direction:column; gap:5px; padding:4px; }
.hamburger span { width:22px; height:1px; background:var(--fog); transition:all 0.3s; display:block; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

/* ═══ SHARED UTILITIES ═══ */
.container { max-width:1340px; margin:0 auto; padding:0 60px; }
.section-pad { padding:120px 0; }
.section-pad-sm { padding:80px 0; }

.label-row { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.label-line { width:36px; height:1px; background:var(--gold); flex-shrink:0; }
.label-text { font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); }

.headline-xl { font-family:var(--font-display); font-size:clamp(3rem,5.5vw,5rem); font-weight:300; line-height:1.06; letter-spacing:-0.01em; }
.headline-lg { font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3.6rem); font-weight:300; line-height:1.1; letter-spacing:-0.01em; }
.headline-md { font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.6rem); font-weight:300; line-height:1.15; }
.headline-sm { font-family:var(--font-display); font-size:1.5rem; font-weight:400; line-height:1.2; }
em.gold { font-style:italic; color:var(--gold); }

.body-lg { font-size:1.05rem; font-weight:300; line-height:1.8; color:var(--silver-lt); }
.body-md { font-size:0.92rem; line-height:1.78; color:var(--silver); }
.body-sm { font-size:0.82rem; line-height:1.75; color:var(--silver); }

.btn-primary { display:inline-flex; align-items:center; gap:10px; font-size:0.75rem; font-weight:400; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink); background:var(--gold); padding:17px 40px; transition:all 0.35s var(--ease-out); }
.btn-primary:hover { background:var(--fog); transform:translateY(-2px); box-shadow:0 12px 40px rgba(196,163,90,0.3); }
.btn-ghost { display:inline-flex; align-items:center; gap:10px; font-size:0.75rem; font-weight:400; letter-spacing:0.16em; text-transform:uppercase; color:var(--fog); border:1px solid rgba(242,240,236,0.25); padding:17px 40px; transition:all 0.35s var(--ease-out); }
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.btn-link { display:inline-flex; align-items:center; gap:10px; font-size:0.72rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); transition:gap 0.3s; }
.btn-link:hover { gap:16px; }

/* Animations */
.reveal { opacity:0; transform:translateY(28px); transition:opacity 0.85s var(--ease-out), transform 0.85s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-fade { opacity:0; transition:opacity 0.9s var(--ease-out); }
.reveal-fade.visible { opacity:1; }
.reveal-left { opacity:0; transform:translateX(-32px); transition:opacity 0.85s var(--ease-out), transform 0.85s var(--ease-out); }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.d1{transition-delay:0.1s!important} .d2{transition-delay:0.2s!important} .d3{transition-delay:0.3s!important} .d4{transition-delay:0.4s!important} .d5{transition-delay:0.5s!important} .d6{transition-delay:0.6s!important}

/* ═══ PAGE HERO (inner pages) ═══ */
.page-hero { min-height:55vh; display:flex; align-items:flex-end; padding-top:76px; background:var(--ink-deep); position:relative; overflow:hidden; }
.page-hero::after { content:''; position:absolute; bottom:0; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent, var(--border-gold), transparent); }
.page-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 30%, rgba(63,184,200,0.05), transparent 55%), radial-gradient(ellipse 50% 60% at 10% 70%, rgba(196,163,90,0.06), transparent 50%); }
.page-hero-inner { position:relative; z-index:2; padding:60px 0 80px; }
.page-hero-eyebrow { font-family:var(--font-mono); font-size:0.65rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.page-hero-title { font-family:var(--font-display); font-size:clamp(3rem,6vw,5.5rem); font-weight:300; line-height:1.05; color:var(--fog-light); }

/* ═══ DIVIDER ═══ */
.divider-gold { width:100%; height:1px; background:linear-gradient(90deg, transparent, var(--border-gold), transparent); margin:0; }

/* ═══ TICKER ═══ */
.ticker-band { overflow:hidden; background:var(--gold); padding:10px 0; flex-shrink:0; }
.ticker-track { display:flex; white-space:nowrap; animation:ticker 35s linear infinite; }
.ticker-track:hover { animation-play-state:paused; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker-item { font-family:var(--font-mono); font-size:0.65rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-deep); padding:0 36px; }
.ticker-dot { color:rgba(4,5,10,0.4); }

/* ═══ HOME HERO ═══ */
.home-hero { position:relative; min-height:100vh; display:flex; align-items:center; background:var(--ink-deep); overflow:hidden; padding-top:76px; }
.home-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 90% 70% at 65% 40%, rgba(63,184,200,0.055) 0%, transparent 55%), radial-gradient(ellipse 70% 90% at 15% 75%, rgba(196,163,90,0.06) 0%, transparent 50%); }

/* SVG canvas */
.hero-canvas { position:absolute; right:0; top:50%; transform:translateY(-50%); width:54%; height:95%; pointer-events:none; }

.hero-content { position:relative; z-index:2; padding:80px 0 160px; max-width:680px; }
.hero-eyebrow { display:flex; align-items:center; gap:16px; margin-bottom:36px; }
.hero-eyebrow-line { width:44px; height:1px; background:var(--gold); }
.hero-eyebrow-text { font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.26em; text-transform:uppercase; color:var(--gold); }
.hero-headline { font-family:var(--font-display); font-size:clamp(3.4rem,6.5vw,5.6rem); font-weight:300; line-height:1.06; letter-spacing:-0.015em; color:var(--fog-light); margin-bottom:28px; }
.hero-headline em { font-style:italic; color:var(--gold-light); }
.hero-sub { font-size:1.05rem; font-weight:300; line-height:1.82; color:var(--silver-lt); max-width:540px; margin-bottom:52px; }
.hero-actions { display:flex; gap:18px; flex-wrap:wrap; margin-bottom:72px; }

.hero-stats { display:flex; gap:52px; padding-top:44px; border-top:1px solid var(--border-dim); flex-wrap:wrap; }
.hero-stat {}
.stat-num { font-family:var(--font-display); font-size:2.5rem; font-weight:300; line-height:1; color:var(--fog-light); letter-spacing:-0.02em; }
.stat-num sup { font-size:1.2rem; color:var(--gold); vertical-align:super; }
.stat-label { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--silver); margin-top:7px; }

/* ═══ SERVICES SECTION ═══ */
.services-section { background:var(--fog-light); color:var(--ink); }
.services-intro { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:end; margin-bottom:64px; }
.services-intro .headline-lg { color:var(--ink); }
.services-intro .label-line { background:var(--gold-dark); }
.services-intro .label-text { color:var(--gold-dark); }
.services-desc { font-size:0.97rem; line-height:1.85; color:#4a5568; }

.services-grid { display:grid; grid-template-columns:repeat(4,1fr); background:rgba(0,0,0,0.06); gap:1px; }
.svc-card { background:var(--fog-light); padding:52px 36px; position:relative; overflow:hidden; cursor:default; transition:all 0.45s var(--ease-out); }
.svc-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform 0.45s var(--ease-out); }
.svc-card:hover { background:var(--white); transform:translateY(-5px); box-shadow:0 24px 60px rgba(0,0,0,0.1); z-index:2; }
.svc-card:hover::after { transform:scaleX(1); }
.svc-num { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.2em; color:var(--gold-dark); margin-bottom:20px; text-transform:uppercase; }
.svc-icon { width:52px; height:52px; margin-bottom:24px; }
.svc-title { font-family:var(--font-display); font-size:1.45rem; font-weight:400; color:var(--ink); line-height:1.18; margin-bottom:14px; }
.svc-desc { font-size:0.83rem; line-height:1.78; color:#5a6472; margin-bottom:28px; }
.svc-link { font-size:0.68rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold-dark); display:flex; align-items:center; gap:8px; transition:gap 0.3s; }
.svc-link:hover { gap:14px; }

/* ═══ APPROACH SECTION ═══ */
.approach-section { background:var(--ink); }
.approach-grid { display:grid; grid-template-columns:1fr 0.85fr; gap:100px; align-items:center; }
.approach-steps { margin-top:52px; }
.step-item { display:flex; gap:28px; padding:36px 0; border-bottom:1px solid var(--border-dim); cursor:pointer; transition:all 0.35s; }
.step-item:first-child { border-top:1px solid var(--border-dim); }
.step-item:hover .step-title, .step-item.active .step-title { color:var(--fog-light); }
.step-item.active .step-n { color:rgba(196,163,90,0.5); }
.step-n { font-family:var(--font-display); font-size:2.8rem; font-weight:300; color:rgba(196,163,90,0.15); min-width:52px; line-height:1; transition:color 0.35s; }
.step-body {}
.step-tag { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.step-title { font-family:var(--font-display); font-size:1.5rem; font-weight:300; color:var(--silver); margin-bottom:10px; transition:color 0.35s; }
.step-desc { font-size:0.85rem; line-height:1.78; color:var(--silver); max-width:400px; }

/* Approach orbit visual */
.approach-visual { display:flex; align-items:center; justify-content:center; position:relative; height:460px; }
.orbit-svg { width:100%; max-width:380px; }

/* ═══ INDUSTRIES ═══ */
.industries-section { background:var(--fog-light); color:var(--ink); }
.industries-section .headline-lg { color:var(--ink); }
.industries-section .label-line { background:var(--gold-dark); }
.industries-section .label-text { color:var(--gold-dark); }

.industries-header { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:end; margin-bottom:60px; }
.industries-header .body-md { color:#4a5568; }

.ind-list { border-top:1px solid rgba(0,0,0,0.1); }
.ind-row { display:flex; align-items:center; justify-content:space-between; padding:28px 0; border-bottom:1px solid rgba(0,0,0,0.06); cursor:pointer; transition:all 0.35s; text-decoration:none; color:inherit; }
.ind-row:hover .ind-name { color:var(--gold-dark); transform:translateX(14px); }
.ind-row:hover .ind-arrow { opacity:1; transform:translateX(0); }
.ind-left { display:flex; align-items:center; gap:36px; }
.ind-num { font-family:var(--font-mono); font-size:0.65rem; letter-spacing:0.18em; color:var(--gold-dark); min-width:36px; }
.ind-name { font-family:var(--font-display); font-size:clamp(1.5rem,3vw,2.2rem); font-weight:300; color:var(--ink); transition:all 0.4s var(--ease-out); }
.ind-tags { display:flex; gap:8px; flex-wrap:wrap; }
.ind-tag { font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase; padding:4px 10px; border:1px solid rgba(0,0,0,0.12); color:#6b7a8d; }
.ind-arrow { font-size:1.3rem; color:var(--gold-dark); opacity:0; transform:translateX(-12px); transition:all 0.35s var(--ease-out); }

/* ═══ INSIGHTS ═══ */
.insights-section { background:var(--ink); }
.insights-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:56px; flex-wrap:wrap; gap:24px; }

.insights-grid { display:grid; grid-template-columns:1.55fr 1fr 1fr; gap:1px; background:var(--border-dim); }
.ins-card { background:var(--ink); padding:44px; text-decoration:none; color:inherit; display:block; transition:background 0.3s; position:relative; overflow:hidden; }
.ins-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, var(--gold), var(--cyan)); transform:scaleX(0); transform-origin:left; transition:transform 0.4s var(--ease-out); }
.ins-card:hover { background:rgba(196,163,90,0.04); }
.ins-card:hover::before { transform:scaleX(1); }
.ins-card.featured { padding:54px; }
.ins-cat { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.ins-title { font-family:var(--font-display); font-size:1.55rem; font-weight:300; color:var(--fog-light); line-height:1.22; margin-bottom:14px; }
.ins-card.featured .ins-title { font-size:2.1rem; }
.ins-excerpt { font-size:0.84rem; line-height:1.78; color:var(--silver); margin-bottom:26px; }
.ins-meta { display:flex; align-items:center; gap:12px; font-size:0.7rem; color:var(--silver); letter-spacing:0.06em; }
.ins-dot { width:3px; height:3px; border-radius:50%; background:var(--gold-dark); flex-shrink:0; }
.ins-stacked { display:flex; flex-direction:column; gap:1px; background:var(--border-dim); }

/* ═══ CASE STUDIES ═══ */
.cases-section { background:var(--fog-light); color:var(--ink); }
.cases-section .headline-lg { color:var(--ink); }
.cases-section .label-line { background:var(--gold-dark); }
.cases-section .label-text { color:var(--gold-dark); }

.cases-header { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:end; margin-bottom:60px; }
.cases-header .body-md { color:#4a5568; }

.cases-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:rgba(0,0,0,0.07); }
.case-card { background:var(--fog-light); padding:50px 40px; position:relative; overflow:hidden; cursor:default; }
.case-card-overlay { position:absolute; inset:0; background:var(--ink-deep); opacity:0; transition:opacity 0.45s; display:flex; flex-direction:column; justify-content:flex-end; padding:50px 40px; z-index:2; }
.case-card:hover .case-card-overlay { opacity:0.96; }
.case-card:hover { transform:translateY(-4px); box-shadow:0 20px 60px rgba(0,0,0,0.15); z-index:3; }
.overlay-desc { font-size:0.88rem; line-height:1.78; color:var(--silver-lt); margin-bottom:24px; }
.overlay-link { font-size:0.68rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:8px; transition:gap 0.3s; }
.overlay-link:hover { gap:14px; }
.case-ind { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--gold-dark); margin-bottom:18px; }
.case-title { font-family:var(--font-display); font-size:1.5rem; font-weight:300; color:var(--ink); line-height:1.2; margin-bottom:24px; }
.case-metric { margin-bottom:22px; }
.case-metric-label { font-size:0.62rem; letter-spacing:0.14em; text-transform:uppercase; color:#8a9aaa; margin-bottom:4px; }
.case-metric-val { font-family:var(--font-display); font-size:2.6rem; font-weight:300; color:var(--ink); line-height:1; }
.case-metric-val sup { font-size:1.2rem; color:var(--gold-dark); }
.case-body { font-size:0.8rem; line-height:1.75; color:#6b7a8d; }

/* ═══ CTA SECTION ═══ */
.cta-section { background:var(--ink-deep); text-align:center; position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 65% 65% at 50% 50%, rgba(196,163,90,0.08), transparent 65%); }
.cta-inner { position:relative; z-index:2; max-width:760px; margin:0 auto; }
.cta-inner .label-row { justify-content:center; }
.cta-inner .headline-lg { color:var(--fog-light); margin-bottom:20px; }
.cta-sub { font-size:1rem; color:var(--silver); line-height:1.8; max-width:560px; margin:0 auto 50px; }
.cta-actions { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }

/* ═══ ABOUT PAGE ═══ */
.about-mission { background:var(--fog-light); color:var(--ink); }
.about-mission .headline-lg { color:var(--ink); }
.about-mission .label-line { background:var(--gold-dark); }
.about-mission .label-text { color:var(--gold-dark); }
.mission-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.mission-quote { font-family:var(--font-display); font-size:1.9rem; font-weight:300; line-height:1.35; color:var(--ink); font-style:italic; }
.mission-quote::before { content:'\201C'; color:var(--gold-dark); font-size:3rem; line-height:0.5; vertical-align:-0.5rem; margin-right:4px; }

.values-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:rgba(0,0,0,0.07); margin-top:80px; }
.value-card { background:var(--fog-light); padding:44px 32px; }
.value-icon { width:36px; height:36px; border:1px solid var(--gold-dark); transform:rotate(45deg); display:flex; align-items:center; justify-content:center; margin-bottom:28px; }
.value-icon span { transform:rotate(-45deg); color:var(--gold-dark); font-size:1rem; }
.value-title { font-family:var(--font-display); font-size:1.3rem; font-weight:400; color:var(--ink); margin-bottom:10px; }
.value-desc { font-size:0.82rem; line-height:1.78; color:#5a6472; }

.leadership-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--border-dim); margin-top:52px; }
.leader-card { background:var(--ink); padding:44px; }
.leader-name { font-family:var(--font-display); font-size:1.5rem; font-weight:300; color:var(--fog-light); margin-bottom:4px; }
.leader-role { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.leader-bio { font-size:0.84rem; line-height:1.78; color:var(--silver); }

/* ═══ SERVICES PAGE ═══ */
.service-detail { position:relative; }
.service-detail:nth-child(even) { background:var(--ink-mid); }
.service-detail-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.service-detail:nth-child(even) .service-detail-inner { direction:rtl; }
.service-detail:nth-child(even) .service-detail-content { direction:ltr; }
.service-detail:nth-child(even) .service-detail-visual { direction:ltr; }
.service-detail-content {}
.service-detail-num { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.service-detail-title { font-family:var(--font-display); font-size:clamp(2rem,3.5vw,3rem); font-weight:300; color:var(--fog-light); margin-bottom:20px; line-height:1.12; }
.service-detail-desc { font-size:0.95rem; line-height:1.85; color:var(--silver-lt); margin-bottom:32px; }
.service-bullets { display:flex; flex-direction:column; gap:12px; margin-bottom:36px; }
.service-bullet { display:flex; align-items:flex-start; gap:12px; font-size:0.87rem; line-height:1.65; color:var(--silver); }
.service-bullet::before { content:'◆'; color:var(--gold); font-size:0.5rem; margin-top:7px; flex-shrink:0; }
.service-detail-visual { display:flex; align-items:center; justify-content:center; }

/* ═══ INDUSTRIES PAGE ═══ */
.industry-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:rgba(0,0,0,0.07); margin-top:52px; }
.ind-card { background:var(--fog-light); padding:48px 36px; cursor:default; transition:all 0.4s var(--ease-out); }
.ind-card:hover { background:var(--white); transform:translateY(-4px); box-shadow:0 20px 50px rgba(0,0,0,0.1); z-index:2; }
.ind-card-num { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.2em; color:var(--gold-dark); margin-bottom:16px; text-transform:uppercase; }
.ind-card-name { font-family:var(--font-display); font-size:1.6rem; font-weight:300; color:var(--ink); margin-bottom:14px; }
.ind-card-desc { font-size:0.83rem; line-height:1.78; color:#5a6472; margin-bottom:20px; }
.ind-card-tags { display:flex; flex-wrap:wrap; gap:7px; }
.ind-card-tag { font-size:0.58rem; letter-spacing:0.1em; text-transform:uppercase; padding:4px 10px; border:1px solid rgba(0,0,0,0.12); color:#7a8a9a; }

/* ═══ INSIGHTS PAGE ═══ */
.insights-page-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--border-dim); margin-top:52px; }
.insight-full-card { background:var(--ink); padding:44px; text-decoration:none; color:inherit; display:block; transition:background 0.3s; }
.insight-full-card:hover { background:rgba(196,163,90,0.04); }

/* ═══ CAREERS PAGE ═══ */
.careers-section { background:var(--fog-light); color:var(--ink); }
.careers-section .headline-lg { color:var(--ink); }
.careers-section .label-line { background:var(--gold-dark); }
.careers-section .label-text { color:var(--gold-dark); }
.careers-values { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:rgba(0,0,0,0.07); margin-top:52px; margin-bottom:100px; }
.cv-card { background:var(--fog-light); padding:44px 36px; }
.cv-title { font-family:var(--font-display); font-size:1.35rem; font-weight:400; color:var(--ink); margin-bottom:10px; }
.cv-desc { font-size:0.83rem; line-height:1.78; color:#5a6472; }

.jobs-list { border-top:1px solid rgba(0,0,0,0.1); }
.job-row { display:flex; align-items:center; justify-content:space-between; padding:28px 0; border-bottom:1px solid rgba(0,0,0,0.06); text-decoration:none; color:inherit; transition:all 0.3s; }
.job-row:hover .job-title { color:var(--gold-dark); }
.job-row:hover .job-arrow { transform:translateX(6px); }
.job-left { display:flex; flex-direction:column; gap:4px; }
.job-title { font-family:var(--font-display); font-size:1.4rem; font-weight:300; color:var(--ink); transition:color 0.3s; }
.job-meta { display:flex; gap:20px; font-size:0.72rem; letter-spacing:0.08em; color:#7a8a9a; }
.job-arrow { font-size:1.2rem; color:var(--gold-dark); transition:transform 0.3s; }
.job-badge { font-size:0.6rem; letter-spacing:0.12em; text-transform:uppercase; padding:5px 12px; background:rgba(196,163,90,0.1); color:var(--gold-dark); border:1px solid rgba(196,163,90,0.2); }

/* ═══ CONTACT PAGE ═══ */
.contact-page { background:var(--ink-deep); min-height:100vh; }
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:0; }
.contact-info-panel { background:var(--ink); padding:80px 60px; border-right:1px solid var(--border-dim); }
.contact-form-panel { background:var(--ink-deep); padding:80px 60px; }

.contact-item { display:flex; align-items:flex-start; gap:16px; margin-bottom:36px; }
.contact-item-icon { width:40px; height:40px; border:1px solid var(--border-gold); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--gold); }
.contact-item-label { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--silver); margin-bottom:4px; }
.contact-item-value { font-family:var(--font-display); font-size:1.3rem; font-weight:300; color:var(--fog-light); }
.contact-item-value a { color:inherit; transition:color 0.3s; }
.contact-item-value a:hover { color:var(--gold); }

.form-group { margin-bottom:28px; }
.form-label { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--silver); display:block; margin-bottom:10px; }
.form-control { width:100%; background:rgba(255,255,255,0.04); border:1px solid var(--border-dim); padding:16px 18px; color:var(--fog); font-family:var(--font-body); font-size:0.9rem; font-weight:300; transition:all 0.3s; outline:none; -webkit-appearance:none; }
.form-control:focus { border-color:var(--gold); background:rgba(196,163,90,0.04); }
.form-control::placeholder { color:var(--silver); opacity:0.5; }
textarea.form-control { resize:vertical; min-height:140px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-submit { margin-top:8px; }
.form-success { display:none; padding:20px; background:rgba(196,163,90,0.1); border:1px solid var(--border-gold); color:var(--gold); font-size:0.9rem; margin-top:20px; }

/* ═══ FLOATING CTA ═══ */
.floating-cta { position:fixed; bottom:36px; right:36px; z-index:700; background:var(--gold); color:var(--ink); display:flex; align-items:center; gap:10px; padding:14px 24px; font-size:0.72rem; letter-spacing:0.14em; text-transform:uppercase; font-weight:400; transition:all 0.35s var(--ease-out); transform:translateY(80px); opacity:0; box-shadow:0 8px 32px rgba(196,163,90,0.35); }
.floating-cta.visible { transform:translateY(0); opacity:1; }
.floating-cta:hover { background:var(--fog); transform:translateY(-2px); box-shadow:0 16px 48px rgba(196,163,90,0.4); }

/* ═══ FOOTER ═══ */
.site-footer { background:var(--ink-deep); border-top:1px solid var(--border-dim); position:relative; overflow:hidden; }
.footer-glow { position:absolute; top:0; left:50%; transform:translateX(-50%); width:600px; height:200px; background:radial-gradient(ellipse at 50% 0%, rgba(196,163,90,0.06), transparent 70%); pointer-events:none; }
.footer-inner { position:relative; z-index:1; padding:80px 60px 40px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:64px; }
.footer-logo { display:flex; align-items:center; gap:12px; margin-bottom:20px; text-decoration:none; }
.footer-logo-mark { width:34px; height:34px; position:relative; }
.footer-logo-mark-inner { width:20px; height:20px; background:var(--gold); transform:rotate(45deg); position:absolute; top:50%; left:50%; translate:-50% -50%; }
.footer-logo-text { font-family:var(--font-display); font-size:1.1rem; font-weight:400; letter-spacing:0.12em; text-transform:uppercase; color:var(--fog); display:flex; flex-direction:column; line-height:1; }
.footer-logo-text em { font-style:normal; font-size:0.7rem; letter-spacing:0.22em; color:var(--gold); margin-top:3px; font-weight:300; }
.footer-tagline { font-family:var(--font-display); font-style:italic; font-size:0.9rem; color:var(--silver); line-height:1.65; max-width:280px; margin-bottom:24px; }
.footer-contact-info { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.footer-contact-info a { font-size:0.82rem; color:var(--silver); display:flex; align-items:center; gap:8px; transition:color 0.3s; }
.footer-contact-info a:hover { color:var(--gold); }
.footer-socials { display:flex; gap:12px; }
.social-link { width:34px; height:34px; border:1px solid var(--border-dim); display:flex; align-items:center; justify-content:center; font-size:0.8rem; color:var(--silver); transition:all 0.3s; }
.social-link:hover { border-color:var(--gold); color:var(--gold); }
.footer-col h4 { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.footer-col ul { display:flex; flex-direction:column; gap:11px; }
.footer-col a { font-size:0.83rem; color:var(--silver); transition:color 0.3s; }
.footer-col a:hover { color:var(--fog); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--border-dim); padding-top:28px; flex-wrap:wrap; gap:16px; }
.footer-copy { font-size:0.73rem; color:var(--silver); letter-spacing:0.04em; }
.footer-copy a { color:var(--gold); }
.footer-legal { display:flex; gap:24px; }
.footer-legal a { font-size:0.73rem; color:var(--silver); transition:color 0.3s; }
.footer-legal a:hover { color:var(--fog); }

/* ═══ SVG ANIMATIONS ═══ */
@keyframes node-pulse { 0%,100%{opacity:0.5} 50%{opacity:1} }
@keyframes dash-flow { from{stroke-dashoffset:0} to{stroke-dashoffset:-48} }
@keyframes ring-spin { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes ring-spin-rev { from{transform:rotate(0)} to{transform:rotate(-360deg)} }
@keyframes float-up { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }

.anim-pulse { animation:node-pulse 2.8s ease-in-out infinite; }
.anim-flow { stroke-dasharray:10 5; animation:dash-flow 2.2s linear infinite; }
.anim-ring { transform-origin:center; animation:ring-spin 22s linear infinite; }
.anim-ring-rev { transform-origin:center; animation:ring-spin-rev 16s linear infinite; }
.anim-float { animation:float-up 5s ease-in-out infinite; }

/* ═══ RESPONSIVE ═══ */
@media (max-width:1200px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .insights-grid { grid-template-columns:1fr 1fr; }
  .ins-stacked:last-child { display:none; }
  .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
  .cases-grid { grid-template-columns:repeat(2,1fr); }
  .cases-grid .case-card:last-child { grid-column:span 2; max-width:50%; }
}
@media (max-width:960px) {
  .header-inner { padding:0 28px; }
  .main-nav, .header-phone { display:none; }
  .hamburger { display:flex; }
  .container { padding:0 28px; }
  .services-intro, .approach-grid, .industries-header, .cases-header, .mission-grid, .contact-grid { grid-template-columns:1fr; gap:36px; }
  .approach-visual { display:none; }
  .cases-grid { grid-template-columns:1fr; }
  .cases-grid .case-card:last-child { grid-column:auto; max-width:100%; }
  .hero-canvas { display:none; }
  .hero-stats { gap:28px; }
  .insights-grid { grid-template-columns:1fr; }
  .leadership-grid { grid-template-columns:1fr; }
  .service-detail-inner { grid-template-columns:1fr; direction:ltr !important; }
  .service-detail-visual { display:none; }
  .industry-cards { grid-template-columns:1fr; }
  .insights-page-grid { grid-template-columns:1fr; }
  .careers-values { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .ind-tags { display:none; }
  .services-desc { max-width:100%; }
  .contact-info-panel, .contact-form-panel { padding:48px 28px; }
  .contact-grid { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  .footer-inner { padding:60px 28px 32px; }
  .page-hero-title { font-size:clamp(2.4rem,8vw,4rem); }
}
@media (max-width:600px) {
  .hero-headline { font-size:clamp(2.6rem,9vw,4rem); }
  .hero-stats { flex-direction:column; gap:20px; }
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .values-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .floating-cta { bottom:20px; right:20px; padding:12px 18px; font-size:0.66rem; }
}
