:root{
    --pols-blue:#1A0FBF;
    --pols-blue-2:#2A1CE8;
    --pols-blue-soft:#5A4DFF;
    --pols-blue-glow: 26 15 191;
    --ink:#0A0A14;
    --ink-2:#13131F;
    --ink-3:#1B1B2C;
    --paper:#F4F2EC;
    --paper-2:#ECEAE2;
    --line:rgba(255,255,255,.10);
    --line-d:rgba(10,10,20,.12);
    --radius-l: 4px;
    --radius-m: 4px;
    --radius-s: 2px;
    --maxw:1280px;
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Space Grotesk', system-ui, -apple-system, sans-serif;
    background:var(--ink); color:#fff;
    -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  img{max-width:100%; display:block}
  a{color:inherit; text-decoration:none}
  button{font:inherit}
  ::selection{background:var(--pols-blue); color:#fff}

  /* Subtle film grain overlay */
  .grain{position:fixed; inset:0; pointer-events:none; z-index:60; opacity:.06; mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  }

  /* ============== HEADER ============== */
  .nav-wrap{position:fixed; top:0; left:0; right:0; z-index:50;
    transition:background .3s ease, backdrop-filter .3s ease, border-color .3s ease;
    border-bottom:1px solid transparent;
  }
  .nav-wrap.solid{background:rgba(10,10,20,.78); backdrop-filter:saturate(140%) blur(14px); border-color:var(--line)}
  .nav-wrap.light{background:rgba(244,242,236,.92); backdrop-filter:saturate(140%) blur(14px); border-color:rgba(10,10,20,.20); color:var(--ink); box-shadow:0 1px 0 rgba(10,10,20,.10)}
  .nav{max-width:var(--maxw); margin:0 auto; padding:14px 28px; display:flex; align-items:center; justify-content:space-between; gap:24px}
  .brand{display:flex; align-items:center; gap:12px; cursor:pointer}
  .brand-mark{
    width:42px; height:42px; border-radius:4px; background:var(--pols-blue);
    display:grid; place-items:center; color:#fff; font-weight:700; letter-spacing:.5px;
    font-family:'Space Grotesk',sans-serif;
    font-size:13px;
  }
  .brand-mark span{transform:translateY(-1px)}
  .brand-name{font-weight:700; letter-spacing:.04em; font-size:14px}
  .brand-sub{font-size:11px; opacity:.6; margin-top:-2px; letter-spacing:.16em; text-transform:uppercase}
  .nav-links{display:flex; align-items:center; gap:4px}
  .nav-links a{padding:8px 12px; border-radius:3px; font-size:14px; opacity:.72; transition:opacity .2s, background .2s, color .2s}
  .nav-links a:hover{opacity:1; background:rgba(255,255,255,.07)}
  .nav-wrap.light .nav-links a:hover{background:rgba(10,10,20,.07)}
  .nav-links a.active{opacity:1; background:rgba(255,255,255,.09)}
  .nav-wrap.light .nav-links a.active{background:rgba(10,10,20,.08)}
  .cta{display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border-radius:4px;
    background:var(--pols-blue); color:#fff; font-weight:600; font-size:14px;
    border:1px solid rgba(255,255,255,.08);
    transition:transform .2s, background .2s, box-shadow .2s;
  }
  .cta:hover{transform:translateY(-1px); background:var(--pols-blue-2); box-shadow:0 8px 24px -6px rgba(26,15,191,.55)}
  .cta.ghost{background:transparent; color:#fff; border:1px solid rgba(255,255,255,.3); box-shadow:none}
  .nav-wrap.light .cta.ghost{color:var(--ink); border-color:rgba(10,10,20,.22)}
  .cta.ghost:hover{background:rgba(255,255,255,.08)}
  .nav-wrap.light .cta.ghost:hover{background:rgba(10,10,20,.06)}
  .burger{display:none; width:42px; height:42px; border-radius:4px; border:1px solid rgba(255,255,255,.18); background:transparent; cursor:pointer; align-items:center; justify-content:center}
  .nav-wrap.light .burger{border-color:rgba(10,10,20,.18)}
  .burger svg{width:20px; height:20px}

  @media (max-width: 980px){
    .nav-links, .nav .cta:not(.mobile-cta){display:none}
    .burger{display:inline-flex}
  }
  /* mobile nav drawer */
  .drawer{position:fixed; inset:0; z-index:70; background:var(--ink); transform:translateY(-100%); transition:transform .4s cubic-bezier(.7,0,.2,1); display:flex; flex-direction:column; padding:24px 28px; overflow:auto}
  .drawer.open{transform:translateY(0)}
  .drawer-top{display:flex; justify-content:space-between; align-items:center}
  .drawer-links{display:flex; flex-direction:column; gap:0; margin-top:48px}
  .drawer-links a{font-size:32px; font-weight:600; letter-spacing:-.01em; padding:14px 0; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between}
  .drawer-links a small{font-size:11px; opacity:.4; letter-spacing:.2em}
  .drawer-foot{margin-top:auto; padding-top:32px; display:flex; flex-direction:column; gap:8px; opacity:.6; font-size:13px}

  /* ============== HERO ============== */
  .hero{position:relative; height:100dvh; min-height:660px; overflow:hidden; isolation:isolate}
  .hero-bg{position:absolute; inset:0; z-index:0; background:#06060E; overflow:hidden}
  /* Hero background real photo */
  .hero-bg-img{
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; object-position:center 38%;
    display:block;
  }
  /* Dark + brand overlay on top of photo */
  .hero-bg-overlay{
    position:absolute; inset:0;
    background:
      linear-gradient(to bottom, rgba(6,6,14,.72) 0%, rgba(10,10,20,.30) 35%, rgba(10,10,20,.30) 60%, rgba(6,6,14,.90) 100%),
      radial-gradient(80% 60% at 70% 30%, rgba(26,15,191,.14), transparent 60%);
  }
  /* Ambient atmospheric lights — subtle, not SaaS */
  .stage-light{position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; mix-blend-mode:screen}
  .sl-1{width:460px; height:460px; background:rgba(26,15,191,.18); top:-120px; left:-120px; animation:float1 20s ease-in-out infinite}
  .sl-2{width:500px; height:500px; background:rgba(90,77,255,.12); bottom:-180px; right:-140px; animation:float2 24s ease-in-out infinite}
  .sl-3{width:260px; height:260px; background:rgba(255,255,255,.04); top:30%; right:20%; animation:float3 18s ease-in-out infinite}
  @keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,40px)}}
  @keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-60px,-30px)}}
  @keyframes float3{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-20px)}}

  .hero-inner{position:relative; z-index:2; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:0 24px}

  .scroll-expand{
    position:absolute; left:50%; top:50%;
    width:220px; height:290px;
    transform:translate(-50%,-50%);
    border-radius:0; overflow:hidden;
    box-shadow:0 20px 60px -16px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.08);
    will-change: width, height;
    transition:width .15s linear, height .15s linear;
  }
  .scroll-expand .visual{
    position:absolute; inset:0;
    background:
      radial-gradient(60% 60% at 50% 40%, rgba(90,77,255,.4), transparent 70%),
      linear-gradient(135deg, #1A0FBF 0%, #0A0A14 60%, #1B1B2C 100%);
  }
  .scroll-expand .visual::before{
    content:""; position:absolute; inset:0;
    background-image:
      repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 4px),
      radial-gradient(50% 30% at 50% 90%, rgba(255,255,255,.18), transparent 60%);
    mix-blend-mode:overlay;
  }
  .scroll-expand .visual::after{
    content:""; position:absolute; left:0; right:0; bottom:0; height:42%;
    background:
      radial-gradient(20px 18px at 8% 100%, #000 60%, transparent 62%),
      radial-gradient(22px 22px at 16% 100%, #000 60%, transparent 62%),
      radial-gradient(18px 20px at 24% 100%, #000 60%, transparent 62%),
      radial-gradient(24px 22px at 33% 100%, #000 60%, transparent 62%),
      radial-gradient(20px 20px at 42% 100%, #000 60%, transparent 62%),
      radial-gradient(22px 24px at 51% 100%, #000 60%, transparent 62%),
      radial-gradient(20px 20px at 60% 100%, #000 60%, transparent 62%),
      radial-gradient(24px 22px at 69% 100%, #000 60%, transparent 62%),
      radial-gradient(20px 20px at 78% 100%, #000 60%, transparent 62%),
      radial-gradient(22px 22px at 87% 100%, #000 60%, transparent 62%),
      radial-gradient(20px 18px at 96% 100%, #000 60%, transparent 62%),
      linear-gradient(to top, rgba(0,0,0,.85), transparent);
  }
  .scroll-expand-poster{display:none}
  .scroll-expand-poster .poster-mark{
    width:auto; height:auto; min-width:0; padding:8px 13px; border-radius:3px; background:rgba(255,255,255,.92); color:var(--pols-blue);
    display:grid; place-items:center; font-weight:700; letter-spacing:.06em;
    font-size:11px;
  }
  .scroll-expand-overlay{position:absolute; inset:0; background:rgba(0,0,0,.35)}

  .hero-title{
    position:relative; z-index:3;
    font-size: clamp(34px, 5.8vw, 76px);
    line-height:.96; letter-spacing:-.03em; font-weight:700;
    margin:0; color:#fff;
    text-shadow: 0 2px 24px rgba(0,0,0,.45);
    will-change: transform;
  }
  .hero-title .word{display:inline-block; will-change:transform}
  .hero-title .word.left{transform:translateX(0)}
  .hero-title .word.right{transform:translateX(0)}
  .hero-row{display:flex; justify-content:center; gap:.4em}
  .hero-sub{
    display:none;
    margin-top:18px; font-size:12px; letter-spacing:.34em; text-transform:uppercase;
    color:rgba(226,223,255,.68); position:relative; z-index:3;
  }
  .hero-scroll-hint{position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:3;
    display:flex; align-items:center; gap:10px; font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.6)}
  .hero-scroll-hint .arrow{width:1px; height:32px; background:rgba(255,255,255,.4); position:relative; overflow:hidden}
  .hero-scroll-hint .arrow::after{content:""; position:absolute; left:0; top:-100%; width:100%; height:50%; background:#fff; animation:scrollPulse 1.8s ease-in-out infinite}
  @keyframes scrollPulse{0%{top:-50%}100%{top:100%}}

  /* hero overlay content shown after expansion */
  .hero-after{
    position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:4;
    text-align:center; max-width:760px; padding:0 24px;
    opacity:0; pointer-events:none; transition:opacity .5s ease;
  }
  .hero-after.show{opacity:1; pointer-events:auto}
  .hero-after h1{font-size:clamp(36px,6vw,68px); margin:0 0 16px; letter-spacing:-.03em; line-height:1; font-weight:700}
  .hero-after p{font-size:clamp(16px,1.6vw,20px); opacity:.78; margin:0 0 28px; line-height:1.5}
  .hero-after .btn-row{display:flex; gap:12px; justify-content:center; flex-wrap:wrap}

  /* ============== PAGES ============== */
  main{position:relative}
  .page{display:none; min-height:100vh}
  .page.active{display:block; animation:pageIn .4s ease}
  @keyframes pageIn{from{opacity:0; transform:translateY(6px)}to{opacity:1; transform:translateY(0)}}

  .container{max-width:var(--maxw); margin:0 auto; padding:0 28px}

  /* eyebrow + section title */
  .eyebrow{font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.26em; text-transform:uppercase; opacity:.55; display:inline-flex; align-items:center; gap:10px}
  .eyebrow::before{content:""; width:24px; height:1px; background:currentColor; opacity:.5}
  h1.display, h2.display{font-size:clamp(36px, 5.8vw, 84px); line-height:.95; letter-spacing:-.035em; margin:18px 0 24px; font-weight:700}
  h2.display .ital{font-family:'Instrument Serif', serif; font-style:italic; font-weight:400; letter-spacing:-.02em}
  .lede{font-size:clamp(17px, 1.6vw, 22px); line-height:1.55; opacity:.78; max-width:62ch}

  section.block{padding:120px 0; position:relative}
  section.block.tight{padding:80px 0}
  section.block.dark{background:var(--ink)}
  section.block.darker{background:#06060E}
  section.block.light{background:var(--paper); color:var(--ink)}
  section.block.light .lede{opacity:.72}
  section.block.blue{background:var(--pols-blue); color:#fff}

  .row{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start}
  @media (max-width:880px){.row{grid-template-columns:1fr; gap:32px}}

  /* CARDS / GRIDS */
  .grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line)}
  .grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line)}
  .grid-4{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line)}
  @media (max-width:1080px){.grid-3{grid-template-columns:repeat(2,1fr)} .grid-4{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:640px){.grid-3,.grid-2,.grid-4{grid-template-columns:1fr}}

  /* Override gap for light sections and specific grids */
  section.block.light .grid-3,
  section.block.light .grid-2,
  section.block.light .grid-4{background:var(--line-d)}

  .card{
    background:var(--ink-2); border:none;
    padding:32px; transition:background .25s;
    position:relative; overflow:hidden;
  }
  .card:hover{background:#161624}
  .card .num{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.2em; opacity:.4}
  .card h3{margin:14px 0 10px; font-size:22px; letter-spacing:-.01em; line-height:1.2}
  .card p{margin:0; opacity:.7; font-size:15px; line-height:1.55}
  .card .icon{width:48px; height:48px; border-radius:4px; background:rgba(90,77,255,.12); border:1px solid rgba(90,77,255,.22); display:grid; place-items:center; color:#B9B3FF; margin-bottom:18px}
  .card .icon svg{width:22px; height:22px}

  .card.light{background:#fff; color:var(--ink)}
  .card.light p{opacity:.65}
  .card.light:hover{background:#F7F6F0}
  .card.light .icon{background:rgba(26,15,191,.07); border-color:rgba(26,15,191,.18); color:var(--pols-blue)}

  /* Big highlight card */
  .feature-card{
    grid-column:span 2; padding:40px;
    background:linear-gradient(135deg, rgba(26,15,191,.18), rgba(10,10,20,.36));
    border:1px solid rgba(90,77,255,.22); position:relative; overflow:hidden;
  }
  @media (max-width:640px){.feature-card{grid-column:span 1}}

  /* PILL TAGS */
  .pill{display:inline-flex; align-items:center; padding:5px 10px; border-radius:3px; font-size:11px; letter-spacing:.06em; text-transform:uppercase; background:rgba(90,77,255,.12); color:#C8C2FF; border:1px solid rgba(90,77,255,.25)}
  .pill.dark{background:rgba(26,15,191,.08); color:var(--pols-blue); border-color:rgba(26,15,191,.18)}

  /* AUDIENCE STRIP */
  .audience{display:grid; grid-template-columns:repeat(7,1fr); gap:0; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
  .audience > div{padding:32px 16px; text-align:center; border-right:1px solid var(--line); transition:background .25s}
  .audience > div:last-child{border-right:none}
  .audience > div:hover{background:rgba(255,255,255,.04)}
  .audience .num{font-family:'JetBrains Mono', monospace; font-size:11px; opacity:.4; letter-spacing:.2em}
  .audience .name{margin-top:6px; font-size:18px; letter-spacing:-.01em}
  .audience.light{border-color:var(--line-d)}
  .audience.light > div{border-right-color:var(--line-d)}
  .audience.light > div:hover{background:rgba(26,15,191,.04)}
  @media (max-width:880px){.audience{grid-template-columns:repeat(2,1fr)} .audience > div{border-right:1px solid var(--line); border-bottom:1px solid var(--line)}}
  @media (max-width:540px){.audience{grid-template-columns:1fr}}

  /* METHOD STEPS */
  .steps{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--ink)}
  @media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:540px){.steps{grid-template-columns:1fr}}
  .step{padding:32px; background:#fff; color:var(--ink); position:relative; min-height:200px}
  .step .step-num{
    width:40px; height:40px; border-radius:3px; background:var(--pols-blue); color:#fff;
    display:grid; place-items:center; font-weight:700; font-size:14px; letter-spacing:.04em;
  }
  .step h4{margin:18px 0 8px; font-size:20px; letter-spacing:-.01em; color:var(--ink)}
  .step p{margin:0; font-size:14px; line-height:1.5; color:var(--ink); opacity:.7}

  /* PAGE HERO */
  .page-hero{padding:160px 0 80px; position:relative; overflow:hidden}
  .page-hero.dark{background:var(--ink); color:#fff}
  .page-hero.dark::before{content:""; position:absolute; inset:0;
    background:
      radial-gradient(50% 60% at 80% 30%, rgba(26,15,191,.22), transparent 70%),
      radial-gradient(50% 60% at 10% 80%, rgba(90,77,255,.14), transparent 70%);
  }
  .page-hero.light{background:var(--paper); color:var(--ink)}
  .page-hero.blue{background:var(--pols-blue); color:#fff; position:relative}
  .page-hero .container{position:relative; z-index:2}
  .page-hero h1{font-size:clamp(40px, 7vw, 96px); line-height:.95; letter-spacing:-.035em; margin:18px 0 24px; font-weight:700; max-width:18ch}
  .page-hero .lede{max-width:60ch}

  /* QUOTE BAR */
  .quotebar{padding:120px 0; background:var(--ink); position:relative; overflow:hidden; border-top:1px solid var(--line)}
  .quotebar blockquote{font-size:clamp(28px, 3.6vw, 48px); line-height:1.15; letter-spacing:-.02em; max-width:22ch; margin:0 auto; text-align:center; font-weight:600; position:relative; z-index:2}
  .quotebar blockquote .ital{font-family:'Instrument Serif', serif; font-style:italic; font-weight:400}

  /* CTA BAND */
  .cta-band{padding:120px 0; background:var(--pols-blue); color:#fff; text-align:center; position:relative; overflow:hidden}
  .cta-band h2{font-size:clamp(36px, 5vw, 72px); line-height:1; letter-spacing:-.03em; margin:0 0 24px; font-weight:700; position:relative; z-index:2}
  .cta-band p{font-size:18px; opacity:.85; max-width:50ch; margin:0 auto 32px; position:relative; z-index:2}
  .cta-band .btn-row{position:relative; z-index:2; display:flex; justify-content:center; gap:12px; flex-wrap:wrap}
  .cta-band .cta{background:#fff; color:var(--pols-blue); border-color:transparent; box-shadow:none}
  .cta-band .cta:hover{background:#F0EFFF; box-shadow:none}
  .cta-band .cta.ghost{background:transparent; color:#fff; border:1px solid rgba(255,255,255,.4)}
  .cta-band .cta.ghost:hover{background:rgba(255,255,255,.1)}

  /* FORMATS GRID */
  .format-card{
    background:#fff; color:var(--ink); border-radius:0; padding:32px;
    border:none;
    display:flex; flex-direction:column; gap:14px;
    transition:background .25s;
    position:relative; overflow:hidden;
  }
  .format-card:hover{background:#F7F6F0}
  .format-card .tag-row{display:flex; gap:6px; flex-wrap:wrap}
  .format-card h3{margin:0; font-size:26px; letter-spacing:-.015em; line-height:1.1}
  .format-card .who{font-size:14px; opacity:.6; margin:0}
  .format-card ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; font-size:14px; line-height:1.4}
  .format-card ul li{display:flex; gap:10px; opacity:.85}
  .format-card ul li::before{content:""; flex:none; margin-top:7px; width:6px; height:6px; border-radius:1px; background:var(--pols-blue)}
  .format-card .energy{margin-top:auto; padding-top:14px; border-top:1px solid rgba(10,10,20,.08); display:flex; justify-content:space-between; align-items:center; font-size:12px; letter-spacing:.06em; text-transform:uppercase; opacity:.6}

  /* Grid wrapper for formats */
  #formatsGrid{background:var(--line-d); gap:1px; display:grid; grid-template-columns:repeat(3,1fr)}
  @media(max-width:900px){#formatsGrid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:540px){#formatsGrid{grid-template-columns:1fr}}

  /* ABOUT */
  .values{display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line-d)}
  .values > div{padding:32px 24px; border-bottom:1px solid var(--line-d); border-right:1px solid var(--line-d)}
  .values > div:nth-child(3n){border-right:none}
  .values > div h4{margin:0 0 6px; font-size:18px; letter-spacing:-.01em}
  .values > div p{margin:0; font-size:14px; opacity:.65; line-height:1.5}
  .values .v-num{font-family:'JetBrains Mono',monospace; font-size:11px; opacity:.4; letter-spacing:.2em}
  @media (max-width:780px){.values{grid-template-columns:1fr}.values > div{border-right:none}}

  /* CONTACT */
  .contact-grid{display:grid; grid-template-columns:1.2fr 1fr; gap:60px; align-items:start}
  @media (max-width:980px){.contact-grid{grid-template-columns:1fr}}
  form{display:grid; grid-template-columns:1fr 1fr; gap:14px}
  form .full{grid-column:1 / -1}
  .field{display:flex; flex-direction:column; gap:6px}
  .field label{font-size:12px; letter-spacing:.16em; text-transform:uppercase; opacity:.55}
  .field input, .field textarea, .field select{
    background:#fff; color:var(--ink); border:1px solid rgba(10,10,20,.16);
    border-radius:4px; padding:14px 16px; font:inherit; font-size:15px;
    transition:border-color .2s, box-shadow .2s;
  }
  .field input:focus, .field textarea:focus, .field select:focus{
    outline:none; border-color:var(--pols-blue); box-shadow:0 0 0 3px rgba(26,15,191,.10);
  }
  .field textarea{min-height:140px; resize:vertical}
  form .submit{grid-column:1 / -1; display:flex; gap:12px; flex-wrap:wrap; margin-top:8px}

  .contact-info{padding:32px; border-radius:0; background:var(--ink-2); border:1px solid var(--line)}
  .contact-info h3{margin:0 0 18px; font-size:22px}
  .contact-info .row-info{display:flex; flex-direction:column; gap:8px; margin-bottom:24px}
  .contact-info .row-info a{display:flex; gap:12px; align-items:center; padding:14px 16px; border-radius:4px; background:#0f0f1c; border:1px solid var(--line); transition:border-color .2s, background .2s}
  .contact-info .row-info a:hover{border-color:var(--pols-blue-soft); background:#13132a}
  .contact-info .label{font-size:11px; letter-spacing:.2em; text-transform:uppercase; opacity:.5}
  .contact-info .value{font-size:15px; font-weight:500}
  .wa-cta{display:inline-flex; align-items:center; gap:10px; padding:14px 20px; border-radius:4px; background:#25D366; color:#fff; font-weight:600; font-size:15px; transition:transform .2s, box-shadow .2s}
  .wa-cta:hover{transform:translateY(-1px); box-shadow:0 10px 24px -8px rgba(37,211,102,.45)}

  /* Floating WhatsApp button */
  .wa-float{position:fixed; right:22px; bottom:22px; z-index:55; width:52px; height:52px; border-radius:50%; background:#25D366; display:grid; place-items:center; box-shadow:0 8px 20px -4px rgba(37,211,102,.4); transition:transform .25s}
  .wa-float:hover{transform:translateY(-2px) scale(1.04)}
  .wa-float svg{width:26px; height:26px; fill:#fff}

  /* ============== FOOTER ============== */
  footer{background:#06060E; padding:80px 0 24px; border-top:1px solid var(--line); position:relative}
  .foot-grid{display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:48px; position:relative}
  @media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr; gap:32px}}
  @media (max-width:540px){.foot-grid{grid-template-columns:1fr}}
  .foot-grid h5{margin:0 0 14px; font-size:12px; letter-spacing:.2em; text-transform:uppercase; opacity:.5}
  .foot-grid ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px}
  .foot-grid a{opacity:.75; font-size:14px; transition:opacity .2s}
  .foot-grid a:hover{opacity:1}
  .foot-brand p{font-size:14px; opacity:.6; max-width:36ch; margin:14px 0 0; line-height:1.55}
  .foot-bottom{margin-top:60px; padding-top:24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:12px; opacity:.5}

  /* small reveal */
  .reveal{opacity:0; transform:translateY(16px); transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1; transform:translateY(0)}

  /* ============ FOCUS ============ */
  a:focus-visible,button:focus-visible{outline:2px solid var(--pols-blue);outline-offset:3px;border-radius:3px}

  /* ============ SCROLL PROGRESS ============ */
  .scroll-progress{position:fixed;top:0;left:0;height:2px;background:var(--pols-blue-soft);z-index:200;width:0;transition:width .08s linear;pointer-events:none}

  /* ============ HERO REAL IMAGE ============ */
  .expand-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;z-index:0}
  .scroll-expand .visual,.scroll-expand .visual::before,.scroll-expand .visual::after{display:none}
  .scroll-expand-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(26,15,191,.18) 0%,rgba(0,0,0,.48) 100%)}
  .scroll-expand-poster{z-index:2}

  /* ============ HERO MOBILE ============ */
  @media(max-width:767px){
    .scroll-expand,.hero-inner,.hero-scroll-hint{display:none!important}
    .hero{display:flex;align-items:center;justify-content:center}
    .hero-bg{
      background:
        linear-gradient(to bottom,rgba(6,6,14,.45) 0%,rgba(10,10,20,.82) 100%),
        url('../../public/images/events/event-crowd-main.webp') center 30% / cover no-repeat;
    }
    .stage-light{display:none}
    .hero-after{
      position:relative!important;left:auto!important;top:auto!important;
      transform:none!important;opacity:1!important;pointer-events:auto!important;
      padding:110px 20px 64px;max-width:100%;width:100%;text-align:center;
    }
    .hero-after h1{font-size:clamp(30px,8.5vw,44px);line-height:1.08}
    .hero-after p{font-size:15px;margin-bottom:24px}
    .hero-after .btn-row{justify-content:center}
  }

  /* ============ HERO STRIP ============ */
  .hero-strip{position:relative;height:400px;overflow:hidden}
  .hero-strip img{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block;transition:transform 8s ease}
  .hero-strip:hover img{transform:scale(1.04)}
  .hero-strip-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,20,.92) 0%,rgba(10,10,20,.08) 35%,rgba(10,10,20,.08) 65%,rgba(10,10,20,.85) 100%)}
  .hero-strip-label{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);white-space:nowrap;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.52);display:flex;align-items:center;gap:16px}
  .hero-strip-label::before,.hero-strip-label::after{content:"";width:40px;height:1px;background:rgba(255,255,255,.28)}
  @media(max-width:640px){.hero-strip{height:240px}.hero-strip-label{font-size:10px;gap:10px}.hero-strip-label::before,.hero-strip-label::after{width:24px}}

  /* ============ BENTO GRID ============ */
  .bento-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-template-rows:300px 210px;gap:3px}
  .bento-item{position:relative;border-radius:0;overflow:hidden;background:var(--ink-3)}
  .bento-item img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
  .bento-item:hover img{transform:scale(1.04)}
  .bento-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.55));pointer-events:none}
  .bento-caption{position:absolute;bottom:14px;left:16px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
  .bento-item:hover .bento-caption{opacity:1;transform:translateY(0)}
  .bento-main{grid-row:span 2}
  @media(prefers-reduced-motion:reduce){.bento-item img,.hero-strip img{transition:none}.bento-item:hover img,.hero-strip:hover img{transform:none}}
  @media(max-width:900px){.bento-grid{grid-template-columns:1fr 1fr;grid-template-rows:260px 200px 200px}.bento-main{grid-row:span 1;grid-column:span 2}}
  @media(max-width:540px){.bento-grid{grid-template-columns:1fr;gap:2px}.bento-item{height:220px}.bento-main{height:280px;grid-column:span 1}}

  /* ============ IMG TEASER ============ */
  .img-teaser{border-radius:0;overflow:hidden;position:relative;height:360px}
  .img-teaser img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
  .img-teaser:hover img{transform:scale(1.03)}
  .img-teaser-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.6))}
  @media(max-width:880px){.img-teaser{height:240px}}

  /* ============ MOBILE GENERAL ============ */
  @media(max-width:767px){
    section.block{padding:72px 0}
    section.block.tight{padding:52px 0}
    .container{padding:0 18px}
    h2.display{font-size:clamp(28px,7.5vw,48px)}
    .lede{font-size:clamp(16px,1.8vw,20px)}
    .page-hero{padding:110px 0 56px}
    .cta-band{padding:72px 0}
    .quotebar{padding:72px 0}
    .quotebar blockquote{font-size:clamp(24px,5.5vw,36px)}
    .foot-bottom{flex-direction:column;gap:6px}
    .audience .name{font-size:15px}
    .feature-card{padding:28px}
  }
  @media(max-width:640px){
    form{grid-template-columns:1fr}
    form .full{grid-column:1}
    form .submit{flex-direction:column;align-items:flex-start}
    .contact-grid{gap:28px}
    .page-hero h1{font-size:clamp(28px,7.5vw,46px)}
    .card{padding:20px}
    .card h3{font-size:19px}
    .format-card{padding:22px}
    .format-card h3{font-size:21px}
    .steps{gap:0}
    .step{padding:22px;min-height:auto;border-bottom:1px solid rgba(10,10,20,.14)}
    .step:last-child{border-bottom:none}
  }
  @media(max-width:440px){
    .audience{grid-template-columns:1fr 1fr}
    .nav{padding:12px 16px}
    .drawer-links a{font-size:26px}
  }

  /* ============ PREFERS REDUCED MOTION ============ */
  @media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
    .reveal,.reveal.in{opacity:1!important;transform:none!important;transition:none!important}
    .stage-light{animation:none!important}
    .page.active{animation:none}
  }

  /* ============ FORM NOTE ============ */
  .form-note{font-size:12px;opacity:.5;margin:8px 0 0;line-height:1.5;grid-column:1/-1}

  /* Hide floating WA on contact page — form already has inline WA CTA */
  body[data-page="contacte"] .wa-float{display:none}

  /* Skip to content link */
  .skip-link{position:absolute;left:-100vw;top:8px;background:var(--pols-blue);color:#fff;padding:8px 18px;z-index:300;font-size:14px;font-weight:600;border-radius:0 0 4px 4px;text-decoration:none}
  .skip-link:focus{left:8px}
