:root{
    --bg: #ffffff;
    --bg-tint: #f0f7ee;          /* light green wash */
    --bg-dark: #0e1411;          /* near-black ink */
    --ink: #111613;
    --ink-2: #3b423e;
    --muted: #6b736e;
    --line: #e6ebe7;
    --line-2: #d4dcd6;
    --green: #7ED957;            /* primary brand green */
    --green-2: #5fbe39;
    --green-dark: #1f6b1f;
    --green-ink: #0e3017;
    --chip: #eafbe1;
    --warn: #f5b342;
    --radius: 18px;
    --radius-sm: 12px;
    --radius-lg: 28px;
    --radius-hero: 26px;
    --shadow-sm: 0 1px 2px rgba(15,30,20,.05), 0 4px 14px -8px rgba(15,30,20,.08);
    --shadow-md: 0 4px 20px -8px rgba(15,30,20,.18), 0 24px 60px -28px rgba(15,30,20,.22);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    color: var(--ink);
    background: var(--bg);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  h1,h2,h3,h4{font-family:'Space Grotesk', 'Inter', sans-serif; font-weight:600; letter-spacing:-0.02em; margin:0; text-wrap: balance;}
  h1{font-size: clamp(38px, 5vw, 64px); line-height: 1.05;}
  h2{font-size: clamp(28px, 3.4vw, 44px); line-height: 1.08;}
  h3{font-size: 20px; line-height: 1.3;}
  p{margin:0; text-wrap:pretty;}
  a{color:inherit; text-decoration:none}
  button{font-family:inherit; cursor:pointer; border:0; background:none}
  img{display:block; max-width:100%}
  .wrap{max-width: 1180px; margin: 0 auto; padding: 0 28px;}
  .eyebrow{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--green-dark);
    display:inline-flex; align-items:center; gap:8px;
  }
  .eyebrow::before{content:""; width:18px; height:1px; background: var(--green-dark);}
  .btn{
    display:inline-flex; align-items:center; gap:10px;
    padding: 14px 22px;
    border-radius: 999px;
    font-weight: 500;
    font-size: 15px;
    transition: transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
    white-space: nowrap;
  }
  .btn-primary{background: var(--green); color: var(--green-ink);}
  .btn-primary:hover{background: var(--green-2); transform: translateY(-1px);}
  .btn-ghost{background: transparent; color: var(--ink); border:1px solid var(--line-2);}
  .btn-ghost:hover{background: #f7faf7;}
  .btn-dark{background: var(--bg-dark); color:#fff;}
  .btn-dark:hover{background:#1c2520;}
  .btn-sm{padding: 10px 16px; font-size: 13.5px;}
  .text-link{
    display:inline-flex; align-items:center; gap: 6px;
    font-size: 14px; font-weight: 500;
    color: var(--ink-2);
    padding: 4px 0;
    border-bottom: 1px solid var(--line-2);
    transition: color .15s ease, border-color .2s ease, gap .2s ease;
  }
  .text-link:hover{color: var(--green-dark); border-color: var(--green); gap: 10px;}
  .text-link .arr{width: 14px; height: 14px;}
  .btn .arr{ width:18px; height:18px; display:inline-block; }

  /* placeholder media */
  .ph{
    position:relative; overflow:hidden;
    background:
      repeating-linear-gradient(135deg, rgba(0,0,0,.04) 0 2px, transparent 2px 14px),
      linear-gradient(180deg, #d9e3da, #c2cfc4);
    border-radius: var(--radius);
    color: #2a322b;
  }
  .ph-dark{
    background:
      repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 2px, transparent 2px 14px),
      linear-gradient(180deg, #1a221d, #0c110f);
    color:#cfd9d2;
  }
  .ph .label{
    position:absolute; left:14px; bottom:12px;
    font-family:'JetBrains Mono', monospace;
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: rgba(255,255,255,.85);
    color: #1c241f;
    padding: 5px 9px;
    border-radius: 6px;
  }
  .ph-dark .label{background: rgba(0,0,0,.55); color:#e7f0e9;}

  /* logo */
  .logo{
    display:inline-flex; align-items:center; gap:8px;
    font-family:'Space Grotesk', sans-serif;
    font-weight:700; font-size: 19px; letter-spacing:-0.01em;
  }
  .logo-mark{
    width: 26px; height:26px; border-radius:8px;
    background: var(--green);
    display:grid; place-items:center;
    color: var(--green-ink);
  }

  /* NAV */
  .nav{
    position: sticky; top: 0; z-index: 30;
    backdrop-filter: blur(10px);
    background: rgba(255,255,255,.78);
    border-bottom: 1px solid rgba(230,235,231,.6);
  }
  .nav-inner{display:flex; align-items:center; justify-content:space-between; height:72px;}
  .nav ul{list-style:none; display:flex; gap:30px; margin:0; padding:0; align-items:center;}
  .nav li{display:flex; align-items:center;}
  .nav li a{font-size: 14.5px; color: var(--ink-2); position:relative; padding: 6px 0; display:inline-flex; align-items:center; gap:6px; line-height:1;}
  .nav li a.active{color: var(--ink); font-weight: 500;}
  .nav li a.active::after{
    content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px;
    background: var(--green); border-radius:2px;
  }
  .nav li a:hover{color: var(--ink);}

  /* Dropdown menu */
  .nav .main-nav > ul > li.has-dropdown{position: relative;}
  .nav .dd-trigger{display:inline-flex; align-items:center; gap:6px;}
  .nav .dd-trigger .caret{transition: transform .2s ease; opacity:.55;}
  .nav .has-dropdown:hover .dd-trigger .caret{transform: rotate(180deg); opacity: 1;}
  .nav .dropdown{
    position: absolute;
    top: calc(100% + 14px);
    right: 0;
    min-width: 240px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 8px;
    margin: 0;
    list-style: none;
    display: flex !important;
    flex-direction: column;
    gap: 2px;
    box-shadow: 0 12px 40px -12px rgba(15,30,20,.18), 0 4px 12px -6px rgba(15,30,20,.08);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity .18s ease, transform .18s ease, visibility .18s;
    z-index: 40;
  }
  .nav .dropdown::before{
    content:""; position:absolute; top:-14px; left:0; right:0; height:14px;
  }
  .nav .has-dropdown:hover .dropdown,
  .nav .has-dropdown:focus-within .dropdown{
    opacity: 1; visibility: visible; transform: translateY(0);
  }
  .nav .dropdown li{width: 100%;}
  .nav .dropdown li a{
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 14px;
    color: var(--ink-2);
    width: 100%;
  }
  .nav .dropdown li a::after{display:none !important;}
  .nav .dropdown li a:hover{
    background: var(--bg-tint);
    color: var(--ink);
  }
  .nav .dd-ic{
    width: 30px; height: 30px; border-radius: 9px;
    background: var(--chip); color: var(--green-dark);
    display: grid; place-items: center; flex-shrink: 0;
    transition: background .2s ease, color .2s ease, transform .2s ease;
  }
  .nav .dropdown li a:hover .dd-ic{
    background: var(--green); color: var(--green-ink); transform: scale(1.05);
  }
  .nav-cta{display:flex; align-items:center; gap:12px;}
  .lang{display:inline-flex; align-items:center; gap:8px; padding: 9px 14px; border-radius:999px; border:1px solid var(--line-2); font-size: 13.5px; color: var(--ink-2);}

  /* Hamburger button (hidden on desktop, shown via styles-medium.css on tablet+phone) */
  .nav-burger{
    display: none;
    width: 42px; height: 42px;
    background: transparent; border: none; padding: 0;
    flex-direction: column; justify-content: center; align-items: center; gap: 5px;
    cursor: pointer;
    position: relative;
    z-index: 101;
  }
  .nav-burger span{
    display: block;
    width: 22px; height: 2px;
    background: var(--ink); border-radius: 2px;
    transition: transform .25s ease, opacity .2s ease;
  }
  .nav-burger.is-open span:nth-child(1){transform: translateY(7px) rotate(45deg);}
  .nav-burger.is-open span:nth-child(2){opacity: 0;}
  .nav-burger.is-open span:nth-child(3){transform: translateY(-7px) rotate(-45deg);}
  body.nav-locked{overflow: hidden;}
  .lang .dot{width:18px; height:18px; border-radius:50%; background: linear-gradient(135deg,#7ED957,#1f6b1f);}

  /* HERO */
  .hero{padding: 22px 0 80px;}
  .hero-card{
    position: relative;
    border-radius: var(--radius-hero);
    overflow: hidden;
    min-height: 520px;
    color: #fff;
    isolation: isolate;
  }
  .hero-bg{
    position:absolute; inset:0; z-index:-2;
    background:
      radial-gradient(120% 90% at 70% 10%, rgba(126,217,87,.18), transparent 45%),
      linear-gradient(120deg, #0e1411 0%, #18241a 60%, #0e1411 100%);
  }
  .hero-bg::after{
    content:""; position:absolute; inset:0;
    background:
      repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 2px, transparent 2px 12px),
      radial-gradient(60% 100% at 95% 50%, rgba(126,217,87,.18), transparent 60%);
    mix-blend-mode: screen;
  }
  /* Faux EV "cable" illustration */
  .hero-art{
    position:absolute; inset:0; z-index:-1; pointer-events:none;
  }
  .hero-art svg{position:absolute; right:-40px; top:0; width: 70%; height:100%; opacity:.9;}
  .hero-content{
    position: relative;
    padding: 72px 64px 56px;
    display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: end;
  }
  .hero h1{max-width: 600px;}
  .hero h1 em{font-style:normal; color: var(--green); position:relative;}
  .hero-sub{
    color: rgba(255,255,255,.78);
    max-width: 480px;
    margin-top: 18px;
    font-size: 15.5px;
  }
  .hero-cta{display:flex; gap:12px; margin-top: 28px;}
  .hero-side{display:flex; flex-direction:column; gap:14px; align-items:flex-end;}
  .rating-card{
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(8px);
    border-radius: 14px;
    padding: 14px 18px;
    display:flex; align-items:center; gap:14px;
    color:#fff;
    min-width: 240px;
  }
  .stars{display:inline-flex; gap:2px; color: var(--green);}
  .rating-num{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 18px;}
  .rating-card small{color: rgba(255,255,255,.65); font-size:12px;}
  .promo-card{
    background: var(--green);
    color: var(--green-ink);
    border-radius: 18px;
    padding: 18px 20px;
    width: 240px;
    position: relative;
    box-shadow: 0 12px 30px -10px rgba(126,217,87,.45);
  }
  .promo-card .num{
    font-family:'Space Grotesk', sans-serif;
    font-size: 38px; font-weight: 700; line-height:1;
    letter-spacing:-0.03em;
  }
  .promo-card .lbl{font-size: 13px; margin-top: 4px; max-width: 150px;}
  .promo-bolt{
    position:absolute; top: -14px; right: -10px;
    width: 56px; height: 56px; border-radius: 50%;
    background: #0e1411; color: var(--green);
    display:grid; place-items:center;
    box-shadow: 0 8px 20px -6px rgba(0,0,0,.4);
  }

  /* feature strip */
  .strip{
    display:grid; grid-template-columns: repeat(4, 1fr);
    gap: 28px;
    padding: 0 8px;
    margin-top: -28px;
  }
  .strip .feat{
    display:flex; gap:14px; align-items:flex-start;
    padding: 18px 14px;
  }
  .feat .ic{
    width: 38px; height: 38px; border-radius: 10px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
    flex-shrink: 0;
  }
  .feat .t{font-weight: 500; font-size: 14.5px;}
  .feat .d{font-size: 12.5px; color: var(--muted); margin-top: 2px;}

  /* Section: leading */
  .leading{padding: 90px 0;}
  .leading-grid{display:grid; grid-template-columns: 1.05fr 1fr; gap: 60px; align-items: center;}
  .leading-media{position: relative; aspect-ratio: 5/4; border-radius: var(--radius);}
  .leading-stat{
    position:absolute; left: 20px; bottom: 20px;
    background: var(--green); color: var(--green-ink);
    border-radius: 12px; padding: 12px 16px;
    box-shadow: var(--shadow-md);
  }
  .leading-stat .n{font-family:'Space Grotesk', sans-serif; font-weight:700; font-size: 28px; line-height:1;}
  .leading-stat .l{font-size: 12px; opacity:.85;}
  .leading-text{display:flex; flex-direction:column; gap: 22px;}
  .checks{display:grid; gap: 10px; padding: 18px 0;}
  .checks li{display:flex; gap:10px; align-items:flex-start; font-size: 14.5px; color: var(--ink-2); list-style:none;}
  .checks .tick{
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center; flex-shrink:0; margin-top: 1px;
  }
  .leading-actions{display:flex; gap: 14px; align-items:center;}
  .pill-ph{
    width: 100px; aspect-ratio: 1; border-radius: 999px;
    background: linear-gradient(135deg, #2a3a2e, #0e1411);
    position: relative; overflow:hidden;
  }
  .pill-ph::after{
    content:""; position:absolute; inset: 12px;
    border-radius:999px; border: 2px solid rgba(126,217,87,.25);
  }

  /* Charging solutions block */
  .solutions{
    background: var(--bg-tint);
    border-radius: var(--radius-lg);
    padding: 60px 56px;
    margin: 20px 0 100px;
  }
  .sol-head{display:flex; align-items:flex-end; justify-content:space-between; gap: 24px; margin-bottom: 32px;}
  .sol-head h2{max-width: 480px;}
  .accordion{display:flex; flex-direction:column; gap: 12px;}
  .acc-item{
    background: #fff;
    border-radius: var(--radius);
    transition: background .45s ease, color .45s ease;
    border: 1px solid var(--line);
    transition: all .2s ease;
    overflow: hidden;
  }
  .acc-item.open{
    background: transparent;
    color: #e8f3e2;
    border-color: #1d2c22;
    box-shadow: inset 3px 0 0 var(--green), 0 14px 40px -22px rgba(10,20,15,.55);
    position: relative;
    isolation: isolate;
  }
  .acc-item.open::before{
    content:"";
    position:absolute; inset:0; z-index:-1;
    border-radius: inherit;
    background:
      radial-gradient(120% 100% at 0% 0%, rgba(126,217,87,.18), transparent 55%),
      linear-gradient(135deg, #14241a 0%, #0e1a13 55%, #0a130e 100%);
  }
  .acc-item.open .acc-head{color:#fff;}
  .acc-item.open .acc-head .idx{color: var(--green); opacity: .9;}
  .acc-head{
    display:flex; align-items:center; justify-content:space-between;
    padding: 22px 26px; cursor:pointer;
    font-family:'Space Grotesk', sans-serif;
    font-weight: 500;
    font-size: 17px;
  }
  .acc-head .idx{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; opacity:.6; margin-right: 14px; letter-spacing: .12em;
  }
  .acc-head .toggle{
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(0,0,0,.06); display:grid; place-items:center;
    transition: transform .2s ease;
  }
  .acc-item.open .acc-head .toggle{background: var(--green); color: var(--green-ink); transform: rotate(45deg);}
  .acc-body{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    padding: 0 26px;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(-6px);
    transition: max-height .5s cubic-bezier(.4,0,.2,1),
                opacity .35s ease,
                padding .5s cubic-bezier(.4,0,.2,1),
                transform .45s cubic-bezier(.4,0,.2,1);
  }
  .acc-body > *{
    opacity: 0;
    transform: translateY(8px);
    transition: opacity .4s ease .15s, transform .45s cubic-bezier(.4,0,.2,1) .15s;
  }
  .acc-body > *:nth-child(2){transition-delay: .22s;}
  .acc-item.open .acc-body{
    max-height: 640px;
    opacity: 1;
    padding: 0 26px 28px;
    transform: translateY(0);
  }
  .acc-item.open .acc-body > *{opacity: 1; transform: translateY(0);}
    .acc-body p{font-size: 14.5px; line-height: 1.6; max-width: 420px;}
  .acc-body .tags{display:flex; gap:8px; flex-wrap:wrap; margin-top: 14px;}
  .acc-body .tag{background: rgba(0,0,0,.1); border-radius: 999px; padding: 6px 12px; font-size: 12px;}
  .acc-item.open .acc-body .tag{background: rgba(126,217,87,.13); color: #c9eab4; border:1px solid rgba(126,217,87,.18);}
  .acc-item.open .acc-body .lnk{color: var(--green);}
  .acc-item.open .acc-body p{color: rgba(232,243,226,.78);}
  .acc-body .lnk{margin-top: 18px; font-weight: 500; font-size: 14px; display:inline-flex; gap:6px; align-items:center;}
  .acc-body .lnk:hover{text-decoration: underline;}
  .acc-media{
    border-radius: var(--radius-sm);
    aspect-ratio: 16/10;
    min-height: 200px;
  }

  /* Why drivers */
  .why{padding: 80px 0;}
  .why-head{text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px; margin-bottom: 50px;}
  .why-head .eyebrow{justify-content:center;}
  .why-grid{
    display:grid; grid-template-columns: 1fr auto 1fr;
    gap: 60px; align-items:center;
  }
  .why-col{display:flex; flex-direction:column; gap: 38px;}
  .why-col.right{text-align:left;}
  .why-card{display:flex; flex-direction:column; gap:6px;}
  .why-card .h{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 17px; display:flex; align-items:center; gap: 10px;}
  .why-card .h .num{
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
    font-family:'JetBrains Mono', monospace;
    font-size: 12px;
  }
  .why-card .d{font-size: 14px; color: var(--muted); max-width: 240px;}
  .why-center{width: 240px; aspect-ratio: 3/5; border-radius: var(--radius-lg); position:relative;}
  .why-center .glow{
    position:absolute; inset:-30px;
    background: radial-gradient(50% 60% at 50% 45%, rgba(126,217,87,.35), transparent 70%);
    z-index:-1;
  }
  .why-center .arc{
    position:absolute; inset: -40px;
    border: 2px dashed rgba(126,217,87,.45);
    border-radius: 50%;
    z-index:-1;
    animation: spin 40s linear infinite;
  }
  @keyframes spin { to { transform: rotate(360deg); } }

  /* Simple fast reliable */
  .reliable{
    position: relative;
    isolation: isolate;
    padding: 90px 0;
    color:#fff;
    overflow: hidden;
  }
  .reliable::before{
    content:""; position:absolute; inset:0; z-index:-1;
    background:
      radial-gradient(60% 80% at 80% 20%, rgba(126,217,87,.18), transparent 60%),
      linear-gradient(180deg, #0c110f, #131c16 60%, #0c110f);
  }
  .reliable::after{
    content:""; position:absolute; inset:0; z-index:-1;
    background: repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 2px, transparent 2px 14px);
  }
  .reliable .eyebrow{color: var(--green);}
  .reliable .eyebrow::before{background: var(--green);}
  .reliable-head{text-align:center; display:flex; flex-direction:column; gap:10px; align-items:center; margin-bottom: 50px;}
  .reliable-head h2{color:#fff;}
  .steps{
    display:grid; grid-template-columns: repeat(4, 1fr);
    gap: 18px; margin-bottom: 64px;
  }
  .step{
    background: #fff;
    color: var(--ink);
    border-radius: var(--radius);
    padding: 22px 22px 24px;
    min-height: 180px;
    display:flex; flex-direction:column; justify-content:flex-end;
    position: relative;
    transition: transform .2s ease;
  }
  .step:hover{transform: translateY(-4px);}
  .step .n{
    position:absolute; top: 18px; right: 18px;
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; color: var(--muted);
  }
  .step .h{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 17px; margin-bottom: 6px;}
  .step .d{font-size: 13px; color: var(--muted);}
  .step .ic{
    position:absolute; top: 18px; left: 18px;
    width: 36px; height: 36px; border-radius: 10px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
  }
  .stats{
    display:grid; grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    border-top: 1px solid rgba(255,255,255,.1);
    padding-top: 40px;
  }
  .stat .lbl{
    font-family:'JetBrains Mono', monospace;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: .14em;
    color: rgba(255,255,255,.55);
    margin-bottom: 12px;
  }
  .stat .v{
    font-family:'Space Grotesk', sans-serif;
    font-weight:700; font-size: clamp(38px, 4.5vw, 58px);
    letter-spacing: -0.03em; line-height: 1;
  }
  .stat .v small{font-size: 0.5em; opacity: .65; font-weight: 500; margin-left:6px;}

  /* Testimonial */
  .testi{padding: 90px 0;}
  .testi-grid{display:grid; grid-template-columns: 1fr 1.1fr; gap: 50px; align-items:center;}
  .testi-left{display:flex; flex-direction:column; gap: 28px;}
  .testi-left h2{max-width: 380px;}
  .testi-stars{display:flex; align-items:center; gap:10px;}
  .testi-stars small{color: var(--muted); font-size: 13px;}
  .testi-media{
    aspect-ratio: 4/3;
    border-radius: var(--radius);
    position: relative;
  }
  .pill-tag{
    position:absolute; left:18px; bottom:18px;
    background: var(--green); color: var(--green-ink);
    border-radius: 999px; padding: 8px 14px; font-size:13px; font-weight:500;
    display:inline-flex; align-items:center; gap:6px;
  }
  .quote-card{
    background: var(--green);
    color: var(--green-ink);
    border-radius: 22px;
    padding: 38px 38px 32px;
    position: relative;
    box-shadow: var(--shadow-md);
  }
  .quote-mark{
    font-family:'Space Grotesk', sans-serif;
    font-size: 70px; line-height: .6; font-weight: 700;
    color: var(--green-ink); opacity: .25;
    margin-bottom: 6px;
  }
  .quote-card blockquote{
    margin:0; font-size: 17px; line-height: 1.6; font-weight: 500;
    max-width: 480px;
  }
  .quote-foot{display:flex; justify-content:space-between; align-items:flex-end; margin-top: 28px;}
  .quote-who{display:flex; flex-direction:column;}
  .quote-who b{font-family:'Space Grotesk', sans-serif; font-weight:600;}
  .quote-who small{font-size: 12.5px; opacity:.7;}
  .q-nav{display:flex; gap: 8px;}
  .q-nav button{
    width: 38px; height: 38px; border-radius: 50%;
    background: var(--green-ink); color: var(--green);
    display:grid; place-items:center;
  }
  .q-nav button:hover{background:#082010;}

  /* Logo strip */
  .partners{padding: 80px 0 80px;}
  .partners-head{
    font-family:'JetBrains Mono', monospace;
    font-size: 12px; text-transform: uppercase; letter-spacing: .14em;
    color: var(--muted); text-align:center; margin-bottom: 28px;
  }
  .partners-row{
    display:flex; align-items:center; justify-content:space-between; gap:30px;
    flex-wrap: wrap;
    opacity: .65;
  }
  .partner{
    font-family:'Space Grotesk', sans-serif;
    font-weight:700; font-size: 22px; color: var(--ink-2);
    letter-spacing: -0.02em;
    display:inline-flex; align-items:center; gap:8px;
  }
  .partner .swatch{
    width: 22px; height: 22px; border-radius: 6px;
    background: var(--ink-2);
  }
  .partner.p2 .swatch{border-radius:50%; background:#7ed957;}
  .partner.p3 .swatch{transform: rotate(45deg);}
  .partner.p4 .swatch{border-radius:4px; background:#1f6b1f;}
  .partner.p5 .swatch{border-radius:50% 0 50% 50%;}

  /* Pricing */
  .pricing{
    background: var(--bg-tint);
    border-radius: var(--radius-lg);
    padding: 70px 56px 80px;
    margin-bottom: 100px;
  }
  .pricing-head{text-align:center; display:flex; flex-direction:column; gap:10px; align-items:center; margin-bottom: 50px;}
  .price-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; align-items:start;}
  .price-card{
    background: #fff;
    border-radius: 22px;
    padding: 30px 28px;
    border: 1px solid var(--line);
    display:flex; flex-direction:column; gap: 22px;
  }
  .price-card.featured{
    background: var(--bg-dark);
    color: #fff;
    border-color: var(--bg-dark);
    transform: translateY(-12px);
    box-shadow: var(--shadow-md);
    position: relative;
  }
  .price-card.featured .recommended{
    position:absolute; top: -14px; left: 50%; transform: translateX(-50%);
    background: var(--green); color: var(--green-ink);
    padding: 6px 12px; border-radius: 999px;
    font-size: 11px; font-weight: 500; letter-spacing:.06em;
    font-family:'JetBrains Mono', monospace; text-transform: uppercase;
  }
  .price-name{display:flex; justify-content:space-between; align-items:center;}
  .price-name .name{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 18px;}
  .price-name .ic{
    width: 32px; height: 32px; border-radius: 8px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
  }
  .price-card.featured .price-name .ic{background: rgba(126,217,87,.18); color: var(--green);}
  .price-card .desc{font-size: 13px; color: var(--muted); margin-top: 4px;}
  .price-card.featured .desc{color: rgba(255,255,255,.6);}
  .price-amt{display:flex; align-items:baseline; gap: 6px;}
  .price-amt .num{font-family:'Space Grotesk', sans-serif; font-weight:700; font-size: 50px; letter-spacing:-0.03em; line-height:1;}
  .price-amt .per{font-size: 13px; color: var(--muted);}
  .price-card.featured .per{color: rgba(255,255,255,.55);}
  .price-feats{list-style:none; padding:0; margin:0; display:grid; gap: 10px;}
  .price-feats li{display:flex; gap:10px; font-size: 14px; align-items:flex-start;}
  .price-feats .tick{
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center; flex-shrink:0; margin-top: 2px;
  }
  .price-card.featured .price-feats .tick{background: rgba(126,217,87,.18); color: var(--green);}
  .price-card .btn{justify-content:center; width:100%;}

  /* FAQ */
  .faq{padding: 70px 0 90px;}
  .faq-grid{display:grid; grid-template-columns: 1fr 1.4fr; gap: 60px; align-items:flex-start;}
  .faq-left h2{max-width: 320px;}
  .faq-img{
    margin-top: 26px;
    aspect-ratio: 5/4;
    border-radius: var(--radius);
  }
  .faq-list{display:flex; flex-direction:column; gap: 10px;}
  .faq-item{
    background: #f6faf6;
    border-radius: var(--radius-sm);
    border: 1px solid var(--line);
    transition: all .2s ease;
  }
  .faq-item.open{background: #fff; border-color: var(--line-2); box-shadow: var(--shadow-sm);}
  .faq-q{
    display:flex; align-items:center; justify-content:space-between;
    padding: 18px 22px; cursor:pointer;
    font-weight: 500; font-size: 15px;
  }
  .faq-q .toggle{
    width: 26px; height: 26px; border-radius: 50%;
    border: 1px solid var(--line-2);
    display:grid; place-items:center;
    color: var(--ink-2);
    transition: transform .2s ease;
  }
  .faq-item.open .toggle{transform: rotate(45deg); background: var(--green); color: var(--green-ink); border-color: var(--green);}
  .faq-a{
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    padding: 0 22px;
    color: var(--muted); font-size: 14.5px;
    line-height: 1.6;
    transition: max-height .35s cubic-bezier(.4,0,.2,1), opacity .25s ease, padding .3s ease;
  }
  .faq-item.open .faq-a{
    max-height: 360px;
    opacity: 1;
    padding: 0 22px 20px;
  }
  .faq-foot{
    display:flex; align-items:center; justify-content:space-between; gap: 30px;
    margin-top: 50px; padding-top: 28px; border-top: 1px solid var(--line);
  }
  .faq-foot .ask{display:flex; align-items:center; gap:18px;}
  .faq-foot .ask .ic{
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
  }
  .faq-foot .ask .t{font-weight:500; font-size: 15px;}
  .faq-foot .ask .d{font-size: 13px; color: var(--muted);}

  /* Find stations */
  .stations{
    position: relative;
    isolation: isolate;
    border-radius: var(--radius-lg);
    overflow: hidden;
    padding: 90px 56px;
    color:#fff;
    margin-bottom: 100px;
  }
  .stations::before{
    content:""; position:absolute; inset:0; z-index:-1;
    background:
      radial-gradient(60% 90% at 20% 50%, rgba(126,217,87,.22), transparent 65%),
      linear-gradient(135deg, #0c1a12 0%, #0a1410 50%, #0c1a12 100%);
  }
  .stations::after{
    content:""; position:absolute; inset:0; z-index:-1;
    background: repeating-linear-gradient(135deg, rgba(126,217,87,.04) 0 2px, transparent 2px 18px);
  }
  .stations-grid{display:grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items:center;}
  .stations h2{color:#fff; max-width: 380px;}
  .stations p.sub{color: rgba(255,255,255,.7); margin-top: 14px; max-width: 380px; font-size: 15px;}
  .store-btns{display:flex; gap:12px; margin-top: 28px;}
  .store-btn{
    display:inline-flex; align-items:center; gap:10px;
    padding: 12px 18px; border-radius: 14px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    color:#fff; font-size: 13px;
  }
  .store-btn:hover{background: rgba(255,255,255,.13);}
  .store-btn .t{display:flex; flex-direction:column; line-height: 1.15;}
  .store-btn .t small{font-size: 10px; opacity: .65;}
  .store-btn .t b{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size:15px;}
  .map-wrap{position: relative; aspect-ratio: 3/4; max-width: 380px; margin: 0 auto;}

  .poland-map{
    position: relative;
    width: 100%;
    max-width: 480px;
    aspect-ratio: 1 / 1;
    margin: 0 auto;
  }
  .poland-outline{
    position: absolute;
    inset: 0;
    background-color: var(--green);
    -webkit-mask-image: url('../assets/poland-mask.png');
    mask-image: url('../assets/poland-mask.png');
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    filter: drop-shadow(0 0 24px rgba(126,217,87,.18));
  }
  .city-marker{
    position: absolute;
    width: 14px;
    height: 14px;
    transform: translate(-50%, -50%);
    z-index: 2;
  }
  .city-marker .dot{
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: var(--green);
    border: 2px solid #0a130e;
    box-shadow: 0 0 0 4px rgba(126,217,87,.18), 0 0 0 10px rgba(126,217,87,.08);
  }
  .city-marker .dot::before{
    content:"";
    position: absolute;
    inset: -10px;
    border-radius: 50%;
    background: var(--green);
    opacity: .22;
    animation: cityPulse 2.4s ease-in-out infinite;
  }
  .city-marker:nth-of-type(3) .dot::before{animation-delay: .6s;}
  .city-marker:nth-of-type(4) .dot::before{animation-delay: 1.2s;}
  .city-marker:nth-of-type(5) .dot::before{animation-delay: 1.8s;}
  .city-marker.is-capital{width: 18px; height: 18px;}
  .city-marker.is-capital .dot{
    box-shadow: 0 0 0 6px rgba(126,217,87,.22), 0 0 0 14px rgba(126,217,87,.1);
  }
  .city-marker .label{
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: #e8f3e2;
    pointer-events: none;
  }
  .city-marker .label.label-left{
    left: auto;
    right: calc(100% + 10px);
  }
  .city-marker.is-capital .label{
    color: #ffffff;
    font-weight: 600;
    font-size: 14px;
  }
  @keyframes cityPulse{
    0%, 100%{transform: scale(1); opacity: .22;}
    50%{transform: scale(1.7); opacity: .05;}
  }
  .phone-frame{
    position:absolute; inset:0;
    border-radius: 38px;
    background: #0a0f0c;
    border: 8px solid #1a201c;
    overflow: hidden;
    box-shadow: 0 30px 80px -20px rgba(0,0,0,.6);
  }
  .phone-frame .notch{
    position:absolute; top: 8px; left:50%; transform: translateX(-50%);
    width: 70px; height: 18px; background:#0a0f0c; border-radius: 12px; z-index:2;
  }
  .map{
    position:absolute; inset:0;
    background:
      radial-gradient(40% 40% at 30% 35%, rgba(126,217,87,.18), transparent 60%),
      linear-gradient(180deg, #15211a, #0c130f);
  }
  .map svg{position:absolute; inset:0; width:100%; height:100%;}
  .map-pin{
    position:absolute; width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--green); color: var(--green-ink);
    display:grid; place-items:center;
    box-shadow: 0 0 0 6px rgba(126,217,87,.2), 0 0 0 14px rgba(126,217,87,.08);
  }
  .map-card{
    position: absolute; top: 40px; right: 14px;
    background: #fff; color: var(--ink);
    border-radius: 12px; padding: 10px 14px;
    box-shadow: 0 8px 24px -8px rgba(0,0,0,.3);
    font-size: 12px;
    width: 130px;
  }
  .map-card .t{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 13px;}
  .map-card .d{color: var(--muted); font-size: 11px;}

  /* News */
  .news{padding: 0 0 90px;}
  .news-head{text-align:center; display:flex; flex-direction:column; align-items:center; gap: 10px; margin-bottom: 40px;}
  .news-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 28px;}
  .news-card{display:flex; flex-direction:column; gap: 16px;}
  .news-img{aspect-ratio: 5/4; border-radius: var(--radius);}
  .news-meta{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
    color: var(--muted);
  }
  .news-title{font-family:'Space Grotesk', sans-serif; font-weight: 600; font-size: 19px; line-height: 1.3;}
  .news-card .more{font-weight:500; font-size: 13.5px; color: var(--green-dark); display:inline-flex; gap:6px;}

  /* Contact */
  .contact{padding: 0 0 100px;}
  .contact-card{
    background: var(--bg-tint);
    border-radius: var(--radius-lg);
    padding: 60px 56px;
    display:grid; grid-template-columns: 1fr 1.1fr; gap: 60px;
    align-items: center;
  }
  .contact-left h2{max-width: 360px;}
  .contact-left .map-mini{
    margin-top: 30px;
    aspect-ratio: 16/10;
    border-radius: 14px;
    position: relative;
  }
  .contact-form{
    background: var(--bg-dark);
    color: #fff;
    border-radius: 22px;
    padding: 34px;
    position: relative;
  }
  .form-head{display:flex; justify-content:space-between; align-items:center; margin-bottom: 26px;}
  .form-head .t{font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 19px;}
  .form-head small{color: rgba(255,255,255,.55); font-size: 12px; display:block;}
  .form-head .ic{
    width: 38px; height: 38px; border-radius: 10px;
    background: var(--green); color: var(--green-ink);
    display:grid; place-items:center;
  }
  .form-row{display:grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px;}
  .field{display:flex; flex-direction:column; gap:6px;}
  .field label{font-size: 11px; color: rgba(255,255,255,.55); letter-spacing:.05em; text-transform: uppercase;}
  .field input, .field textarea, .field select{
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    color:#fff;
    border-radius: 10px;
    padding: 12px 14px;
    font-family: inherit; font-size: 14px;
    transition: border .2s ease, background .2s ease;
  }
  .field input:focus, .field textarea:focus, .field select:focus{
    outline:none;
    border-color: var(--green);
    background: rgba(255,255,255,.1);
  }
  .field textarea{resize: vertical; min-height: 90px;}
  .form-row.full{grid-template-columns: 1fr;}
  .contact-form .btn{width:100%; justify-content:center; margin-top: 8px;}

  /* Footer */
  footer{
    background: var(--bg-dark);
    color: rgba(255,255,255,.7);
    padding: 60px 0 30px;
  }
  .foot-top{display:grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 40px; padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,.08);}
  .foot-brand{display:flex; flex-direction:column; gap: 16px;}
  .foot-brand .logo{color:#fff;}
  .foot-brand p{font-size: 13.5px; color: rgba(255,255,255,.6); max-width: 280px;}
  .foot-col h4{color:#fff; font-family:'Space Grotesk', sans-serif; font-weight:600; font-size: 14px; letter-spacing:.04em; text-transform: uppercase; margin-bottom: 16px;}
  .foot-col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px;}
  .foot-col a{font-size: 13.5px; color: rgba(255,255,255,.6);}
  .foot-col a:hover{color: var(--green);}
  .foot-contact{display:grid; grid-template-columns: repeat(3,1fr); gap: 18px; padding: 26px 0;}
  .foot-contact .item{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 14px;
    padding: 14px 18px;
    display:flex; gap: 12px; align-items:center;
  }
  .foot-contact .ic{
    width: 36px; height: 36px; border-radius: 10px;
    background: rgba(126,217,87,.18); color: var(--green);
    display:grid; place-items:center; flex-shrink:0;
  }
  .foot-contact small{font-size: 11px; color: rgba(255,255,255,.5); display:block;}
  .foot-contact b{font-family:'Space Grotesk', sans-serif; font-weight:500; color:#fff; font-size: 14px;}
  .foot-contact b a{color: inherit; text-decoration: none; border-bottom: 1px solid transparent; transition: border-color .15s ease, color .15s ease;}
  .foot-contact b a:hover{color: var(--green); border-color: var(--green);}
  .foot-bot{display:flex; justify-content:space-between; align-items:center; padding-top: 20px; font-size: 12.5px; color: rgba(255,255,255,.45);}
  .foot-bot .socials{display:flex; gap: 14px;}
  .foot-bot .socials a{
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(255,255,255,.06);
    display:grid; place-items:center;
    color: rgba(255,255,255,.7);
  }
  .foot-bot .socials a:hover{background: var(--green); color: var(--green-ink);}

  /* ─── POLITYKA PRYWATNOŚCI ─── */
  .policy-page{padding: 80px 0 100px;}
  .policy-grid{
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 80px;
    align-items: start;
  }
  .policy-toc{
    position: sticky;
    top: 100px;
    background: var(--bg-tint);
    border-radius: var(--radius);
    padding: 26px 26px 22px;
  }
  .policy-toc .toc-label{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.16em; text-transform: uppercase;
    color: var(--green-dark); margin-bottom: 18px;
  }
  .policy-toc ol{
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 8px;
    counter-reset: toc;
  }
  .policy-toc li{counter-increment: toc;}
  .policy-toc li a{
    display: flex; gap: 10px; align-items: baseline;
    font-size: 14px; color: var(--ink-2);
    text-decoration: none;
    line-height: 1.45;
    padding: 4px 0;
    transition: color .15s ease, padding-left .2s ease;
  }
  .policy-toc li a::before{
    content: counter(toc, decimal-leading-zero);
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; color: var(--muted);
    flex-shrink: 0; width: 22px;
  }
  .policy-toc li a:hover{color: var(--green-dark); padding-left: 4px;}
  .policy-toc .toc-update{
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid var(--line);
    font-size: 12.5px;
    color: var(--muted);
    line-height: 1.5;
  }
  .policy-content{
    max-width: 760px;
  }
  .policy-content section{
    padding: 32px 0;
    border-bottom: 1px solid var(--line);
    scroll-margin-top: 100px;
  }
  .policy-content section:last-child{border-bottom: none;}
  .policy-content section:first-child{padding-top: 0;}
  .policy-content h2{
    font-family:'Space Grotesk', sans-serif;
    font-size: clamp(22px, 2.2vw, 28px);
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -.01em;
    margin-bottom: 18px;
  }
  .policy-content p{
    font-size: 15.5px;
    line-height: 1.75;
    color: var(--ink-2);
    margin-bottom: 14px;
  }
  .policy-content p strong{color: var(--ink); font-weight: 600;}
  .policy-content ul{
    list-style: none; padding: 0;
    margin: 0 0 18px;
    display: flex; flex-direction: column; gap: 10px;
  }
  .policy-content li{
    position: relative;
    padding-left: 22px;
    font-size: 15px;
    line-height: 1.7;
    color: var(--ink-2);
  }
  .policy-content li::before{
    content: "";
    position: absolute;
    left: 0; top: 11px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--green);
  }
  .policy-content li strong{color: var(--ink); font-weight: 600;}
  .policy-content a{
    color: var(--green-dark);
    text-decoration: none;
    border-bottom: 1px solid var(--line-2);
    transition: border-color .15s ease;
  }
  .policy-content a:hover{border-color: var(--green-dark);}

  
  /* ─── SCROLL REVEAL ANIMATION ─── */
  [data-reveal]{
    opacity: 0;
    transform: translateY(22px);
    transition:
      opacity .75s cubic-bezier(.2,.65,.3,1) var(--reveal-delay, 0ms),
      transform .75s cubic-bezier(.2,.65,.3,1) var(--reveal-delay, 0ms);
    will-change: opacity, transform;
  }
  [data-reveal].is-visible{
    opacity: 1;
    transform: translateY(0);
  }
  @media (prefers-reduced-motion: reduce){
    [data-reveal]{opacity: 1; transform: none; transition: none;}
  }
  .foot-bot .foot-legal a{
    color: rgba(255,255,255,.6); text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,.15);
    padding-bottom: 2px; transition: color .2s, border-color .2s;
  }
  .foot-bot .foot-legal a:hover{color: var(--green); border-color: var(--green);}

  /* responsive (keep it tidy under 880) */
  /* ─── TWEAKS — accent palettes ─── */
:root[data-accent="cobalt"]{
  --green: #4A78F3;
  --green-2: #3862da;
  --green-dark: #1d3ea9;
  --green-ink: #0a1638;
  --chip: #e4ecff;
  --bg-tint: #eef2fc;
}
:root[data-accent="sunset"]{
  --green: #F47B3A;
  --green-2: #de6726;
  --green-dark: #a64412;
  --green-ink: #3a1407;
  --chip: #fee8d8;
  --bg-tint: #fcf2ea;
}
:root[data-accent="lavender"]{
  --green: #9F7AEA;
  --green-2: #8359d8;
  --green-dark: #5b3aa8;
  --green-ink: #1f1340;
  --chip: #ece1fb;
  --bg-tint: #f4eefc;
}
/* hue-rotate ONLY decorative background layers so children (buttons, text, etc.) keep accent colors */
:root[data-accent="cobalt"] .hero-bg,
:root[data-accent="cobalt"] .hero-art,
:root[data-accent="cobalt"] .reliable::before,
:root[data-accent="cobalt"] .reliable::after,
:root[data-accent="cobalt"] .stations::before,
:root[data-accent="cobalt"] .stations::after,
:root[data-accent="cobalt"] .acc-item.open::before{filter: hue-rotate(95deg);}
:root[data-accent="sunset"] .hero-bg,
:root[data-accent="sunset"] .hero-art,
:root[data-accent="sunset"] .reliable::before,
:root[data-accent="sunset"] .reliable::after,
:root[data-accent="sunset"] .stations::before,
:root[data-accent="sunset"] .stations::after,
:root[data-accent="sunset"] .acc-item.open::before{filter: hue-rotate(-90deg) saturate(1.15);}
:root[data-accent="lavender"] .hero-bg,
:root[data-accent="lavender"] .hero-art,
:root[data-accent="lavender"] .reliable::before,
:root[data-accent="lavender"] .reliable::after,
:root[data-accent="lavender"] .stations::before,
:root[data-accent="lavender"] .stations::after,
:root[data-accent="lavender"] .acc-item.open::before{filter: hue-rotate(150deg);}

/* ─── TWEAKS — typography pairings ─── */
:root[data-type="editorial"] h1,
:root[data-type="editorial"] h2,
:root[data-type="editorial"] h3,
:root[data-type="editorial"] h4,
:root[data-type="editorial"] .logo,
:root[data-type="editorial"] .price-amt .num,
:root[data-type="editorial"] .stat .v,
:root[data-type="editorial"] .leading-stat .n,
:root[data-type="editorial"] .promo-card .num,
:root[data-type="editorial"] .quote-mark,
:root[data-type="editorial"] .news-title,
:root[data-type="editorial"] .step .h,
:root[data-type="editorial"] .acc-head,
:root[data-type="editorial"] .price-name .name,
:root[data-type="editorial"] .quote-who b,
:root[data-type="editorial"] .form-head .t,
:root[data-type="editorial"] .why-card .h,
:root[data-type="editorial"] .partner,
:root[data-type="editorial"] .map-card .t,
:root[data-type="editorial"] .store-btn .t b,
:root[data-type="editorial"] .foot-contact b,
:root[data-type="editorial"] .foot-col h4{
  font-family: 'Fraunces', 'Times New Roman', serif !important;
  font-weight: 600;
  letter-spacing: -0.015em;
  font-style: italic;
}
:root[data-type="editorial"] h1 em,
:root[data-type="editorial"] h2 em{font-style: italic;}

:root[data-type="display"] h1,
:root[data-type="display"] h2,
:root[data-type="display"] h3,
:root[data-type="display"] h4,
:root[data-type="display"] .logo,
:root[data-type="display"] .price-amt .num,
:root[data-type="display"] .stat .v,
:root[data-type="display"] .leading-stat .n,
:root[data-type="display"] .promo-card .num,
:root[data-type="display"] .news-title,
:root[data-type="display"] .step .h,
:root[data-type="display"] .acc-head,
:root[data-type="display"] .price-name .name,
:root[data-type="display"] .quote-who b,
:root[data-type="display"] .form-head .t,
:root[data-type="display"] .why-card .h,
:root[data-type="display"] .partner,
:root[data-type="display"] .map-card .t,
:root[data-type="display"] .store-btn .t b,
:root[data-type="display"] .foot-contact b,
:root[data-type="display"] .foot-col h4{
  font-family: 'Bricolage Grotesque', 'Space Grotesk', sans-serif !important;
  font-weight: 700;
  letter-spacing: -0.035em;
}
:root[data-type="display"] h1,
:root[data-type="display"] h2{font-size: calc(1em * 1.08);}

/* ─── TWEAKS — shape language ─── */
:root[data-shape="sharp"]{
  --radius: 4px;
  --radius-sm: 4px;
  --radius-lg: 6px;
  --radius-hero: 6px;
}
:root[data-shape="sharp"] .btn,
:root[data-shape="sharp"] .lang,
:root[data-shape="sharp"] .nav .dropdown,
:root[data-shape="sharp"] .acc-item,
:root[data-shape="sharp"] .quote-card,
:root[data-shape="sharp"] .price-card,
:root[data-shape="sharp"] .step,
:root[data-shape="sharp"] .faq-item,
:root[data-shape="sharp"] .contact-form,
:root[data-shape="sharp"] .news-card .news-img,
:root[data-shape="sharp"] .field input,
:root[data-shape="sharp"] .field textarea,
:root[data-shape="sharp"] .field select,
:root[data-shape="sharp"] .promo-card,
:root[data-shape="sharp"] .rating-card,
:root[data-shape="sharp"] .pill-tag,
:root[data-shape="sharp"] .partner .swatch,
:root[data-shape="sharp"] .logo-mark,
:root[data-shape="sharp"] .feat .ic,
:root[data-shape="sharp"] .step .ic,
:root[data-shape="sharp"] .price-card .ic,
:root[data-shape="sharp"] .form-head .ic,
:root[data-shape="sharp"] .acc-body .tag,
:root[data-shape="sharp"] .checks .tick,
:root[data-shape="sharp"] .price-feats .tick,
:root[data-shape="sharp"] .nav .dd-ic,
:root[data-shape="sharp"] .nav .dropdown li a,
:root[data-shape="sharp"] .acc-head .toggle,
:root[data-shape="sharp"] .faq-q .toggle,
:root[data-shape="sharp"] .why-card .h .num,
:root[data-shape="sharp"] .q-nav button,
:root[data-shape="sharp"] .foot-bot .socials a,
:root[data-shape="sharp"] .foot-contact .ic{
  border-radius: 2px !important;
}
:root[data-shape="sharp"] .phone-frame{border-radius: 8px;}
:root[data-shape="sharp"] .why-center{border-radius: 6px;}

:root[data-shape="pillow"]{
  --radius: 26px;
  --radius-sm: 18px;
  --radius-lg: 40px;
  --radius-hero: 36px;
}
:root[data-shape="pillow"] .acc-item,
:root[data-shape="pillow"] .quote-card,
:root[data-shape="pillow"] .price-card,
:root[data-shape="pillow"] .step,
:root[data-shape="pillow"] .faq-item,
:root[data-shape="pillow"] .contact-form,
:root[data-shape="pillow"] .news-card .news-img{
  border-radius: 26px;
}
:root[data-shape="pillow"] .logo-mark,
:root[data-shape="pillow"] .feat .ic,
:root[data-shape="pillow"] .step .ic,
:root[data-shape="pillow"] .price-card .ic,
:root[data-shape="pillow"] .form-head .ic,
:root[data-shape="pillow"] .nav .dd-ic,
:root[data-shape="pillow"] .foot-contact .ic{border-radius: 16px;}

/* ─── Tweaks panel UI ─── */
.tweaks-panel{
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  width: 280px;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(20px);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 20px 60px -20px rgba(15,30,20,.25), 0 4px 16px -8px rgba(15,30,20,.12);
  padding: 16px;
  font-family: 'Inter', sans-serif;
  color: var(--ink);
  /* Counteract any global filter for tweaks panel itself: never */
}
.tweaks-panel[hidden]{display:none;}
.tp-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom: 14px;
}
.tp-title{
  font-family:'Space Grotesk', sans-serif;
  font-weight:600; font-size:15px;
  display:flex; align-items:center; gap:8px;
}
.tp-title::before{
  content:""; width:8px; height:8px; border-radius:2px; background: var(--green);
}
.tp-close{
  width: 26px; height: 26px;
  border-radius: 8px;
  background: var(--bg-tint);
  color: var(--ink-2);
  display:grid; place-items:center;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  border: 0;
}
.tp-close:hover{background: #e6ebe7;}
.tp-section{margin-bottom: 14px;}
.tp-section:last-child{margin-bottom: 0;}
.tp-label{
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted);
  margin-bottom: 8px;
}
.tp-swatches{display:flex; gap: 8px;}
.tp-swatch{
  flex:1; height: 38px;
  border-radius: 10px;
  border: 2px solid transparent;
  cursor: pointer;
  position: relative;
  transition: transform .15s ease;
}
.tp-swatch:hover{transform: scale(1.05);}
.tp-swatch.active{border-color: var(--ink); box-shadow: 0 0 0 2px #fff inset;}
.tp-segment{
  display:flex; gap:4px;
  background: var(--bg-tint);
  border-radius: 10px;
  padding: 4px;
}
.tp-segment button{
  flex: 1;
  padding: 8px 6px;
  border-radius: 7px;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-size: 12.5px;
  color: var(--ink-2);
  font-weight: 500;
  transition: background .15s ease, color .15s ease;
}
.tp-segment button:hover{color: var(--ink);}
.tp-segment button.active{
  background: #fff;
  color: var(--ink);
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
@media (max-width: 600px){
  .tweaks-panel{left: 12px; right: 12px; bottom: 12px; width: auto;}
}


/* ═══════════════════════════════════════════════════════════════════════════
   PAGE-SPECIFIC STYLES (moved from <style> in HTML on 2026-05-21)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Kontakt page ─── */
/* ─── Kontakt page specific ─── */
  .hero--compact .hero-card{min-height: 380px;}
  .hero--compact .hero-content{
    grid-template-columns: 1fr;
    padding: 80px 64px 70px;
    text-align: left;
    align-items: center;
  }
  .hero--compact h1{
    max-width: none;
    margin: 0;
  }
  .hero--compact .hero-eyebrow{
    display:inline-flex; align-items:center; gap:8px;
    font-family:'JetBrains Mono', monospace;
    font-size: 12px; letter-spacing:.18em; text-transform: uppercase;
    color: var(--green); margin-bottom: 18px;
  }
  .hero--compact .hero-eyebrow::before{
    content:""; width:24px; height:1px; background: var(--green);
  }
  .hero--compact .hero-sub{margin-top: 18px; max-width: 540px;}

  .contact-page{padding: 56px 0 110px;}
  .contact-grid{
    display:grid;
    grid-template-columns: 1fr 1.25fr;
    gap: 24px;
    align-items: stretch;
  }
  .info-box{
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    padding: 44px 40px;
    box-shadow: var(--shadow-sm);
    display:flex;
    flex-direction:column;
    gap: 28px;
  }
  .info-box h2{
    font-size: 28px; line-height: 1.15; margin: 0;
  }
  .info-box .info-intro{
    color: var(--muted);
    font-size: 15px;
    max-width: 380px;
    margin-top: 4px;
  }
  .info-list{
    display:flex; flex-direction:column; gap: 18px;
    list-style: none; margin: 0; padding: 0;
  }
  .info-list li{
    display:flex; gap: 16px; align-items:flex-start;
    padding: 18px 0;
    border-top: 1px solid var(--line);
  }
  .info-list li:first-child{border-top: none; padding-top: 4px;}
  .info-list .ic{
    width: 42px; height: 42px; border-radius: 12px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center; flex-shrink: 0;
  }
  .info-list .label{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.14em; text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 4px;
  }
  .info-list .value{
    font-family:'Space Grotesk', sans-serif;
    font-size: 17px; font-weight: 500;
    color: var(--ink);
    text-decoration: none;
    display:block;
  }
  .info-list a.value:hover{color: var(--green-dark);}
  .info-list .hint{font-size: 13px; color: var(--muted); margin-top: 4px;}
  .info-cta{
    margin-top: auto;
    padding-top: 4px;
  }

  .map-box{
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    overflow: hidden;
    position: relative;
    min-height: 540px;
    box-shadow: var(--shadow-sm);
  }
  .map-box iframe{
    width: 100%; height: 100%;
    min-height: 540px;
    border: 0; display: block;
    filter: grayscale(.15) contrast(1.02);
  }
  .map-overlay{
    position:absolute; left: 20px; top: 20px;
    background: #0e1411; color:#fff;
    border-radius: 16px;
    padding: 18px 22px;
    display:flex; gap: 14px; align-items:center;
    box-shadow: 0 14px 40px -16px rgba(0,0,0,.4);
    max-width: calc(100% - 40px);
    min-width: 280px;
    z-index: 1;
  }
  .map-overlay .dot{
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--green); color: var(--green-ink);
    display:grid; place-items:center;
    flex-shrink: 0;
  }
  .map-overlay .t{font-family:'Space Grotesk', sans-serif; font-size: 15px; font-weight: 600;}
  .map-overlay .d{font-size: 13px; color: rgba(255,255,255,.72); margin-top: 3px;}

  
/* ─── O nas page ─── */
/* ─── Hero compact (shared shape with Kontakt) ─── */
  .hero--compact .hero-card{min-height: 380px;}
  .hero--compact .hero-content{
    grid-template-columns: 1fr;
    padding: 80px 64px 70px;
    text-align: left;
    align-items: center;
  }
  .hero--compact h1{max-width: none; margin: 0;}
  .hero--compact .hero-eyebrow{
    display:inline-flex; align-items:center; gap:8px;
    font-family:'JetBrains Mono', monospace;
    font-size: 12px; letter-spacing:.18em; text-transform: uppercase;
    color: var(--green); margin-bottom: 18px;
  }
  .hero--compact .hero-eyebrow::before{content:""; width:24px; height:1px; background: var(--green);}
  .hero--compact .hero-sub{margin-top: 18px; max-width: 580px;}

  /* ─── O nas — sections ─── */
  .about-intro{padding: 90px 0 40px;}
  .about-intro h2{max-width: 720px; font-size: clamp(34px, 4vw, 52px); line-height: 1.05;}
  .about-intro .lead{
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 500;
    font-size: clamp(20px, 2.2vw, 26px);
    line-height: 1.4;
    color: var(--ink);
    max-width: 720px;
    margin-top: 26px;
  }
  .about-intro .lead em{font-style: italic; color: var(--green-dark);}
  .about-meta{
    display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
    margin-top: 56px;
    border-top: 1px solid var(--line);
    padding-top: 36px;
  }
  .about-meta .item .num{
    font-family:'Space Grotesk', sans-serif;
    font-size: 42px; font-weight: 600; line-height: 1; letter-spacing: -.02em;
  }
  .about-meta .item .lbl{font-size: 13.5px; color: var(--muted); margin-top: 8px;}

  /* History timeline */
  .history{padding: 80px 0;}
  .history-head{display:grid; grid-template-columns: 1fr 1.4fr; gap: 60px; margin-bottom: 60px; align-items: end;}
  .history-head .text p{color: var(--muted); font-size: 15px; max-width: 520px;}
  .timeline{
    display:grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    position: relative;
  }
  .timeline::before{
    content:""; position:absolute; left: 0; right: 0; top: 26px;
    height: 1px; background: var(--line-2);
  }
  .timeline .step-t{
    position:relative;
    padding: 0 24px 0 0;
  }
  .timeline .dot{
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--green);
    border: 3px solid var(--bg-tint, #fff);
    box-shadow: 0 0 0 2px var(--green);
    position: relative; z-index: 1;
    margin-bottom: 22px;
    margin-top: 18px;
  }
  .timeline .year{
    font-family:'JetBrains Mono', monospace;
    font-size: 12px; letter-spacing:.14em;
    color: var(--green-dark);
    margin-bottom: 10px;
  }
  .timeline .ti{
    font-family:'Space Grotesk', sans-serif;
    font-size: 18px; font-weight: 600; line-height: 1.2;
    margin-bottom: 8px;
  }
  .timeline .td{font-size: 14px; color: var(--muted); line-height: 1.55; max-width: 220px;}

  /* Values */
  .values{
    background: var(--bg-tint);
    border-radius: var(--radius-lg);
    padding: 70px 56px;
    margin: 20px 0 80px;
  }
  .values-head{display:grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 44px;}
  .values-head h2{max-width: 460px;}
  .values-head p{color: var(--muted); font-size: 15px; max-width: 460px;}
  .values-grid{
    display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  }
  .value-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 26px 26px 28px;
    display:flex; flex-direction:column; gap: 16px;
    min-height: 200px;
    transition: transform .25s ease, box-shadow .25s ease;
  }
  .value-card:hover{transform: translateY(-2px); box-shadow: var(--shadow-sm);}
  .value-card .ic{
    width: 44px; height: 44px; border-radius: 12px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
  }
  .value-card .h{font-family:'Space Grotesk', sans-serif; font-size: 17px; font-weight: 600; line-height: 1.25;}
  .value-card .d{font-size: 14px; color: var(--muted); line-height: 1.55;}

  /* Team */
  .team{padding: 60px 0 80px;}
  .team-head{display:grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 44px;}
  .team-head p{color: var(--muted); font-size: 15px; max-width: 460px;}
  .team-grid{display:grid; grid-template-columns: repeat(4, 1fr); gap: 18px;}
  .team-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    display:flex; flex-direction:column;
  }
  .team-card .photo{
    aspect-ratio: 4/5;
    position: relative;
  }
  .team-card .photo .label{
    position:absolute; left:14px; bottom:14px;
    font-family:'JetBrains Mono', monospace;
    font-size: 10px; letter-spacing:.12em;
    color: rgba(0,0,0,.35);
  }
  .team-card .info{padding: 18px 20px 22px;}
  .team-card .name{font-family:'Space Grotesk', sans-serif; font-size: 17px; font-weight: 600;}
  .team-card .role{font-size: 13px; color: var(--muted); margin-top: 3px;}
  .team-card .bio{font-size: 13.5px; color: var(--ink-2); margin-top: 12px; line-height: 1.55;}

  /* Trust */
  .trust{padding: 60px 0 100px;}
  .trust-head{text-align:center; max-width: 640px; margin: 0 auto 50px;}
  .trust-head .eyebrow{justify-content:center;}
  .trust-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;}
  .trust-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 32px 28px;
    position: relative;
    overflow: hidden;
  }
  .trust-card .n{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.16em;
    color: var(--green-dark);
    margin-bottom: 22px;
  }
  .trust-card .h{font-family:'Space Grotesk', sans-serif; font-size: 19px; font-weight: 600; line-height: 1.25; margin-bottom: 12px;}
  .trust-card .d{font-size: 14px; color: var(--muted); line-height: 1.6;}
  .trust-card.is-dark{
    background: linear-gradient(135deg, #14241a 0%, #0e1a13 100%);
    color: #e8f3e2;
    border-color: #1d2c22;
  }
  .trust-card.is-dark .n{color: var(--green);}
  .trust-card.is-dark .d{color: rgba(232,243,226,.7);}

  .trust-cta{
    margin-top: 36px;
    display:flex; justify-content:center; gap: 14px; flex-wrap: wrap;
  }

  
/* ─── Uslugi (services overview) page ─── */
/* ─── Hero compact (shared shape) ─── */
  .hero--compact .hero-card{min-height: 380px;}
  .hero--compact .hero-content{
    grid-template-columns: 1fr;
    padding: 80px 64px 70px;
    text-align: left;
    align-items: center;
  }
  .hero--compact h1{max-width: none; margin: 0;}
  .hero--compact .hero-eyebrow{
    display:inline-flex; align-items:center; gap:8px;
    font-family:'JetBrains Mono', monospace;
    font-size: 12px; letter-spacing:.18em; text-transform: uppercase;
    color: var(--green); margin-bottom: 18px;
  }
  .hero--compact .hero-eyebrow::before{content:""; width:24px; height:1px; background: var(--green);}
  .hero--compact .hero-sub{margin-top: 18px; max-width: 620px;}

  /* ─── Service cards (replaces accordion on services page) ─── */
  .svc-section{
    background: var(--bg-tint);
    border-radius: var(--radius-lg);
    padding: 60px 56px 70px;
    margin: 20px 0 60px;
  }
  .svc-grid{
    display:grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 18px;
  }
  .svc-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 30px 30px 28px;
    display:flex; flex-direction:column; gap: 16px;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    position: relative;
    overflow: hidden;
    scroll-margin-top: 100px;
  }
  .svc-card:hover{
    transform: translateY(-3px);
    box-shadow: 0 18px 40px -22px rgba(15,30,20,.18);
    border-color: var(--line-2);
  }
  .svc-card .idx{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.18em;
    color: var(--muted);
  }
  .svc-card .ic{
    width: 52px; height: 52px; border-radius: 14px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center;
  }
  .svc-card .name{
    font-family:'Space Grotesk', sans-serif;
    font-size: 22px; font-weight: 600; line-height: 1.15;
    letter-spacing: -.01em;
  }
  .svc-card .desc{
    font-size: 14.5px; line-height: 1.65;
    color: var(--ink-2);
    max-width: 380px;
  }
  .svc-card .tags{display:flex; gap:6px; flex-wrap:wrap; margin-top: 2px;}
  .svc-card .tag{
    background: var(--bg-tint);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 5px 12px; font-size: 12px;
    color: var(--ink-2);
  }
  .svc-card .lnk{
    margin-top: auto;
    padding-top: 14px;
    display:inline-flex; align-items:center; gap: 6px;
    font-size: 14px; font-weight: 500;
    color: var(--green-dark);
    transition: gap .2s ease;
  }
  .svc-card .lnk:hover{gap: 10px;}
  .svc-card .lnk svg{width:14px; height:14px;}

  /* Featured (SEO) — wide, dark */
  .svc-card.is-featured{
    grid-column: span 6;
    background: linear-gradient(135deg, #14241a 0%, #0e1a13 60%, #0a130e 100%);
    color: #e8f3e2;
    border-color: #1d2c22;
    flex-direction: row;
    align-items: stretch;
    gap: 36px;
    padding: 36px 38px;
  }
  .svc-card.is-featured::before{
    content:"";
    position:absolute; right:-120px; top:-120px;
    width: 360px; height: 360px; border-radius: 50%;
    background: radial-gradient(circle, rgba(126,217,87,.2), transparent 70%);
    pointer-events: none;
  }
  .svc-card.is-featured .col-left{flex: 1.1; display:flex; flex-direction:column; gap: 16px; position: relative; z-index: 1;}
  .svc-card.is-featured .col-right{flex: 1; display:flex; flex-direction:column; gap: 16px; position: relative; z-index: 1; border-left: 1px solid rgba(255,255,255,.08); padding-left: 36px;}
  .svc-card.is-featured .idx{color: var(--green);}
  .svc-card.is-featured .ic{background: rgba(126,217,87,.15); color: var(--green);}
  .svc-card.is-featured .name{font-size: 32px; color:#fff;}
  .svc-card.is-featured .desc{color: rgba(232,243,226,.78); font-size: 15.5px; max-width: 460px;}
  .svc-card.is-featured .tag{background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.1); color: rgba(232,243,226,.8);}
  .svc-card.is-featured .lnk{color: var(--green);}
  .svc-card.is-featured .mini-list{
    list-style: none; padding:0; margin: 0;
    display:flex; flex-direction:column; gap: 10px;
  }
  .svc-card.is-featured .mini-list li{
    display:flex; gap: 12px; align-items:flex-start;
    font-size: 13.5px; color: rgba(232,243,226,.85); line-height: 1.55;
  }
  .svc-card.is-featured .mini-list .tick{
    width: 20px; height: 20px; border-radius: 50%;
    background: rgba(126,217,87,.15); color: var(--green);
    display:grid; place-items:center; flex-shrink: 0; margin-top: 1px;
  }
  .svc-card.is-featured .stat-row{
    display:flex; gap: 36px;
    margin-top: 4px;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .svc-card.is-featured .stat-row .v{
    font-family:'Space Grotesk', sans-serif;
    font-size: 26px; font-weight: 600; color: var(--green);
    letter-spacing: -.02em; line-height: 1;
  }
  .svc-card.is-featured .stat-row .l{font-size: 12px; color: rgba(232,243,226,.6); margin-top: 6px;}

  /* Regular cards span */
  .svc-card.span-3{grid-column: span 3;}
  .svc-card.span-2{grid-column: span 2;}

    .seo-block{padding: 80px 0 40px;}
  .seo-grid{
    display:grid; grid-template-columns: 1fr 1.6fr; gap: 80px;
    align-items: start;
  }
  .seo-grid .lead{
    font-family:'Space Grotesk', sans-serif;
    font-weight: 500;
    font-size: clamp(22px, 2.3vw, 28px);
    line-height: 1.35;
    letter-spacing: -.01em;
    color: var(--ink);
  }
  .seo-grid .lead em{font-style: normal; color: var(--green-dark);}
  .seo-grid .body p{
    color: var(--ink-2);
    font-size: 15.5px;
    line-height: 1.75;
    margin-bottom: 18px;
  }
  .seo-grid .body p:last-child{margin-bottom: 0;}
  .seo-grid .body strong{color: var(--ink); font-weight: 600;}

  /* Case studies */
  .cases{padding: 60px 0 80px;}
  .cases-head{display:grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 44px;}
  .cases-head p{color: var(--muted); font-size: 15px; max-width: 460px;}
  .case-list{display:flex; flex-direction:column; gap: 18px;}
  .case-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    display:grid;
    grid-template-columns: 0.85fr 1.15fr;
    min-height: 360px;
  }
  .case-card .visual{
    background: linear-gradient(135deg, #14241a 0%, #0e1a13 100%);
    color: #e8f3e2;
    padding: 38px 36px;
    display:flex; flex-direction:column; justify-content:space-between;
    position: relative;
    overflow: hidden;
  }
  .case-card .visual::after{
    content:"";
    position:absolute; right:-80px; bottom:-80px;
    width: 240px; height: 240px; border-radius: 50%;
    background: radial-gradient(circle, rgba(126,217,87,.2), transparent 70%);
  }
  .case-card .visual .tag{
    display:inline-flex; align-items:center; gap:6px;
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.14em; text-transform: uppercase;
    color: var(--green);
    padding: 6px 10px; border-radius: 999px;
    background: rgba(126,217,87,.1);
    border: 1px solid rgba(126,217,87,.2);
    align-self: flex-start;
  }
  .case-card .visual .who{
    margin-top: auto;
    position: relative; z-index: 1;
  }
  .case-card .visual .who h3{
    font-family:'Space Grotesk', sans-serif;
    font-size: 24px; font-weight: 600; line-height: 1.2;
    margin: 0 0 6px;
    color:#fff;
  }
  .case-card .visual .who .who-d{font-size: 13.5px; color: rgba(232,243,226,.6);}
  .case-card .visual .big-stat{
    margin-top: 22px;
    font-family:'Space Grotesk', sans-serif;
    font-size: 56px; font-weight: 700; letter-spacing:-.02em; line-height: 1;
    color: var(--green);
    position: relative; z-index: 1;
  }
  .case-card .visual .big-stat small{font-size:.45em; font-weight: 500; color: rgba(232,243,226,.6);}
  .case-card .content{padding: 38px 40px; display:flex; flex-direction:column; gap: 18px;}
  .case-card .step{
    display:grid; grid-template-columns: auto 1fr; gap: 14px;
    align-items: start;
  }
  .case-card .step .lbl{
    display:inline-flex; align-items:center; gap:6px;
    font-family:'JetBrains Mono', monospace;
    font-size: 10.5px; letter-spacing:.16em; text-transform: uppercase;
    color: var(--muted);
    padding-top: 4px;
    min-width: 86px;
  }
  .case-card .step .lbl::before{
    content:""; width: 6px; height: 6px; border-radius: 50%;
    background: var(--green);
    flex-shrink: 0;
  }
  .case-card .step .lbl.is-eff::before{background: var(--green); box-shadow: 0 0 0 3px rgba(126,217,87,.2);}
  .case-card .step .txt{
    font-size: 14.5px; line-height: 1.6; color: var(--ink-2);
  }
  .case-card .step .txt strong{color: var(--ink);}

  .case-card.is-reverse{grid-template-columns: 1.15fr 0.85fr;}
  .case-card.is-reverse .visual{order: 2;}

  /* CTA band */
  .cta-band{
    background: var(--bg-dark);
    color:#fff;
    border-radius: var(--radius-lg);
    padding: 60px 56px;
    display:grid; grid-template-columns: 1.4fr 1fr; gap: 50px; align-items: center;
    position: relative;
    overflow: hidden;
    margin: 40px 0 100px;
  }
  .cta-band::before{
    content:"";
    position:absolute; right:-100px; top:50%; transform: translateY(-50%);
    width: 400px; height: 400px; border-radius: 50%;
    background: radial-gradient(circle, rgba(126,217,87,.18), transparent 65%);
  }
  .cta-band h2{
    color:#fff;
    font-size: clamp(28px, 3.6vw, 44px); line-height: 1.1;
    margin: 0;
  }
  .cta-band .eyebrow{color: var(--green);}
  .cta-band .eyebrow::before{background: var(--green);}
  .cta-band p{color: rgba(255,255,255,.7); margin-top: 16px; max-width: 480px; font-size: 15px;}
  .cta-band .actions{display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end; position: relative; z-index: 1;}
  .cta-band .btn-ghost{background: rgba(255,255,255,.06); color:#fff; border-color: rgba(255,255,255,.16);}
  .cta-band .btn-ghost:hover{background: rgba(255,255,255,.12);}

  
/* ─── Service detail pages (uslugi-seo, uslugi-google-ads, uslugi-consulting, uslugi-programowanie, uslugi-video) ─── */
/* ─── Hero compact (shared shape) ─── */
  .hero--compact .hero-card{min-height: 380px;}
  .hero--compact .hero-content{
    grid-template-columns: 1.4fr 1fr;
    padding: 80px 64px 70px;
    align-items: end;
  }
  .hero--compact h1{max-width: none; margin: 0;}
  .hero--compact .hero-eyebrow{
    display:inline-flex; align-items:center; gap:8px;
    font-family:'JetBrains Mono', monospace;
    font-size: 12px; letter-spacing:.18em; text-transform: uppercase;
    color: var(--green); margin-bottom: 18px;
  }
  .hero--compact .hero-eyebrow::before{content:""; width:24px; height:1px; background: var(--green);}
  .hero--compact .hero-sub{margin-top: 18px; max-width: 580px;}

  .breadcrumb{
    color: rgba(255,255,255,.5); font-size: 13px;
    display:flex; gap: 10px; align-items:center;
    margin-bottom: 18px;
  }
  .breadcrumb a{color: rgba(255,255,255,.7); text-decoration: none;}
  .breadcrumb a:hover{color: var(--green);}
  .breadcrumb .sep{opacity:.4;}

  /* Lead with stats card */
  .seo-intro{padding: 80px 0 40px;}
  .seo-intro-grid{
    display:grid; grid-template-columns: 1.5fr 1fr; gap: 60px;
    align-items: start;
  }
  .seo-intro p{
    color: var(--ink-2);
    font-size: 16px;
    line-height: 1.75;
    margin-bottom: 16px;
  }
  .seo-intro p:last-child{margin-bottom: 0;}
  .seo-intro p strong{color: var(--ink); font-weight: 600;}
  .seo-intro .lead{
    font-family:'Space Grotesk', sans-serif;
    font-weight: 500;
    font-size: clamp(22px, 2.2vw, 28px);
    line-height: 1.35;
    letter-spacing: -.01em;
    color: var(--ink);
    margin-bottom: 26px;
  }
  .seo-intro .lead em{font-style: normal; color: var(--green-dark);}

  .stat-card{
    background: var(--bg-dark);
    color:#fff;
    border-radius: var(--radius);
    padding: 36px 32px;
    position: sticky;
    top: 100px;
    overflow: hidden;
  }
  .stat-card .label{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.18em; text-transform: uppercase;
    color: var(--green); margin-bottom: 24px;
    display:inline-flex; align-items:center; gap:8px;
  }
  .stat-card .label::before{content:""; width: 20px; height:1px; background: var(--green);}
  .stat-card .stat-row{
    display:flex; flex-direction:column; gap: 22px;
  }
  .stat-card .stat{
    padding-bottom: 22px;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .stat-card .stat:last-child{border-bottom: none; padding-bottom: 0;}
  .stat-card .v{
    font-family:'Space Grotesk', sans-serif;
    font-size: 44px; font-weight: 600; letter-spacing: -.02em; line-height: 1;
    color: var(--green);
  }
  .stat-card .v small{font-size:.42em; color:rgba(255,255,255,.6); font-weight:500;}
  .stat-card .l{font-size: 13.5px; color: rgba(255,255,255,.65); margin-top: 8px; line-height: 1.5;}

  /* What we do — scope grid */
  .scope-section{padding: 60px 0;}
  .scope-section h2{max-width: 540px;}
  .scope-section .head-p{color: var(--muted); font-size: 15px; max-width: 520px; margin-top: 14px;}
  .scope-grid{
    display:grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
    margin-top: 44px;
  }
  .scope-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 28px 30px;
    display:flex; gap: 22px;
    align-items: flex-start;
    transition: transform .25s ease, box-shadow .25s ease;
  }
  .scope-card:hover{transform: translateY(-2px); box-shadow: 0 14px 30px -18px rgba(15,30,20,.15);}
  .scope-card .ic{
    width: 48px; height: 48px; border-radius: 12px;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center; flex-shrink:0;
  }
  .scope-card .h{
    font-family:'Space Grotesk', sans-serif;
    font-size: 18px; font-weight: 600; line-height: 1.25;
    margin-bottom: 8px;
  }
  .scope-card .d{font-size: 14px; color: var(--muted); line-height: 1.6;}

  /* Process timeline */
  .process-section{
    background: var(--bg-tint);
    border-radius: var(--radius-lg);
    padding: 70px 56px;
    margin: 60px 0;
  }
  .process-head{display:grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 50px;}
  .process-head h2{max-width: 480px;}
  .process-head p{color: var(--muted); font-size: 15px; max-width: 460px;}
  .process-grid{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    position: relative;
  }
  .process-grid::before{
    content:""; position:absolute; left: 0; right: 60px; top: 22px;
    height: 1px; background: var(--line-2);
  }
  .proc-step{position:relative; padding: 0 28px 0 0;}
  .proc-step .dot{
    width: 14px; height: 14px; border-radius: 50%;
    background: var(--green);
    box-shadow: 0 0 0 6px var(--bg-tint), 0 0 0 7px var(--green);
    margin-bottom: 24px;
    margin-top: 16px;
    position: relative; z-index: 1;
  }
  .proc-step .num{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.14em;
    color: var(--green-dark); margin-bottom: 10px;
  }
  .proc-step .h{
    font-family:'Space Grotesk', sans-serif;
    font-size: 18px; font-weight: 600; line-height: 1.2;
    margin-bottom: 8px;
  }
  .proc-step .d{font-size: 14px; color: var(--muted); line-height: 1.6; max-width: 220px;}
  .proc-step .when{
    font-size: 12px;
    color: var(--green-dark);
    margin-top: 12px;
    font-family:'JetBrains Mono', monospace;
    letter-spacing:.06em;
  }

  /* Case (single, focused) */
  .case-section{padding: 40px 0 60px;}
  .case-block{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    display:grid;
    grid-template-columns: 0.85fr 1.15fr;
    min-height: 420px;
  }
  .case-block .visual{
    background: linear-gradient(135deg, #14241a 0%, #0e1a13 100%);
    color: #e8f3e2;
    padding: 44px 40px;
    display:flex; flex-direction:column; justify-content:space-between;
    position: relative;
    overflow: hidden;
  }
  .case-block .visual::after{
    content:"";
    position:absolute; right:-80px; bottom:-80px;
    width: 240px; height: 240px; border-radius: 50%;
    background: radial-gradient(circle, rgba(126,217,87,.22), transparent 70%);
  }
  .case-block .visual .tag{
    display:inline-flex; align-items:center; gap:6px;
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.14em; text-transform: uppercase;
    color: var(--green);
    padding: 6px 10px; border-radius: 999px;
    background: rgba(126,217,87,.1);
    border: 1px solid rgba(126,217,87,.2);
    align-self: flex-start;
  }
  .case-block .visual .who{margin-top: auto; position: relative; z-index: 1;}
  .case-block .visual .who h3{
    font-family:'Space Grotesk', sans-serif;
    font-size: 24px; font-weight: 600; line-height: 1.2;
    margin: 0 0 6px; color:#fff;
  }
  .case-block .visual .who-d{font-size: 13.5px; color: rgba(232,243,226,.6);}
  .case-block .visual .stats{
    display:flex; gap: 26px;
    margin-top: 22px;
    position: relative; z-index: 1;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .case-block .visual .stats .v{
    font-family:'Space Grotesk', sans-serif;
    font-size: 32px; font-weight: 700; letter-spacing:-.02em; line-height: 1;
    color: var(--green);
  }
  .case-block .visual .stats .v small{font-size:.45em; color: rgba(232,243,226,.6); font-weight: 500;}
  .case-block .visual .stats .l{font-size: 12px; color: rgba(232,243,226,.6); margin-top: 6px;}
  .case-block .content{padding: 44px 44px; display:flex; flex-direction:column; gap: 18px;}
  .case-block .step{display:grid; grid-template-columns: auto 1fr; gap: 14px; align-items:start;}
  .case-block .step .lbl{
    display:inline-flex; align-items:center; gap:6px;
    font-family:'JetBrains Mono', monospace;
    font-size: 10.5px; letter-spacing:.16em; text-transform: uppercase;
    color: var(--muted);
    padding-top: 4px;
    min-width: 96px;
  }
  .case-block .step .lbl::before{
    content:""; width: 6px; height: 6px; border-radius: 50%;
    background: var(--green); flex-shrink: 0;
  }
  .case-block .step .lbl.is-eff::before{box-shadow: 0 0 0 3px rgba(126,217,87,.2);}
  .case-block .step .txt{font-size: 14.5px; line-height: 1.65; color: var(--ink-2);}
  .case-block .step .txt strong{color: var(--ink);}

  /* Pricing-ish package strip */
  .pack-section{padding: 60px 0;}
  .pack-section h2{max-width: 560px;}
  .pack-section .head-p{color: var(--muted); font-size: 15px; max-width: 520px; margin-top: 14px;}
  .pack-grid{
    display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
    margin-top: 44px;
  }
  .pack-card{
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 32px 28px;
    display:flex; flex-direction:column; gap: 14px;
    position: relative;
  }
  .pack-card.is-featured{
    background: linear-gradient(180deg, #14241a 0%, #0e1a13 100%);
    color:#fff; border-color: #1d2c22;
  }
  .pack-card.is-featured::before{
    content:"Najpopularniejszy";
    position:absolute; top: -12px; left: 50%; transform: translateX(-50%);
    background: var(--green); color: var(--green-ink);
    font-size: 11px; letter-spacing:.08em; padding: 6px 14px;
    border-radius: 999px; font-weight: 500;
  }
  .pack-card .pkn{
    font-family:'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing:.18em; text-transform: uppercase;
    color: var(--green-dark);
  }
  .pack-card.is-featured .pkn{color: var(--green);}
  .pack-card .pname{
    font-family:'Space Grotesk', sans-serif;
    font-size: 26px; font-weight: 600; letter-spacing: -.01em;
  }
  .pack-card .price{
    font-family:'Space Grotesk', sans-serif;
    font-size: 16px; color: var(--muted);
    padding-bottom: 18px;
    border-bottom: 1px solid var(--line);
  }
  .pack-card.is-featured .price{color: rgba(255,255,255,.55); border-color: rgba(255,255,255,.08);}
  .pack-card .price b{
    font-size: 32px; color: var(--ink); display:inline-block; margin-right: 4px;
    font-weight: 700;
  }
  .pack-card.is-featured .price b{color:#fff;}
  .pack-card ul{
    list-style: none; padding: 0; margin: 0;
    display:flex; flex-direction:column; gap: 10px;
    flex: 1;
  }
  .pack-card li{
    display:flex; gap: 12px; align-items:flex-start;
    font-size: 14px; line-height: 1.55; color: var(--ink-2);
  }
  .pack-card.is-featured li{color: rgba(255,255,255,.85);}
  .pack-card .tick{
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--chip); color: var(--green-dark);
    display:grid; place-items:center; flex-shrink: 0; margin-top: 1px;
  }
  .pack-card.is-featured .tick{background: rgba(126,217,87,.15); color: var(--green);}
  .pack-card .btn{margin-top: 14px; justify-content:center;}

  /* CTA band */
  .cta-band{
    background: var(--bg-dark);
    color:#fff;
    border-radius: var(--radius-lg);
    padding: 60px 56px;
    display:grid; grid-template-columns: 1.4fr 1fr; gap: 50px; align-items: center;
    position: relative;
    overflow: hidden;
    margin: 40px 0 100px;
  }
  .cta-band::before{
    content:"";
    position:absolute; right:-100px; top:50%; transform: translateY(-50%);
    width: 400px; height: 400px; border-radius: 50%;
    background: radial-gradient(circle, rgba(126,217,87,.18), transparent 65%);
  }
  .cta-band h2{
    color:#fff;
    font-size: clamp(28px, 3.6vw, 44px); line-height: 1.1;
    margin: 0;
  }
  .cta-band .eyebrow{color: var(--green);}
  .cta-band .eyebrow::before{background: var(--green);}
  .cta-band p{color: rgba(255,255,255,.7); margin-top: 16px; max-width: 480px; font-size: 15px;}
  .cta-band .actions{display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end; position: relative; z-index: 1;}
  .cta-band .btn-ghost{background: rgba(255,255,255,.06); color:#fff; border-color: rgba(255,255,255,.16);}
  .cta-band .btn-ghost:hover{background: rgba(255,255,255,.12);}

  