/* Montserrat - self-hosted subset (latin+latin-ext), files in ../brand/fonts/montserrat/woff2/ */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400;font-display:swap;src:url('../brand/fonts/montserrat/woff2/Montserrat-Regular.woff2') format('woff2');}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;src:url('../brand/fonts/montserrat/woff2/Montserrat-SemiBold.woff2') format('woff2');}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700;font-display:swap;src:url('../brand/fonts/montserrat/woff2/Montserrat-Bold.woff2') format('woff2');}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('../brand/fonts/montserrat/woff2/Montserrat-ExtraBold.woff2') format('woff2');}

  :root{
    /* Brand tokens - docs/brand-identity.md (SOURCE OF TRUTH) */
    --amber:#FDB035;
    --amber-2:#F2A31D;        /* hover */
    --amber-ink:#1d1200;      /* text on amber */
    --amber-deep:#8f5e00;     /* amber-family text on light bg (AA) */
    --amber-soft:#FFF3DC;
    --navy:#0F192E;
    --navy-2:#182642;
    --navy-deep:#0A1120;
    --ink:#0c0d0f;
    --muted:#575c64;
    --line:#e5e5e5;
    --glass:#E5E5E5;
    --soft:#f7f7f7;
    --r:14px;
    --shadow-sm:0 1px 2px rgba(10,17,32,.06);
    --shadow-md:0 10px 28px rgba(10,17,32,.12);
  }

  *{box-sizing:border-box;}
  html{
    scroll-padding-top:84px;
    -webkit-text-size-adjust:100%;
  }
  @media (prefers-reduced-motion: no-preference){
    html{scroll-behavior:smooth;}
  }
  body{
    margin:0;
    font-family:'Montserrat',system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
    font-size:16px;
    line-height:1.65;
    color:var(--ink);
    background:#fff;
    -webkit-tap-highlight-color:transparent;
  }
  @media (min-width:900px){
    body{font-size:16.5px;}
  }
  @media (max-width:979px){
    body{padding-bottom:calc(74px + env(safe-area-inset-bottom));}
  }
  h1,h2,h3,h4,p{margin:0;}
  a{color:inherit;}
  button{font-family:inherit;}
  ::selection{background:var(--amber);color:var(--amber-ink);}
  :focus-visible{outline:3px solid rgba(253,176,53,.7);outline-offset:2px;border-radius:6px;}

  .container{width:100%;max-width:1150px;margin-inline:auto;padding-inline:clamp(20px,5vw,40px);}

  .skip{
    position:absolute;left:-9999px;top:0;z-index:200;
    background:#000;color:#fff;padding:10px 16px;border-radius:0 0 10px 0;font-weight:700;
  }
  .skip:focus{left:0;}

  /* ============ buttons ============ */
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:9px;
    padding:13px 21px;border-radius:12px;border:0;cursor:pointer;
    font-size:15px;font-weight:700;line-height:1.2;text-decoration:none;
    transition:background .16s ease, transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  }
  .btn svg{width:19px;height:19px;flex:0 0 auto;}
  .btn:active{transform:translateY(1px);}
  .btn-amber{background:var(--amber);color:var(--amber-ink);box-shadow:0 3px 12px rgba(253,176,53,.38);}
  .btn-amber:hover{background:var(--amber-2);}
  .btn-dark{background:#000;color:#fff;}
  .btn-dark:hover{background:#1c1c1f;}
  .btn-ghost{background:rgba(255,255,255,.05);color:#fff;border:1.5px solid rgba(255,255,255,.34);}
  .btn-ghost:hover{background:rgba(255,255,255,.12);}
  .btn-outline{background:#fff;color:#000;border:1.5px solid #d4d4d4;}
  .btn-outline:hover{border-color:#000;}
  .btn-sm{padding:10px 15px;font-size:14px;border-radius:10px;}
  .btn-sm svg{width:17px;height:17px;}

  /* ============ header ============ */
  .site-header{
    position:sticky;top:0;z-index:80;
    background:rgba(255,255,255,.94);
    -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
    border-top:4px solid var(--amber);
    border-bottom:1px solid var(--line);
    transition:box-shadow .2s ease;
  }
  .site-header.scrolled{box-shadow:0 6px 22px rgba(10,17,32,.09);}
  .header-in{display:flex;align-items:center;justify-content:space-between;gap:16px;height:66px;}
  @media (min-width:980px){.header-in{height:76px;}}

  .brand{display:flex;align-items:center;gap:11px;text-decoration:none;min-width:0;}
  .brand-mark{width:42px;height:38px;flex:0 0 auto;}
  .brand > span{min-width:0;}
  .brand-name{font-size:19px;font-weight:700;letter-spacing:-.01em;color:#000;line-height:1.05;display:block;white-space:nowrap;}
  .brand-name b{color:#C07E00;font-weight:700;}
  .brand-tag{display:block;font-size:9.2px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  @media (max-width:374px){.brand-tag{font-size:9px;letter-spacing:.06em;}}

  .main-nav{display:none;}
  .header-cta{display:none;}
  @media (min-width:980px){
    .main-nav{display:block;}
    .main-nav ul{display:flex;gap:1px;list-style:none;margin:0;padding:0;}
    .main-nav a{
      display:block;padding:9px 9px;border-radius:9px;
      font-size:14px;font-weight:600;color:var(--ink);text-decoration:none;
    }
    .main-nav a:hover{background:rgba(10,17,32,.06);}
    .header-cta{display:flex;gap:8px;flex:0 0 auto;}
    .header-cta .btn-sm{padding-inline:13px;}
  }
  /* mezi 980 a 1180 se vedle plneho loga nevejde druhe CTA - telefon zustava v nav/Kontaktu */
  @media (min-width:980px) and (max-width:1179px){
    .header-cta .btn-outline{display:none;}
  }

  .phone-pill{
    display:inline-flex;align-items:center;justify-content:center;
    width:42px;height:42px;border-radius:50%;
    background:var(--amber);color:var(--amber-ink);text-decoration:none;
    box-shadow:0 2px 8px rgba(253,176,53,.4);
  }
  .phone-pill svg{width:19px;height:19px;}
  .burger{
    width:44px;height:44px;border:0;background:transparent;cursor:pointer;
    display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:10px;
  }
  .burger .bar{width:22px;height:2.5px;border-radius:2px;background:#000;transition:transform .22s ease, opacity .18s ease;}
  .burger.open .bar:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
  .burger.open .bar:nth-child(2){opacity:0;}
  .burger.open .bar:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
  .header-mobile{display:flex;align-items:center;gap:8px;}
  @media (min-width:980px){.header-mobile{display:none;}}

  .mobile-panel{
    display:none;position:absolute;left:0;right:0;top:100%;
    background:#fff;border-bottom:1px solid var(--line);
    box-shadow:0 22px 40px rgba(10,17,32,.14);
    padding:10px 0 22px;
  }
  .mobile-panel.open{display:block;animation:panel .2s ease;}
  @keyframes panel{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}
  @media (prefers-reduced-motion: reduce){.mobile-panel.open{animation:none;}}
  .mobile-panel ul{list-style:none;margin:0;padding:0 0 12px;}
  .mobile-panel li a{
    display:block;padding:13px 4px;font-size:17px;font-weight:600;text-decoration:none;color:var(--ink);
    border-bottom:1px solid var(--line);
  }
  .mobile-panel li:last-child a{border-bottom:0;}
  .mobile-panel .panel-cta{display:grid;gap:10px;}

  /* ============ hero ============ */
  /* TODO: az prijde hlavni fotka od Paji, podklad = fotka + tmavy overlay (viz stary web) */
  .hero{
    position:relative;overflow:hidden;color:#fff;
    background:
      radial-gradient(110% 80% at 88% -10%, rgba(253,176,53,.16), transparent 55%),
      linear-gradient(178deg,#182642 0%, #0F192E 52%, #0B1426 100%);
  }
  .hero::before{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:repeating-linear-gradient(135deg, rgba(255,255,255,.022) 0 2px, transparent 2px 9px);
  }
  .hero::after{
    content:"";position:absolute;left:0;right:0;bottom:0;height:6px;
    /* ctvercova dlazdice = bezesvy diagonalni pruh, jde plynule animovat posunem pozice */
    background:linear-gradient(45deg, var(--amber) 0 25%, rgba(253,176,53,.16) 25% 50%, var(--amber) 50% 75%, rgba(253,176,53,.16) 75% 100%);
    background-size:24px 24px;
  }
  .hero-topo{position:absolute;right:-170px;top:-70px;width:min(860px,90vw);height:auto;opacity:.07;pointer-events:none;}
  .hero-exc{position:absolute;right:3%;bottom:52px;width:min(430px,34vw);height:auto;z-index:1;pointer-events:none;display:none;}
  @media (min-width:980px){.hero-exc{display:block;}}
  .hx-boom,.hx-stick,.hx-bucket,.hx-dirt{transform-box:view-box;}
  .hx-boom{transform-origin:178px 122px;}
  .hx-stick{transform-origin:98px 54px;}
  .hx-bucket{transform-origin:52px 133px;}
  .hx-dirt{opacity:0;}
  .hero-in{position:relative;z-index:2;padding:74px 0 66px;max-width:720px;}
  @media (min-width:980px){.hero-in{padding:118px 0 106px;}}
  .hero-kicker{
    display:flex;align-items:center;gap:10px;
    font-size:12.5px;font-weight:700;letter-spacing:.17em;text-transform:uppercase;color:var(--amber);
    margin-bottom:18px;
  }
  .hero-kicker::before{content:"";width:9px;height:9px;background:var(--amber);transform:rotate(45deg);flex:0 0 auto;}
  .hero h1{
    font-size:clamp(2.7rem, 9.5vw, 4.4rem);font-weight:800;letter-spacing:-.025em;line-height:1.02;
    margin-bottom:14px;
  }
  .hero-sub{
    font-size:clamp(1.28rem, 4.6vw, 1.8rem);font-weight:700;letter-spacing:-.01em;line-height:1.3;
    color:#c8cedd;margin-bottom:18px;max-width:600px;
  }
  .hero-sub .hl{color:var(--amber);}
  .hero-lead{color:#a7aec2;font-size:clamp(1rem, 2vw, 1.07rem);max-width:560px;margin-bottom:30px;}
  .hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px;}
  .hero-ctas .btn{padding:15px 24px;font-size:16px;}
  .chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:34px;}
  .chip{
    display:inline-flex;align-items:center;gap:7px;
    background:rgba(255,255,255,.065);border:1px solid rgba(255,255,255,.14);
    color:#dde1ec;border-radius:999px;padding:8px 14px;
    font-size:13px;font-weight:600;
  }
  .chip svg{width:15px;height:15px;color:var(--amber);flex:0 0 auto;}

  /* ============ hero - vstupni animace (jen bez prefers-reduced-motion) ============ */
  @media (prefers-reduced-motion: no-preference){
    .hero-in > *{opacity:0;transform:translateY(22px);animation:heroIn .75s cubic-bezier(.22,.8,.3,1) forwards;}
    .hero-in > :nth-child(1){animation-delay:.08s;}
    .hero-in > :nth-child(2){animation-delay:.2s;}
    .hero-in > :nth-child(3){animation-delay:.36s;}
    .hero-in > :nth-child(4){animation-delay:.5s;}
    .hero-in > :nth-child(5){animation-delay:.64s;}
    .hero-in > :nth-child(6){animation-delay:.78s;}
    .hero::after{animation:stripeMove 2.6s linear infinite;}
    .hero-topo{animation:topoDrift 26s ease-in-out infinite alternate;}
    .hero-exc{opacity:0;animation:heroExcIn 1.1s ease .75s forwards;}
    .hx-boom{animation:hxBoom 6.5s ease-in-out 2s infinite;}
    .hx-stick{animation:hxStick 6.5s ease-in-out 2s infinite;}
    .hx-bucket{animation:hxBucket 6.5s ease-in-out 2s infinite;}
    .hx-dirt{animation:hxDirt 6.5s linear 2s infinite;}
    .hero-ctas .btn-amber{animation:waPulse 5s ease-out 2.8s infinite;}
  }
  @keyframes heroIn{to{opacity:1;transform:none;}}
  @keyframes stripeMove{to{background-position-x:24px;}}
  @keyframes topoDrift{
    from{transform:rotate(0deg) scale(1);opacity:.06;}
    to{transform:rotate(3deg) scale(1.045);opacity:.09;}
  }
  @keyframes heroExcIn{to{opacity:1;}}
  @keyframes hxBoom{0%,100%{transform:rotate(0);}38%{transform:rotate(6deg);}72%{transform:rotate(-2.5deg);}}
  @keyframes hxStick{0%,100%{transform:rotate(0);}38%{transform:rotate(-9deg);}72%{transform:rotate(4deg);}}
  @keyframes hxBucket{0%,100%{transform:rotate(0);}30%{transform:rotate(13deg);}66%{transform:rotate(-6deg);}}
  @keyframes hxDirt{0%,26%{opacity:0;transform:translateY(0);}34%{opacity:.85;}54%{opacity:0;transform:translateY(30px);}100%{opacity:0;transform:translateY(30px);}}
  @keyframes waPulse{
    0%{box-shadow:0 3px 12px rgba(253,176,53,.38), 0 0 0 0 rgba(253,176,53,.45);}
    12%{box-shadow:0 3px 12px rgba(253,176,53,.38), 0 0 0 14px rgba(253,176,53,0);}
    100%{box-shadow:0 3px 12px rgba(253,176,53,.38), 0 0 0 0 rgba(253,176,53,0);}
  }

  /* ============ sections ============ */
  .section{padding:74px 0;}
  @media (min-width:900px){.section{padding:104px 0;}}
  .section.tinted{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
  .section.dark{background:var(--navy);color:#fff;}
  .section.amber{background:var(--amber);color:var(--amber-ink);}
  .sec-head{max-width:660px;margin-bottom:38px;}
  @media (min-width:900px){.sec-head{margin-bottom:46px;}}
  .kicker{
    display:flex;align-items:center;gap:10px;
    font-size:12.5px;font-weight:700;letter-spacing:.17em;text-transform:uppercase;color:var(--muted);
    margin-bottom:12px;
  }
  .kicker::before{content:"";width:9px;height:9px;background:var(--amber);transform:rotate(45deg);flex:0 0 auto;}
  .dark .kicker{color:#98a0b5;}
  .amber .kicker{color:rgba(20,13,0,.72);}
  .amber .kicker::before{background:#000;}
  .sec-head h2{
    font-size:clamp(1.75rem, 5vw, 2.45rem);font-weight:800;letter-spacing:-.02em;line-height:1.12;
    color:#000;margin-bottom:14px;
  }
  .dark .sec-head h2{color:#fff;}
  .amber .sec-head h2{color:#000;}
  .sec-lead{color:var(--muted);font-size:clamp(1rem, 2vw, 1.07rem);}
  .dark .sec-lead{color:#a7aec2;}
  .amber .sec-lead{color:rgba(20,13,0,.72);}

  /* ============ služby ============ */
  .cards-4{display:grid;grid-template-columns:1fr;gap:14px;}
  @media (min-width:640px){.cards-4{grid-template-columns:1fr 1fr;gap:18px;}}
  @media (min-width:1020px){.cards-4{grid-template-columns:repeat(4,1fr);}}
  .svc{
    background:#fff;border:1px solid var(--line);border-radius:16px;
    padding:26px 24px;box-shadow:var(--shadow-sm);
    transition:transform .18s ease, box-shadow .18s ease;
  }
  .svc:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
  .svc-ico{
    width:48px;height:48px;border-radius:13px;
    background:var(--amber);
    display:flex;align-items:center;justify-content:center;
    color:var(--amber-ink);margin-bottom:17px;
    box-shadow:0 3px 10px rgba(253,176,53,.35);
  }
  .svc-ico svg{width:25px;height:25px;}
  .svc h3{font-size:17.5px;font-weight:800;color:#000;margin-bottom:8px;letter-spacing:-.01em;}
  .svc p{font-size:14.5px;color:var(--muted);line-height:1.6;}
  .svc-note{margin-top:30px;font-size:15px;color:var(--muted);}
  .svc-note a{color:var(--amber-deep);font-weight:700;text-decoration-thickness:1.5px;text-underline-offset:3px;}

  /* ============ stroje - spotlight ============ */
  .fleet-stats{
    display:flex;flex-wrap:wrap;gap:10px 0;margin:-6px 0 44px;
    border-block:1px solid var(--line);padding:16px 0;
  }
  .fstat{flex:1 1 160px;display:flex;align-items:baseline;gap:10px;padding:2px 18px;}
  .fstat + .fstat{border-left:1px solid var(--line);}
  .fstat:first-child{padding-left:2px;}
  .fstat b{font-size:clamp(1.6rem,4vw,2.1rem);font-weight:800;letter-spacing:-.02em;color:#000;line-height:1;}
  .fstat b i{font-style:normal;color:var(--amber);}
  .fstat span{font-size:13px;font-weight:600;color:var(--muted);line-height:1.3;}
  @media (max-width:560px){
    .fstat{flex:1 1 100%;padding-inline:2px;}
    .fstat + .fstat{border-left:0;border-top:1px dashed var(--line);padding-top:12px;}
  }

  .spotlight{position:relative;}
  .spot-stage{
    position:relative;
    height:clamp(300px, 42vw, 430px);
    overflow:hidden; /* side cards must not create page-level horizontal overflow */
  }
  .spot-ghost{
    position:absolute;left:0;right:0;top:2%;
    text-align:center;pointer-events:none;user-select:none;
    font-size:clamp(4.6rem, 16vw, 10.5rem);font-weight:800;letter-spacing:.01em;line-height:1;
    color:rgba(15,25,46,.055);
    transition:opacity .22s ease;
  }
  @supports (-webkit-text-stroke: 2px black){
    .spot-ghost{color:transparent;-webkit-text-stroke:2px rgba(15,25,46,.10);}
  }
  .pedestal{
    position:absolute;left:50%;bottom:12px;transform:translateX(-50%);
    width:min(560px, 82%);height:60px;pointer-events:none;
  }
  .pedestal .ped-shadow{
    position:absolute;left:6%;right:6%;bottom:-12px;height:24px;border-radius:50%;
    background:rgba(10,17,32,.3);filter:blur(12px);
  }
  .pedestal .ped-side{
    position:absolute;left:0;right:0;top:17px;bottom:0;
    background:linear-gradient(#131f38,var(--navy-deep));
    border-radius:0 0 50% 50% / 0 0 22px 22px;
  }
  .pedestal .ped-side::after{
    content:"";position:absolute;left:7%;right:7%;top:24px;height:6px;
    background:repeating-linear-gradient(-55deg, var(--amber) 0 12px, rgba(253,176,53,.25) 12px 24px);
    opacity:.9;
  }
  .pedestal .ped-top{
    position:absolute;left:0;right:0;top:0;height:36px;border-radius:50%;
    background:radial-gradient(60% 100% at 50% 32%, #2a3d63, var(--navy) 78%);
    border:1px solid rgba(255,255,255,.07);
  }
  .spot-card{
    position:absolute;left:50%;bottom:44px;
    width:min(430px, 74vw);
    transform:translateX(-50%);
    transition:transform .5s cubic-bezier(.22,.8,.3,1), opacity .5s ease, filter .5s ease;
    will-change:transform,opacity;
  }
  @media (prefers-reduced-motion: reduce){
    .spot-card{transition:none;}
    .spot-ghost{transition:none;}
  }
  .spot-visual{display:flex;align-items:flex-end;justify-content:center;position:relative;}
  .spot-visual svg{width:calc(var(--ms,1) * 100%);height:auto;display:block;}
  .spot-card.pos-c{z-index:5;}
  .spot-card.pos-l,.spot-card.pos-r{z-index:2;opacity:.3;filter:saturate(.25) contrast(.9);}
  .spot-card.pos-l{transform:translateX(calc(-50% - clamp(150px, 30vw, 360px))) scale(.48);}
  .spot-card.pos-r{transform:translateX(calc(-50% + clamp(150px, 30vw, 360px))) scale(.48);}
  .spot-card.pos-off{opacity:0;transform:translateX(-50%) scale(.3);pointer-events:none;}
  .spot-card.pos-off-l{opacity:0;transform:translateX(calc(-50% - clamp(200px,38vw,460px))) scale(.3);pointer-events:none;}
  .spot-card.pos-off-r{opacity:0;transform:translateX(calc(-50% + clamp(200px,38vw,460px))) scale(.3);pointer-events:none;}

  .spot-btn{
    position:absolute;top:44%;z-index:8;width:48px;height:48px;border-radius:50%;cursor:pointer;
    background:#fff;border:1.5px solid #d9d9d9;color:#000;
    display:inline-flex;align-items:center;justify-content:center;
    box-shadow:var(--shadow-sm);
    transition:background .15s ease, border-color .15s ease, transform .15s ease;
  }
  .spot-btn:hover{background:var(--amber);border-color:var(--amber);}
  .spot-btn:active{transform:translateY(1px);}
  .spot-btn svg{width:20px;height:20px;}
  .spot-prev{left:10px;}
  .spot-next{right:10px;}

  .spot-info{max-width:660px;margin:26px auto 0;text-align:center;transition:opacity .18s ease;}
  .spot-info h3{font-size:clamp(1.45rem,4vw,1.95rem);font-weight:800;letter-spacing:-.02em;color:#000;}
  .spot-meta{
    display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;
    margin:10px 0 14px;
  }
  .spot-type{
    font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--amber-deep);
  }
  .spot-class{
    display:inline-flex;align-items:center;
    background:var(--amber-soft);border:1px solid #f0dcae;border-radius:999px;
    padding:3px 11px;font-size:12px;font-weight:700;color:#6b4a08;
  }
  .spot-count{font-size:12px;font-weight:600;color:#6d737c;}
  .spot-desc{font-size:15px;color:var(--muted);max-width:560px;margin:0 auto;}
  .spot-ideal{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;list-style:none;margin:16px 0 0;padding:0;}
  .spot-ideal li{
    display:inline-flex;align-items:center;gap:6px;
    border:1px solid var(--line);border-radius:999px;background:#fff;
    padding:5px 12px;font-size:12.5px;font-weight:600;color:#3d424d;
  }
  .spot-ideal li::before{content:"";width:6px;height:6px;background:var(--amber);transform:rotate(45deg);flex:0 0 auto;}
  .spot-cta{margin-top:18px;}

  .spot-thumbs{
    display:flex;gap:8px;overflow-x:auto;
    padding:22px 4px 8px;
    scrollbar-width:thin;
  }
  @media (min-width:900px){.spot-thumbs{justify-content:center;}}
  .spot-thumb{
    flex:0 0 auto;min-width:96px;
    display:grid;justify-items:center;gap:5px;
    padding:10px 12px 8px;border:1.5px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;
    transition:border-color .15s ease, background .15s ease, transform .15s ease;
  }
  .spot-thumb:hover{border-color:#bdbdbd;transform:translateY(-2px);}
  .spot-thumb svg{height:32px;width:auto;max-width:76px;}
  .spot-thumb span{font-size:11.5px;font-weight:700;color:var(--ink);white-space:nowrap;}
  .spot-thumb[aria-current="true"]{border-color:var(--amber);background:var(--amber-soft);box-shadow:0 3px 10px rgba(253,176,53,.25);}

  /* no-JS fallback: spotlight renders as a plain card grid */
  .spotlight:not(.js) .spot-stage{height:auto;}
  .spotlight:not(.js) .spot-track{display:grid;grid-template-columns:1fr;gap:16px;}
  @media (min-width:620px){.spotlight:not(.js) .spot-track{grid-template-columns:1fr 1fr;}}
  @media (min-width:1020px){.spotlight:not(.js) .spot-track{grid-template-columns:repeat(3,1fr);}}
  .spotlight:not(.js) .spot-card{
    position:static;transform:none;width:auto;
    border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);
  }
  .spotlight:not(.js) .pedestal,
  .spotlight:not(.js) .spot-ghost,
  .spotlight:not(.js) .spot-btn,
  .spotlight:not(.js) .spot-thumbs,
  .spotlight:not(.js) .spot-info{display:none;}
  .spotlight:not(.js) .spot-text h3{font-size:17px;font-weight:800;margin-top:12px;}
  .spotlight.js .spot-text{display:none;}
  .spot-text .spot-type{display:block;margin:3px 0 8px;}
  .spot-text p{font-size:14.5px;color:var(--muted);}
  .spot-text .spot-ideal{justify-content:flex-start;margin-top:12px;}

  /* ============ fotogalerie (amber band, jako stary web) ============ */
  .gal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  @media (min-width:700px){.gal-grid{grid-template-columns:repeat(3,1fr);gap:14px;}}
  @media (min-width:1020px){.gal-grid{grid-template-columns:repeat(4,1fr);}}
  .gal-item{
    aspect-ratio:4/3;position:relative;border-radius:12px;overflow:hidden;
    border:1px solid rgba(10,17,32,.18);cursor:pointer;padding:0;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 4px 14px rgba(122,77,0,.18);
    transition:transform .18s ease, box-shadow .18s ease;
  }
  .gal-item:hover{transform:scale(1.022);box-shadow:0 8px 22px rgba(122,77,0,.28);}
  .gal-item > svg{width:36px;height:36px;}
  .tone-a{background:radial-gradient(120% 100% at 80% 0%, rgba(253,176,53,.14), transparent 55%), linear-gradient(150deg,#223252,#121c33 70%);color:rgba(253,176,53,.85);}
  .tone-b{background:radial-gradient(120% 100% at 20% 0%, rgba(255,255,255,.07), transparent 50%), linear-gradient(150deg,#1b2a4e,#101a30 70%);color:rgba(230,235,247,.72);}
  .tone-light{background:radial-gradient(120% 100% at 20% 0%, #ffffff, transparent 55%), linear-gradient(150deg,#f2f2f2,#dcdcdc 75%);color:rgba(15,25,46,.65);}
  .gal-tag{
    position:absolute;left:8px;bottom:8px;
    border:1px dashed rgba(255,255,255,.36);border-radius:999px;background:rgba(10,13,22,.5);
    padding:3.5px 9px;font-size:10.5px;font-weight:600;color:#d5dae6;white-space:nowrap;
  }
  .tone-light .gal-tag{background:rgba(255,255,255,.72);border-color:rgba(15,25,46,.4);color:#39435e;}
  .gal-hint{
    margin-top:20px;display:flex;align-items:center;gap:9px;
    font-size:13.5px;font-weight:600;color:rgba(20,13,0,.65);
  }
  .gal-hint svg{width:15px;height:15px;flex:0 0 auto;color:#000;}

  /* lightbox */
  .lb{
    position:fixed;inset:0;z-index:120;display:none;
    align-items:center;justify-content:center;flex-direction:column;
    background:rgba(7,10,19,.94);padding:22px;
  }
  .lb.open{display:flex;}
  .lb-stage{width:min(740px, 100%);position:relative;}
  .lb-ph{
    aspect-ratio:4/3;border-radius:16px;border:1px solid rgba(255,255,255,.14);
    display:flex;align-items:center;justify-content:center;
  }
  .lb-ph svg{width:64px;height:64px;}
  .lb-cap{margin-top:16px;color:#dfe3ee;font-size:15.5px;font-weight:600;text-align:center;}
  .lb-count{margin-top:4px;color:#7d8598;font-size:13px;text-align:center;}
  .lb-btn{
    position:absolute;width:46px;height:46px;border-radius:50%;cursor:pointer;
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.24);color:#fff;
    display:inline-flex;align-items:center;justify-content:center;
    transition:background .15s ease;
  }
  .lb-btn:hover{background:rgba(255,255,255,.16);}
  .lb-btn svg{width:20px;height:20px;}
  .lb-close{top:-58px;right:0;position:absolute;}
  .lb-prev{left:-8px;top:50%;transform:translate(-0%,-50%);}
  .lb-next{right:-8px;top:50%;transform:translate(0%,-50%);}
  @media (min-width:900px){
    .lb-prev{left:-64px;}
    .lb-next{right:-64px;}
  }

  /* ============ reference ============ */
  .refs{display:grid;grid-template-columns:1fr;gap:16px;}
  @media (min-width:700px){.refs{grid-template-columns:1fr 1fr;gap:18px;}}
  @media (min-width:1020px){.refs{grid-template-columns:repeat(3,1fr);}}
  .ref{
    background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;
    box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  }
  .ref-chip{
    align-self:flex-start;
    font-size:11.5px;font-weight:700;color:#6b4a08;
    background:var(--amber-soft);border:1px solid #f0dcae;border-radius:999px;
    padding:4px 12px;margin-bottom:15px;
  }
  .ref blockquote{margin:0;font-size:15px;line-height:1.65;color:#3d424d;flex:1;}
  .ref-who{margin-top:17px;padding-top:14px;border-top:1px solid var(--line);}
  .ref-who b{display:block;font-size:14.5px;color:#000;}
  .ref-who span{font-size:13.5px;color:var(--muted);}

  /* ============ kontakt ============ */
  .contact-grid{display:grid;grid-template-columns:1fr;gap:46px;}
  @media (min-width:960px){.contact-grid{grid-template-columns:1.04fr .96fr;gap:60px;align-items:start;}}
  .contact-ctas{display:grid;gap:12px;max-width:430px;margin-bottom:34px;}
  .cta-big{
    display:flex;align-items:center;gap:14px;text-decoration:none;
    border-radius:15px;padding:15px 18px;
    transition:transform .16s ease, background .16s ease;
  }
  .cta-big:active{transform:translateY(1px);}
  .cta-big svg{width:24px;height:24px;flex:0 0 auto;}
  .cta-big .t{display:block;font-size:16px;font-weight:800;line-height:1.2;}
  .cta-big .s{display:block;font-size:12.5px;font-weight:600;margin-top:2px;}
  .cta-wa{background:var(--amber);color:var(--amber-ink);box-shadow:0 3px 14px rgba(253,176,53,.32);}
  .cta-wa:hover{background:var(--amber-2);}
  .cta-wa .s{color:#6b4a08;}
  .cta-call{background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.32);color:#fff;}
  .cta-call:hover{background:rgba(255,255,255,.11);}
  .cta-call .s{color:#a7aec2;}
  .c-rows{display:grid;gap:20px;}
  .c-row{display:flex;gap:14px;align-items:flex-start;}
  .c-ico{
    width:42px;height:42px;border-radius:12px;flex:0 0 auto;
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);
    display:flex;align-items:center;justify-content:center;color:var(--amber);
  }
  .c-ico svg{width:19px;height:19px;}
  .c-label{display:block;font-size:11px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:#8a93aa;margin-bottom:2px;}
  .c-val{font-size:16px;font-weight:700;color:#fff;}
  .c-val a{color:#fff;text-decoration:none;border-bottom:1.5px solid rgba(253,176,53,.6);}
  .c-val a:hover{border-bottom-color:var(--amber);}
  .c-val.todo{color:#a7aec2;font-weight:600;border-bottom:1px dashed rgba(255,255,255,.4);display:inline-block;}
  .c-sub{display:block;font-size:13.5px;color:#8f97ad;margin-top:2px;}

  .form-card{
    background:#fff;border-radius:18px;padding:28px 24px 26px;color:var(--ink);
    box-shadow:0 24px 60px rgba(4,7,15,.5);
  }
  @media (min-width:600px){.form-card{padding:32px 32px 30px;}}
  .form-card h3{font-size:19px;font-weight:800;color:#000;margin-bottom:6px;letter-spacing:-.01em;}
  .form-sub{font-size:14px;color:var(--muted);margin-bottom:22px;}
  .field{margin-bottom:16px;}
  .field label{display:block;font-size:13.5px;font-weight:700;color:#26292f;margin-bottom:6px;}
  .field input,.field textarea{
    width:100%;border:1.5px solid #d6d6d6;border-radius:11px;background:#fff;
    padding:12px 14px;font-size:16px;font-family:inherit;color:var(--ink);
  }
  .field textarea{min-height:112px;resize:vertical;}
  .field input:focus,.field textarea:focus{
    outline:none;border-color:var(--amber);box-shadow:0 0 0 3.5px rgba(253,176,53,.25);
  }
  .field ::placeholder{color:#a3a3a3;}
  .form-note{margin-top:13px;font-size:12.5px;color:var(--muted);text-align:center;}
  .form-ok{text-align:center;padding:26px 6px 16px;}
  .ok-ico{
    width:58px;height:58px;border-radius:50%;margin:0 auto 18px;
    background:var(--navy);color:var(--amber);
    display:flex;align-items:center;justify-content:center;
  }
  .ok-ico svg{width:28px;height:28px;}
  .form-ok h3{margin-bottom:8px;}
  .form-ok p{font-size:14.5px;color:var(--muted);}
  .form-ok p a{color:#000;font-weight:800;text-decoration:none;border-bottom:2px solid var(--amber);}
  .form-ok .btn{margin:18px auto 0;}
  .again{
    margin-top:18px;background:none;border:0;cursor:pointer;display:block;margin-inline:auto;
    font-size:14px;font-weight:700;color:var(--muted);text-decoration:underline;text-underline-offset:3px;
  }
  .again:hover{color:var(--ink);}

  /* ============ footer ============ */
  .site-footer{background:var(--navy-deep);color:#a7aec2;}
  .f-grid{display:grid;grid-template-columns:1fr;gap:34px;padding:54px 0 8px;}
  @media (min-width:820px){.f-grid{grid-template-columns:1.6fr 1fr 1fr;gap:44px;}}
  .f-brand .brand-mark{--pr-a:#fff;--pr-b:#fff;}
  .f-brand .brand-name{color:#fff;}
  .f-brand .brand-name b{color:var(--amber);} /* na navy plna brand amber */
  .f-brand .brand-tag{color:#8a93aa;}
  .f-brand p{font-size:13.5px;color:#7d8598;margin-top:14px;max-width:340px;}
  .f-col h4{
    font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8892ab;
    margin-bottom:14px;
  }
  .f-col ul{list-style:none;margin:0;padding:0;display:grid;gap:9px;}
  .f-col a{color:#c4cad9;text-decoration:none;font-size:14.5px;}
  .f-col a:hover{color:#fff;}
  .f-col li{font-size:14.5px;}
  .f-bar{
    border-top:1px solid rgba(255,255,255,.08);margin-top:40px;padding:20px 0 26px;
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
    font-size:12.5px;color:#8892ab;
  }

  /* ============ mobile action bar ============ */
  .actionbar{
    position:fixed;left:0;right:0;bottom:0;z-index:90;
    display:grid;grid-template-columns:1fr 1fr;gap:10px;
    padding:10px 12px calc(10px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.97);
    -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
    border-top:1px solid var(--line);
    box-shadow:0 -8px 24px rgba(10,17,32,.1);
  }
  @media (min-width:980px){.actionbar{display:none;}}
  .ab-btn{
    height:52px;border-radius:13px;text-decoration:none;
    display:flex;align-items:center;justify-content:center;gap:9px;
    font-size:15.5px;font-weight:800;
  }
  .ab-btn svg{width:20px;height:20px;flex:0 0 auto;}
  .ab-btn:active{transform:translateY(1px);}
  .ab-call{background:#000;color:#fff;}
  .ab-wa{background:var(--amber);color:var(--amber-ink);box-shadow:0 3px 12px rgba(253,176,53,.4);}

  /* ============ reveal ============ */
  [data-reveal]{transition:opacity .6s ease, transform .6s ease;}
  [data-reveal].pre{opacity:0;transform:translateY(14px);}
  [data-reveal].in{opacity:1;transform:none;}

  /* ============ realne fotky (Sanity) v galerii + lightboxu ============ */
  .gal-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
  .gal-photo{background:var(--navy);}
  .lb-ph.lb-photo{background:#0b1120;overflow:hidden;}
  .lb-ph.lb-photo img{width:100%;height:100%;object-fit:contain;border-radius:16px;}

  /* honeypot - mimo obrazovku, pro roboty stale "viditelny" */
  .hp-field{position:absolute !important;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;}

  /* ============ reference - prazdny stav (nez dorazi prvni reference) ============ */
  .refs-single{grid-template-columns:1fr !important;}
  .ref-empty{
    flex-direction:row;align-items:center;gap:18px;
    max-width:640px;justify-self:center;width:100%;
  }
  .ref-empty-ico{
    width:46px;height:46px;border-radius:50%;flex:0 0 auto;
    background:var(--amber);color:var(--amber-ink);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 3px 10px rgba(253,176,53,.35);
  }
  .ref-empty-ico svg{width:22px;height:22px;}
  .ref-empty p{font-size:15px;color:var(--muted);line-height:1.6;}
  .ref-empty p b{color:#000;}
