/* AEROFIT — Premium Editorial Stylesheet
   Design philosophy: Quiet luxury. Hand-crafted papír feel. Restrained gold.
   Typografie nese tíhu, gradient je vyhrazený moment, hairlines místo stínů.
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* === Soft warm ivory — jemně do žluta === */
  --paper:#fcfaf3;            /* primary — whisper of warmth */
  --paper-2:#f6f1e2;          /* sekce-alt — gentle ivory */
  --paper-3:#ece4cc;          /* deepest, jen mírně do béžova */
  --w:#fffefa;                /* warm white */

  /* === Inks (warm dark) === */
  --ink:#1a1612;              /* primary ink */
  --ink-2:#2c2520;            /* secondary */
  --ash-d:#3d3833;            /* dark warm gray */
  --ash:#6b6258;              /* warm gray for body text */
  --ash-l:#a8a094;            /* lighter warm gray */
  --line:rgba(26,22,18,.08);  /* hairline borders */
  --line-2:rgba(26,22,18,.16);

  /* === Gold spectrum — luminous, less brown === */
  --gold:#cfa14a;             /* luminous warm gold */
  --gold-l:#ebc977;           /* bright champagne */
  --gold-d:#8a6620;           /* warm amber-gold (méně espresso) */
  --gold-deep:#5c4220;        /* deepest accent */
  --champagne:#f0d999;        /* luminous pale champagne */
  --brass:#a8843a;
  --gold-tint:rgba(207,161,74,.07);
  --gold-tint-2:rgba(207,161,74,.14);
  /* === Akcent — Kodak yellow, používán velice střídmě === */
  --kodak:#ffcc00;

  /* === Metallic bronze spectrum — používán na horní liště === */
  --bronze-deep:#3d2a13;        /* hluboký bronz — okraje gradientu */
  --bronze:#6b4a1f;             /* mid bronze */
  --bronze-m:#a07a36;            /* warm middle */
  --bronze-l:#cda05a;           /* highlight peak */
  --bronze-shine:#ecc783;       /* brilantní špička */
  /* Metalický gradient s dvojitým „sheenem" — imituje broušený bronz */
  --grad-bronze:linear-gradient(115deg,
    var(--bronze-deep) 0%,
    var(--bronze) 18%,
    var(--bronze-m) 45%,
    var(--bronze-l) 75%,
    var(--bronze-shine) 100%);
  --grad-bronze-soft:linear-gradient(180deg,
    rgba(160,122,54,.92) 0%,
    rgba(107,74,31,.94) 100%);

  /* === Radii — restrained === */
  --r:8px;
  --rl:14px;
  --rx:24px;
  --rxl:36px;

  /* === Shadow — minimal, editorial === */
  --sh:0 1px 2px rgba(26,22,18,.04),0 4px 16px rgba(26,22,18,.04);
  --sh-l:0 8px 32px rgba(26,22,18,.08),0 24px 60px rgba(26,22,18,.06);
  --sh-img:0 16px 48px rgba(26,22,18,.14),0 32px 80px rgba(26,22,18,.08);

  /* === Transition === */
  --tr:.45s cubic-bezier(.22,.61,.36,1);
  --tr-fast:.25s cubic-bezier(.22,.61,.36,1);

  /* === Signature gradient — used SPARINGLY === */
  --grad-gold:linear-gradient(115deg,var(--gold-d) 0%,var(--gold) 38%,var(--gold-l) 72%,var(--champagne) 100%);

}

html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  font-feature-settings:"kern" 1,"liga" 1,"calt" 1;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  position:relative;
}

/* Saténový gradient — velmi jemný sheen */
body::before{
  content:'';position:fixed;inset:0;
  background:
    radial-gradient(ellipse 100% 70% at 50% 0%, rgba(240,217,153,.10), transparent 65%),
    radial-gradient(ellipse 70% 50% at 100% 50%, rgba(235,201,119,.05), transparent 65%),
    radial-gradient(ellipse 70% 50% at 0% 100%, rgba(207,161,74,.03), transparent 65%);
  pointer-events:none;
  z-index:1;
}
body > *{position:relative;z-index:2}

h1,h2,h3,h4{
  font-family:'Playfair Display',Georgia,serif;
  font-weight:700;
  line-height:1.06;
  letter-spacing:-.025em;
  color:var(--ink);
}

h1{font-weight:800}
h2{font-weight:700}

a{color:var(--ink);text-decoration:none;transition:color var(--tr-fast)}
a:hover{color:var(--gold-d)}

img{max-width:100%;height:auto;display:block}

.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,4vw,72px)}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 clamp(20px,4vw,72px)}

/* === Skip link === */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--ink);color:var(--w);
  padding:14px 22px;border-radius:0 0 var(--r) 0;
  font-weight:600;z-index:9999;letter-spacing:.04em;
}
.skip-link:focus{left:0;color:var(--w)}

/* === Focus styles === */
:focus-visible{outline:2px solid var(--kodak);outline-offset:3px;border-radius:4px}

/* === EYEBROW (small caps label) === */
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'DM Sans',sans-serif;
  font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.22em;
  color:var(--gold-d);
}
.eyebrow::before{
  content:'';width:24px;height:1px;
  background:var(--gold);
}
/* Backward-compat: .badge is alias for .eyebrow with default margin */
.badge{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'DM Sans',sans-serif;
  font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.22em;
  color:var(--gold-d);
  margin-bottom:20px;
  background:transparent;padding:0;border-radius:0;
}
.badge::before{
  content:'';width:24px;height:1px;
  background:var(--gold);
}
.eyebrow-num{
  font-family:'Playfair Display',serif;
  font-style:italic;font-weight:400;
  color:var(--gold);font-size:.86rem;
  letter-spacing:0;text-transform:none;
  margin-right:6px;
}

/* === NAV === */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--grad-bronze);
  background-size:200% 200%;
  background-position:50% 50%;
  border-bottom:1px solid rgba(236,199,131,.55);
  box-shadow:
    0 1px 0 rgba(236,199,131,.35) inset,
    0 -1px 0 rgba(0,0,0,.18) inset,
    0 4px 16px rgba(61,42,19,.18);
  transition:box-shadow var(--tr-fast),background-position var(--tr);
  position:fixed;
}
.nav::before{
  /* Jemný horizontální „brushed metal" sheen — odsazen doprava, nižší intenzita */
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(100deg,
      rgba(255,255,255,0) 0%,
      rgba(255,255,255,0) 55%,
      rgba(255,255,255,.06) 75%,
      rgba(255,255,255,.10) 82%,
      rgba(255,255,255,.05) 90%,
      rgba(255,255,255,0) 100%);
  mix-blend-mode:overlay;
  pointer-events:none;
}
.nav::after{
  /* Zlatá hairline na spodní hraně */
  content:'';position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--bronze-shine) 20%,
    var(--bronze-l) 50%,
    var(--bronze-shine) 80%,
    transparent 100%);
  opacity:.7;pointer-events:none;
}
.nav.scrolled{
  box-shadow:
    0 1px 0 rgba(236,199,131,.45) inset,
    0 -1px 0 rgba(0,0,0,.22) inset,
    0 6px 24px rgba(61,42,19,.28);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:84px;position:relative;z-index:1}

.brand{display:flex;align-items:center;text-decoration:none;color:var(--w)}
.brand-logo{
  height:48px;width:48px;display:block;
  transition:opacity var(--tr-fast),transform var(--tr-fast);
  /* Bílé/krémové logo na bronzu — krásný kontrast */
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.25)) drop-shadow(0 0 1px rgba(236,199,131,.4));
}
.brand:hover .brand-logo{opacity:.92;transform:scale(1.04)}

.nav-r{display:flex;align-items:center;gap:32px}
.nl{display:flex;gap:30px;list-style:none}
.nl li:not(:first-child){margin-left:30px}
.nl a{
  color:#fbeed1;
  font-size:.85rem;font-weight:500;
  letter-spacing:.04em;
  position:relative;
  padding:6px 0;
  text-shadow:0 1px 1px rgba(0,0,0,.2);
}
.nl a::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:1px;
  background:var(--bronze-shine);
  box-shadow:0 0 6px rgba(236,199,131,.6);
  transition:width var(--tr);
}
.nl a:hover{color:#fff7e0}
.nl a:hover::after,.nl a[aria-current="page"]::after{width:100%}
.nl a[aria-current="page"]{color:#fff7e0;font-weight:600}

.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(20,14,7,.78);color:#fbeed1;
  padding:11px 22px;border-radius:100px;
  font-size:.82rem;font-weight:500;
  letter-spacing:.04em;
  position:relative;overflow:hidden;
  border:1px solid rgba(236,199,131,.4);
  transition:var(--tr-fast);
  text-shadow:0 1px 1px rgba(0,0,0,.3);
}
.nav-cta::after{content:'→';transition:transform var(--tr-fast)}
.nav-cta:hover{color:#fff;background:rgba(0,0,0,.92);border-color:var(--bronze-shine)}
.nav-cta:hover::after{transform:translateX(3px)}

.mb{display:none;background:none;border:none;cursor:pointer;padding:6px;color:#fbeed1}

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 36px;border-radius:100px;
  font-family:inherit;font-size:.88rem;font-weight:500;
  letter-spacing:.04em;
  text-decoration:none;cursor:pointer;border:none;
  transition:var(--tr-fast);position:relative;
}
.btn-p{
  background:var(--ink);color:var(--w);
}
.btn-p:hover{background:var(--gold-d);color:var(--w);transform:translateY(-1px)}
.btn-o{
  background:transparent;color:var(--ink);
  border:1px solid var(--ink);
}
.btn-o:hover{background:var(--ink);color:var(--w)}

/* Inline link with arrow — premium pattern */
.btn-link{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.88rem;font-weight:500;
  letter-spacing:.04em;
  color:var(--ink);
  padding:0 0 8px;
  position:relative;
  transition:var(--tr-fast);
}
.btn-link::before{
  content:'';position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--line-2);
  transition:background var(--tr-fast);
}
.btn-link::after{content:'→';transition:transform var(--tr-fast)}
.btn-link:hover{color:var(--gold-d)}
.btn-link:hover::before{background:var(--gold)}
.btn-link:hover::after{transform:translateX(4px)}

/* === HERO === */
.hero{
  min-height:680px;display:flex;align-items:center;
  padding:140px 0 90px;position:relative;
  background:var(--paper);
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;
  top:50%;right:-10%;transform:translateY(-50%);
  width:55vw;height:55vw;max-width:760px;max-height:760px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(240,217,153,.28) 0%,rgba(235,201,119,.10) 40%,transparent 70%);
  pointer-events:none;
}
.hero .wrap{
  display:grid;grid-template-columns:1.05fr .95fr;
  gap:80px;align-items:center;position:relative;
}

.hero-eyebrow{margin-bottom:36px}

.hero h1{
  font-size:clamp(3rem,7vw,6rem);
  margin-bottom:36px;
  letter-spacing:-.04em;
  line-height:1.02;
}
.hero h1 em{
  font-style:italic;font-weight:400;
  background:linear-gradient(105deg,var(--gold-d) 0%,var(--gold) 35%,var(--gold-l) 70%,var(--champagne) 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  /* Fallback if background-clip not supported */
}
.hero-d{
  font-size:clamp(1.05rem,1.2vw,1.18rem);
  color:var(--ash);
  max-width:480px;margin:0 0 44px;
  line-height:1.7;
}
.hero-btns{display:flex;gap:24px;align-items:center;flex-wrap:wrap}

.hero-img{
  position:relative;
  aspect-ratio:4/5;min-height:560px;max-height:660px;
  border-radius:var(--rxl);
  overflow:hidden;
  box-shadow:var(--sh-img);
}
.hero-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.02) contrast(1.04) brightness(1.02);
}
.hero-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(240,217,153,.14) 0%,transparent 50%,rgba(28,23,20,.06) 100%);
  pointer-events:none;
}

/* Hero corner mark — premium signature */
.hero-mark{
  position:absolute;bottom:24px;left:24px;
  background:rgba(247,242,230,.92);
  backdrop-filter:blur(8px);
  border:1px solid var(--line);
  border-radius:100px;
  padding:8px 16px;
  font-size:.72rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);
  display:flex;align-items:center;gap:8px;
}
.hero-mark::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--kodak);
}

/* === SECTIONS === */
.sec{padding:clamp(90px,11vw,160px) 0;position:relative}
.sec-alt{background:var(--paper-2)}
.sec-deep{background:var(--paper-3)}
.sec-dark{background:var(--ink);color:#e8dec8}
.sec-dark h1,.sec-dark h2,.sec-dark h3{color:var(--w)}

.sec-head{margin-bottom:64px;max-width:760px}
.sec-head .eyebrow{margin-bottom:24px}
.sec h2{
  font-size:clamp(2.2rem,4.6vw,3.8rem);
  letter-spacing:-.03em;
  line-height:1.04;
}
.sec h2 em{
  font-style:italic;font-weight:400;
  color:var(--gold-d);
}
.sec-sub{
  font-size:clamp(1.05rem,1.18vw,1.15rem);
  color:var(--ash);max-width:600px;
  margin-top:24px;line-height:1.7;
}

/* Section divider — premium touch */
.divider{
  display:flex;align-items:center;gap:14px;
  margin:80px auto;max-width:200px;
  justify-content:center;
}
.divider::before,.divider::after{
  content:'';flex:1;height:1px;background:var(--line-2);
}
.divider-mark{
  width:7px;height:7px;border-radius:50%;
  background:var(--kodak);
  box-shadow:0 0 0 3px rgba(255,204,0,.15);
}

/* === BREADCRUMB === */
.breadcrumb{
  padding:104px 0 0;font-size:.78rem;color:var(--ash);
  letter-spacing:.04em;
}
.breadcrumb .wrap{padding-top:32px;padding-bottom:8px}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.breadcrumb li:not(:last-child)::after{content:'·';margin-left:10px;color:var(--ash-l)}
.breadcrumb a{color:var(--ash)}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb [aria-current="page"]{color:var(--ink);font-weight:500}

/* === CARDS === */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.cards-2{display:grid;grid-template-columns:repeat(2,1fr);gap:40px}

.card{
  background:transparent;
  border-top:1px solid var(--ink);
  padding:48px 0 8px;
  transition:var(--tr);
  position:relative;
}
.card-num{
  font-family:'Playfair Display',serif;
  font-style:italic;font-weight:400;
  color:var(--gold);font-size:2.2rem;
  line-height:1;letter-spacing:-.02em;
  margin-bottom:32px;display:block;
}
.card:hover{border-top-color:var(--gold)}
.card:hover .card-num{color:var(--gold-d)}
.card h3{
  font-size:1.4rem;margin-bottom:14px;
  font-family:'Playfair Display',serif;
  font-weight:700;line-height:1.18;
  letter-spacing:-.015em;
}
.card p{color:var(--ash);font-size:.95rem;line-height:1.7}

.card-icon{
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
  color:var(--gold-d);
}
.card-icon svg{width:32px;height:32px;stroke-width:1.4}

/* === SERVICE TILE === */
.service-tile{
  display:flex;flex-direction:column;
  background:var(--w);
  border:1px solid var(--line);
  border-radius:var(--rl);overflow:hidden;
  transition:var(--tr);
  position:relative;
}
.service-tile:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:var(--sh-l);
}
.service-tile-img{
  aspect-ratio:5/4;min-height:280px;overflow:hidden;
  background:linear-gradient(135deg,var(--paper) 0%,var(--paper-2) 100%);position:relative;
}
.service-tile-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(26,22,18,.04));
  pointer-events:none;
}
.service-tile-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.22,.61,.36,1);
  filter:saturate(1.04) brightness(1.02);
}
.service-tile:hover .service-tile-img img{transform:scale(1.06)}

.service-tile-body{padding:36px 36px 32px;display:flex;flex-direction:column;flex:1}
.service-tile h3{
  font-size:1.6rem;margin-bottom:14px;
  font-family:'Playfair Display',serif;
  font-weight:700;letter-spacing:-.018em;
  line-height:1.16;
}
.service-tile p{color:var(--ash);font-size:.96rem;line-height:1.68;margin-bottom:28px;flex:1}
.service-tile-link{
  color:var(--ink);font-weight:500;font-size:.82rem;
  display:inline-flex;align-items:center;gap:10px;
  letter-spacing:.06em;text-transform:uppercase;
  padding-top:20px;border-top:1px solid var(--line);
  transition:var(--tr-fast);
}
.service-tile-link::after{content:'→';transition:transform var(--tr-fast)}
.service-tile:hover .service-tile-link{color:var(--gold-d)}
.service-tile:hover .service-tile-link::after{transform:translateX(4px)}

/* === EDITORIAL ROW === */
.edit-row{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
  margin-bottom:clamp(80px,10vw,140px);
}
.edit-row:nth-child(even){direction:rtl}
.edit-row:nth-child(even) > *{direction:ltr}
.edit-img{
  aspect-ratio:5/6;min-height:520px;border-radius:var(--rxl);overflow:hidden;
  box-shadow:var(--sh-img);
  position:relative;
}
.edit-img img{width:100%;height:100%;object-fit:cover;filter:saturate(1.04) contrast(1.04) brightness(1.02)}
.edit-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(140deg,rgba(240,217,153,.12) 0%,transparent 50%);
}
.edit-txt .eyebrow{margin-bottom:20px}
.edit-txt h3{
  font-size:clamp(1.7rem,2.8vw,2.4rem);
  margin-bottom:20px;letter-spacing:-.02em;
  line-height:1.12;
}
.edit-txt p{color:var(--ash);font-size:1.02rem;line-height:1.78;margin-bottom:18px}
.edit-txt .lead{color:var(--ink);font-weight:400;font-size:1.1rem;line-height:1.7;font-family:'Playfair Display',serif;font-style:italic}
.edit-txt .btn-link{margin-top:14px}

/* === STATS === */
.stats{padding:80px 0 88px;background:var(--paper)}
.stats .wrap{
  display:grid;grid-template-columns:repeat(4,1fr);gap:60px;
  border-top:1px solid var(--line-2);
  padding-top:64px;
}
.stat{text-align:left}
.stat-num,.stat-v{
  font-family:'Playfair Display',serif;
  font-size:clamp(3.2rem,5vw,4.8rem);
  font-weight:700;line-height:.96;
  letter-spacing:-.045em;
  color:var(--ink);
  display:block;
  margin-bottom:14px;
}
.stat-num em{
  font-style:italic;font-weight:400;
  background:linear-gradient(115deg,var(--gold-d),var(--gold-l));
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
}
.stat-l{
  font-size:.74rem;color:var(--ash);
  text-transform:uppercase;letter-spacing:.22em;
  font-weight:600;
}

/* === PRICING TABLE === */
.pricing-wrap{overflow-x:auto;margin-top:40px;border:1px solid var(--line);border-radius:var(--rl)}
.pricing-tbl{
  width:100%;border-collapse:collapse;
  background:var(--w);min-width:680px;
  font-feature-settings:"tnum" 1;
}
.pricing-tbl th,.pricing-tbl td{
  padding:18px 24px;text-align:left;font-size:.92rem;
  border-bottom:1px solid var(--line);
}
.pricing-tbl thead th{
  background:var(--ink);color:var(--w);
  font-weight:500;font-size:.74rem;
  text-transform:uppercase;letter-spacing:.14em;
  padding:18px 24px;
}
.pricing-tbl thead th.col-best{
  background:var(--gold-d);color:var(--w);position:relative;
}
.pricing-tbl tbody tr:last-child td{border-bottom:none}
.pricing-tbl tbody tr:hover{background:var(--paper)}
.pricing-tbl .price-svc{font-weight:600;color:var(--ink);font-family:'Playfair Display',serif;font-size:1rem}
.pricing-tbl .price-base{color:var(--ash)}
.pricing-tbl .price-best{color:var(--gold-d);font-weight:600}

/* === SCHEDULE TABLE === */
.schedule-wrap{overflow-x:auto;margin-top:32px;border:1px solid var(--line);border-radius:var(--rl);background:var(--w);position:relative;-webkit-overflow-scrolling:touch}
.schedule-tbl{
  width:100%;border-collapse:collapse;
  min-width:760px;font-size:.86rem;
}
/* Subtle scroll-hint na pravém okraji když je content delší než viewport */
@media(max-width:768px){
  .schedule-wrap{
    background:
      linear-gradient(to right,var(--w) 30%,rgba(255,254,250,0)),
      linear-gradient(to right,rgba(255,254,250,0),var(--w) 70%) 100% 0,
      linear-gradient(to right,rgba(26,22,18,.08),rgba(26,22,18,0)),
      linear-gradient(to left,rgba(26,22,18,.08),rgba(26,22,18,0)) 100% 0;
    background-repeat:no-repeat;
    background-size:60px 100%,60px 100%,18px 100%,18px 100%;
    background-attachment:local,local,scroll,scroll;
  }
  .schedule-wrap::before{
    content:'← táhnutím zobrazíte celý rozpis →';
    display:block;text-align:center;
    font-size:.72rem;color:var(--ash);
    padding:8px 16px;
    border-bottom:1px solid var(--line);
    background:var(--paper);
    letter-spacing:.06em;
    text-transform:uppercase;font-weight:500;
  }
}
.schedule-tbl th,.schedule-tbl td{
  padding:14px 18px;text-align:left;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
}
.schedule-tbl tr td:last-child,.schedule-tbl tr th:last-child{border-right:0}
.schedule-tbl tbody tr:last-child td,.schedule-tbl tbody tr:last-child th{border-bottom:0}
.schedule-tbl thead th{
  background:var(--paper);color:var(--ink);
  font-weight:600;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.14em;
}
.schedule-tbl tbody th{
  background:transparent;font-weight:500;
  width:128px;font-family:'Playfair Display',serif;
  font-size:.94rem;
}
.schedule-tbl .lesson{
  display:block;line-height:1.3;
  color:var(--ink);font-weight:500;
}
.schedule-tbl .lesson em{
  font-style:normal;color:var(--ash);
  font-size:.78rem;display:block;font-weight:400;margin-top:2px;
}
.schedule-tbl .lesson-empty{color:var(--ash-l);font-size:.78rem}

/* === HIGHLIGHT BOX === */
.highlight-box{
  background:var(--w);
  border:1px solid var(--gold);
  border-radius:var(--rl);
  padding:32px 36px;
  margin:40px 0;
  position:relative;
}
.highlight-box::before{
  content:'';position:absolute;top:0;left:0;width:5px;height:100%;
  background:var(--grad-gold);
  border-radius:var(--rl) 0 0 var(--rl);
}
.highlight-box h4{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1.2rem;color:var(--ink);
  margin-bottom:10px;letter-spacing:-.01em;
}
.highlight-box p{color:var(--ash);font-size:.96rem;line-height:1.75}

.note-box{
  background:var(--paper);
  border-left:2px solid var(--gold);
  padding:20px 26px;
  border-radius:0 8px 8px 0;
  margin:28px 0;
  font-size:.92rem;color:var(--ash-d);line-height:1.7;
}

/* === CONTENT LIST === */
.content-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin:20px 0}
.content-list li{
  padding:10px 0 10px 28px;position:relative;
  font-size:.96rem;color:var(--ash-d);line-height:1.65;
  border-bottom:1px solid var(--line);
}
.content-list li:last-child{border-bottom:none}
.content-list li::before{
  content:'';position:absolute;left:0;top:18px;
  width:14px;height:1px;background:var(--gold);
}

/* === CTA === */
.cta{padding:clamp(80px,10vw,120px) 0}
.cta-card{
  max-width:1080px;margin:0 auto;
  background:linear-gradient(150deg,#22181a 0%,var(--ink) 50%,#1d1410 100%);
  border-radius:var(--rxl);
  padding:clamp(80px,11vw,130px) clamp(40px,6vw,100px);
  text-align:center;position:relative;overflow:hidden;
  box-shadow:0 32px 80px rgba(26,22,18,.18);
}
.cta-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:var(--grad-gold);
}
.cta-card::after{
  content:'';position:absolute;
  bottom:-280px;right:-260px;
  width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,174,108,.16),transparent 70%);
}
.cta-watermark{
  position:absolute;
  top:50%;left:-60px;
  transform:translateY(-50%);
  width:340px;height:340px;
  opacity:.05;pointer-events:none;
  z-index:0;
}
.cta-watermark img{width:100%;height:100%;display:block}
.cta-card .corner-mark{
  position:absolute;top:32px;right:36px;
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Playfair Display',serif;
  font-style:italic;font-size:.88rem;
  color:var(--gold-l);
  z-index:2;
}
.cta-card .corner-mark::before{
  content:'';width:24px;height:1px;background:var(--gold);
}
.cta-inner{position:relative;z-index:1}
.cta-eyebrow{
  color:var(--champagne);
  margin-bottom:28px;
}
.cta-eyebrow::before{background:var(--gold-l)}
.cta h2{
  color:var(--w);
  font-size:clamp(2rem,4.4vw,3.2rem);
  margin-bottom:24px;letter-spacing:-.025em;
  line-height:1.08;
}
.cta h2 em{font-style:italic;color:var(--gold-l);font-weight:400}
.cta-sub{
  color:rgba(255,253,245,.74);font-size:1.05rem;
  margin:0 auto 44px;max-width:540px;line-height:1.7;
}
.cta-btns{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;align-items:center}
.cta .btn-p{background:var(--w);color:var(--ink)}
.cta .btn-p:hover{background:var(--gold-l);color:var(--ink)}
.cta .btn-o{
  background:transparent;
  color:var(--w);
  border:1px solid rgba(255,255,255,.55);
}
.cta .btn-o:hover{
  background:var(--w);
  color:var(--ink);
  border-color:var(--w);
}
.cta .btn-link{
  color:var(--w);border-bottom-color:rgba(255,255,255,.2);
}
.cta .btn-link:hover{
  color:var(--champagne);border-bottom-color:var(--champagne);
}

/* === CONTACT === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:24px}
.contact-item{display:flex;align-items:flex-start;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}
.contact-item:last-child{border-bottom:none}
.contact-item svg{stroke:var(--gold-d);flex-shrink:0;margin-top:3px;width:20px;height:20px;stroke-width:1.5}
.contact-item strong{display:block;font-size:.78rem;margin-bottom:4px;color:var(--ash);text-transform:uppercase;letter-spacing:.16em;font-weight:500}
.contact-item span,.contact-item a{font-size:1rem;color:var(--ink);font-weight:500}
.contact-item a:hover{color:var(--gold-d)}

.hours-table{
  background:var(--w);
  border:1px solid var(--line);
  border-radius:var(--rl);
  padding:32px;margin-top:8px;
}
.hours-table h4{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1.1rem;margin-bottom:18px;letter-spacing:-.01em;
}
.hours-row{
  display:flex;justify-content:space-between;
  padding:11px 0;font-size:.9rem;
  border-bottom:1px solid var(--line);
}
.hours-row:last-child{border-bottom:0}
.hours-row .day{color:var(--ash);font-weight:500}
.hours-row .time{color:var(--ink);font-weight:600;font-feature-settings:"tnum" 1}
.hours-row .closed{color:var(--ash-l);font-style:italic;font-family:'Playfair Display',serif}

.contact-form{display:flex;flex-direction:column;gap:18px;background:var(--w);padding:36px;border:1px solid var(--line);border-radius:var(--rl)}
.fg{display:flex;flex-direction:column;gap:8px}
.fg label{
  font-size:.74rem;font-weight:600;color:var(--ash);
  text-transform:uppercase;letter-spacing:.14em;
}
.fg input,.fg textarea,.fg select{
  padding:14px 16px;border:1px solid var(--line-2);
  border-radius:var(--r);font-family:inherit;font-size:.94rem;
  transition:var(--tr-fast);background:var(--paper);color:var(--ink);
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  outline:none;border-color:var(--gold);background:var(--w);
  box-shadow:0 0 0 3px var(--gold-tint);
}
.fg textarea{resize:vertical;min-height:120px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* === MAP === */
.map-frame{
  border-radius:var(--rl);overflow:hidden;
  border:1px solid var(--line);
}
.map-frame iframe{display:block;width:100%;border:0;filter:saturate(.85) contrast(1.05)}

/* === FOOTER === */
.ft{
  background:var(--ink);
  padding:88px 0 32px;color:#a89a86;
  position:relative;
}
.ft::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:var(--grad-gold);
}
.ft-brand-logo{height:42px;width:auto;display:block;margin-bottom:18px}
.ft-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;
  padding-bottom:56px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.ft-brand p{font-size:.92rem;max-width:340px;line-height:1.75;margin-top:4px;color:#a89a86}
.ft-col h4{
  color:var(--w);font-size:.74rem;
  font-family:'DM Sans',sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  margin-bottom:24px;
}
.ft-col a,.ft-col span{
  display:block;color:#a89a86;
  font-size:.9rem;padding:6px 0;
  transition:color var(--tr-fast);
}
.ft-col a:hover{color:var(--champagne)}
.ft-bot{
  padding-top:32px;font-size:.78rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  color:#7a6e5e;letter-spacing:.04em;
}

/* === Hero badge — refined === */
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;
  background:var(--w);
  border:1px solid var(--line-2);
  border-radius:100px;
  font-size:.74rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);
  margin-bottom:32px;
}
.hero-badge::before{
  content:'';width:7px;height:7px;border-radius:50%;
  background:var(--kodak);
  box-shadow:0 0 0 2px rgba(255,204,0,.18);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.45;transform:scale(.85)}
}

/* === FAQ === */
.faq-list{max-width:840px}
.faq-item{border-bottom:1px solid var(--line-2)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:28px 0;cursor:pointer;
  font-family:inherit;font-size:1.05rem;font-weight:500;
  text-align:left;background:none;border:none;color:var(--ink);
  gap:16px;
  letter-spacing:-.005em;
}
.faq-q svg{flex-shrink:0;transition:transform .3s;color:var(--gold)}
.faq-item[open] .faq-q svg{transform:rotate(45deg)}
.faq-a{padding:0 0 28px;color:var(--ash);font-size:.96rem;line-height:1.78}

/* === FADE === Visible by default, JS hides them initially via .js-fade-init */
.fade-in{transition:opacity .9s ease,transform .9s cubic-bezier(.22,.61,.36,1)}
.fade-in.js-fade-init{opacity:0;transform:translateY(28px)}
.fade-in.visible{opacity:1;transform:none}

/* === PROSE === */
.prose h2{font-size:clamp(1.7rem,3vw,2.4rem);margin:56px 0 22px;letter-spacing:-.02em}
.prose h3{font-size:clamp(1.25rem,2vw,1.55rem);margin:36px 0 14px;font-family:'Playfair Display',serif;font-weight:700;letter-spacing:-.015em}
.prose p{margin-bottom:18px;color:var(--ash-d);font-size:1.02rem;line-height:1.78}
.prose strong{color:var(--ink);font-weight:600}
.prose ul{margin:18px 0 22px 0;padding-left:24px}
.prose ul li{margin-bottom:10px;color:var(--ash-d);line-height:1.7}

/* === ACTION PACKAGES (akční balíčky) === */
.action-pkgs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  margin-top:40px;align-items:stretch;
}
.action-pkg{
  background:var(--w);
  border:1px solid var(--line);
  border-radius:var(--rl);
  padding:36px 32px 32px;
  position:relative;display:flex;flex-direction:column;
  transition:var(--tr);
}
.action-pkg:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:var(--sh-l);
}
.action-pkg.featured{
  border:1px solid var(--gold);
  background:linear-gradient(180deg,var(--w) 0%,#fffdf2 100%);
  box-shadow:0 12px 36px rgba(207,161,74,.12);
}
.action-pkg.featured::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-gold);
  border-radius:var(--rl) var(--rl) 0 0;
}
.action-pkg .pkg-tag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:var(--bronze-shine);
  padding:5px 14px;border-radius:100px;
  font-size:.66rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  white-space:nowrap;
}
.action-pkg.featured .pkg-tag{
  background:var(--grad-bronze);color:#fff7e0;
  border:1px solid rgba(236,199,131,.4);
}
.action-pkg h3{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1.55rem;letter-spacing:-.018em;
  margin-bottom:8px;line-height:1.18;
}
.action-pkg h3 em{font-style:italic;font-weight:400;color:var(--gold-d)}
.action-pkg .pkg-sub{
  color:var(--ash);font-size:.88rem;
  margin-bottom:24px;line-height:1.55;
  font-style:italic;font-family:'Playfair Display',serif;
}
.action-pkg .pkg-list{
  list-style:none;margin:0 0 24px;padding:0;
  border-top:1px solid var(--line);
}
.action-pkg .pkg-list li{
  padding:12px 0 12px 26px;position:relative;
  font-size:.92rem;color:var(--ash-d);line-height:1.55;
  border-bottom:1px solid var(--line);
}
.action-pkg .pkg-list li::before{
  content:'';position:absolute;left:0;top:19px;
  width:14px;height:1px;background:var(--gold);
}
.action-pkg .pkg-price{
  margin-top:auto;padding-top:8px;
  display:flex;align-items:baseline;gap:10px;
  margin-bottom:8px;flex-wrap:wrap;
}
.action-pkg .pkg-price-amount{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:2.2rem;color:var(--ink);
  letter-spacing:-.025em;line-height:1;
}
.action-pkg .pkg-price-currency{
  color:var(--ash);font-size:.9rem;font-weight:500;
}
.action-pkg .pkg-price-old{
  color:var(--ash-l);font-size:.94rem;
  text-decoration:line-through;
  font-family:'Playfair Display',serif;
  margin-left:6px;
}
.action-pkg .pkg-saving{
  display:inline-block;
  background:var(--gold-tint);color:var(--gold-d);
  padding:3px 10px;border-radius:100px;
  font-size:.7rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;
  margin-bottom:18px;
}
.action-pkg .btn{width:100%;justify-content:center}

/* === STEP LIST (rozpis.html — Jak rezervaci provést) === */
.step-list{
  list-style:none;padding-left:0;margin-top:24px;
  max-width:780px;
}
.step-item{
  padding:18px 0 18px 70px;
  position:relative;
  border-bottom:1px solid var(--line);
}
.step-item--last{border-bottom:none}
.step-num{
  position:absolute;left:0;top:18px;
  width:48px;height:48px;border-radius:50%;
  background:var(--gold-d);color:var(--w);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-family:'Playfair Display',serif;font-size:1.2rem;
}
.step-h{
  display:block;font-size:1.05rem;margin-bottom:4px;color:var(--ink);
}
.step-d{color:var(--ash);font-size:.94rem;line-height:1.65}

/* === NUMBERED LIST (cenik.html — pravidla permanentek) === */
.num-list{
  list-style:none;padding-left:0;
  max-width:800px;
}
.num-item{
  padding:14px 0 14px 60px;
  position:relative;
  color:var(--ash-d);line-height:1.7;
  border-bottom:1px solid var(--line);
}
.num-item--last{border-bottom:none}
.num-mark{
  position:absolute;left:0;top:14px;
  font-family:'Playfair Display',serif;font-weight:900;
  font-size:1.6rem;color:var(--gold-d);
}

/* === QR PAY === */
.qr-pay{
  background:var(--w);
  border:1px solid var(--line);
  border-radius:var(--rl);
  padding:32px;margin:32px 0;
  display:grid;grid-template-columns:280px 1fr;gap:36px;align-items:start;
}
.qr-pay.compact{
  grid-template-columns:200px 1fr;
  padding:24px;gap:24px;
}
.qr-pay h3{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1.3rem;margin-bottom:8px;letter-spacing:-.015em;
}
.qr-pay p.sub{color:var(--ash);font-size:.92rem;line-height:1.65;margin-bottom:18px}
.qr-canvas{
  width:100%;aspect-ratio:1/1;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:14px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.qr-canvas table{border-collapse:collapse;margin:0 auto;border:0}
.qr-canvas table td{padding:0;border:0;width:auto;height:auto}
.qr-canvas img,.qr-canvas svg,.qr-canvas canvas{max-width:100%;height:auto;display:block}
.qr-canvas .qr-placeholder{
  color:var(--ash-l);font-size:.84rem;
  text-align:center;padding:30px 18px;line-height:1.5;
}
.qr-canvas .qr-placeholder svg{
  width:48px;height:48px;margin:0 auto 12px;opacity:.4;
}
.qr-meta{display:flex;flex-direction:column;gap:14px}
.qr-meta-row{
  display:flex;justify-content:space-between;align-items:baseline;gap:14px;
  padding:8px 0;border-bottom:1px solid var(--line);
  font-size:.92rem;
}
.qr-meta-row:last-child{border-bottom:none}
.qr-meta-row .lbl{color:var(--ash);font-weight:500}
.qr-meta-row .val{
  color:var(--ink);font-weight:600;
  font-feature-settings:"tnum" 1;
  font-family:'Playfair Display',serif;
  text-align:right;word-break:break-word;
}
.qr-name-input{
  display:flex;flex-direction:column;gap:8px;
  margin-top:8px;
}
.qr-name-input label{
  font-size:.74rem;font-weight:600;color:var(--ash);
  text-transform:uppercase;letter-spacing:.14em;
}
.qr-name-input input{
  padding:12px 14px;border:1px solid var(--line-2);
  border-radius:var(--r);font-family:inherit;font-size:.94rem;
  transition:var(--tr-fast);background:var(--paper);color:var(--ink);
}
.qr-name-input input:focus{
  outline:none;border-color:var(--gold);background:var(--w);
  box-shadow:0 0 0 3px var(--gold-tint);
}
.qr-warn{
  font-size:.8rem;color:var(--gold-d);
  background:var(--gold-tint);
  padding:10px 14px;border-radius:var(--r);
  margin-top:8px;line-height:1.5;
  border-left:2px solid var(--gold);
}

/* === KREDIT / PERMANENTKA QR CHOOSER === */
.qr-chooser{
  display:flex;gap:10px;flex-wrap:wrap;
  margin:14px 0 18px;
}
.qr-chooser button{
  padding:10px 18px;border-radius:100px;
  background:var(--paper);color:var(--ink);
  border:1px solid var(--line-2);
  font-family:inherit;font-size:.86rem;font-weight:500;
  cursor:pointer;transition:var(--tr-fast);
  font-feature-settings:"tnum" 1;
}
.qr-chooser button:hover{border-color:var(--gold)}
.qr-chooser button.active{
  background:var(--ink);color:var(--w);
  border-color:var(--ink);
}

/* === SURVEY (anonymní dotazník) === */
.survey-intro{
  background:var(--paper-2);
  border-radius:var(--rl);
  padding:32px 36px;margin-bottom:36px;
  border-left:3px solid var(--gold);
}
.survey-intro h2{font-size:1.6rem;margin-bottom:10px}
.survey-intro p{color:var(--ash-d);line-height:1.7;font-size:.96rem}
.survey-form{display:flex;flex-direction:column;gap:24px;max-width:760px}
.survey-q{
  background:var(--w);
  border:1px solid var(--line);
  border-radius:var(--rl);
  padding:28px 32px;
}
.survey-q legend,.survey-q .q-title{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1.12rem;margin-bottom:16px;
  color:var(--ink);letter-spacing:-.01em;
  padding:0;display:block;
}
.survey-rating{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.survey-rating label{
  display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;
  border:1px solid var(--line-2);border-radius:var(--r);
  cursor:pointer;transition:var(--tr-fast);
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1rem;color:var(--ash);
  background:var(--paper);
  position:relative;
}
.survey-rating label:hover{border-color:var(--gold);color:var(--gold-d)}
.survey-rating input{
  position:absolute;opacity:0;pointer-events:none;
  width:1px;height:1px;
}
.survey-rating input:checked + span{display:none}
.survey-rating label.checked{
  background:var(--ink);color:var(--w);border-color:var(--ink);
}
.survey-rating-label{
  display:flex;justify-content:space-between;
  font-size:.74rem;color:var(--ash);
  text-transform:uppercase;letter-spacing:.14em;
  margin-top:10px;font-weight:500;
}
.survey-q .choices{display:flex;flex-direction:column;gap:4px;margin-top:4px}
.survey-q .choices label{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;cursor:pointer;
  border-radius:var(--r);transition:var(--tr-fast);
  font-size:.95rem;color:var(--ash-d);
}
.survey-q .choices label:hover{background:var(--paper)}
.survey-q .choices input{accent-color:var(--gold-d)}
.survey-q textarea{
  width:100%;padding:14px 16px;
  border:1px solid var(--line-2);border-radius:var(--r);
  font-family:inherit;font-size:.94rem;
  background:var(--paper);color:var(--ink);
  resize:vertical;min-height:100px;
  transition:var(--tr-fast);
}
.survey-q textarea:focus{
  outline:none;border-color:var(--gold);background:var(--w);
  box-shadow:0 0 0 3px var(--gold-tint);
}
.survey-thanks{
  background:var(--ink);color:var(--w);
  padding:48px 36px;border-radius:var(--rl);
  text-align:center;margin-top:24px;
  position:relative;overflow:hidden;
  display:none;
}
.survey-thanks.show{display:block}
.survey-thanks::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:var(--grad-gold);
}
.survey-thanks h3{
  color:var(--w);font-size:1.6rem;margin-bottom:10px;
  font-family:'Playfair Display',serif;
}
.survey-thanks p{color:rgba(255,253,245,.74);font-size:1rem;line-height:1.7}

/* === 24/7 BANNER (door access app) === */
.app-banner{
  background:linear-gradient(135deg,#2c2520 0%,var(--ink) 60%,#1d1410 100%);
  color:#e8dec8;
  border-radius:var(--rl);
  padding:28px 36px;margin:48px 0;
  display:grid;grid-template-columns:auto 1fr auto;gap:28px;
  align-items:center;
  position:relative;overflow:hidden;
  border-top:1px solid var(--bronze-shine);
}
.app-banner::after{
  content:'';position:absolute;
  bottom:-160px;right:-120px;
  width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,174,108,.12),transparent 70%);
  pointer-events:none;
}
.app-banner-icon{
  width:64px;height:64px;flex-shrink:0;
  background:rgba(236,199,131,.12);
  border:1px solid rgba(236,199,131,.3);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  color:var(--bronze-shine);
  position:relative;z-index:1;
}
.app-banner-icon svg{width:32px;height:32px;stroke-width:1.4}
.app-banner-txt{position:relative;z-index:1}
.app-banner-txt .eyebrow{
  color:var(--bronze-shine);margin-bottom:6px;
}
.app-banner-txt .eyebrow::before{background:var(--bronze-l)}
.app-banner-txt h3{
  color:var(--w);font-family:'Playfair Display',serif;
  font-size:1.3rem;margin-bottom:6px;font-weight:700;
  letter-spacing:-.01em;
}
.app-banner-txt p{
  color:rgba(255,253,245,.7);font-size:.92rem;line-height:1.55;margin:0;
}
.app-banner-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bronze-shine);color:#1a1612;
  padding:13px 22px;border-radius:100px;
  font-size:.84rem;font-weight:600;
  letter-spacing:.04em;
  text-decoration:none;
  position:relative;z-index:1;
  transition:var(--tr-fast);
  white-space:nowrap;
  border:none;cursor:pointer;font-family:inherit;
}
.app-banner-btn::after{content:'↓';font-weight:400}
.app-banner-btn:hover{
  background:var(--w);color:var(--ink);
  transform:translateY(-1px);
}

/* === KARIERA POSITION CARDS === */
.career-pos{
  background:var(--w);
  border:1px solid var(--line);
  border-radius:var(--rl);
  padding:36px;margin-bottom:24px;
  display:grid;grid-template-columns:240px 1fr;gap:36px;
  transition:var(--tr);
}
.career-pos:hover{
  border-color:var(--gold);box-shadow:var(--sh-l);
}
.career-pos-side{display:flex;flex-direction:column;gap:18px}
.career-pos-side .eyebrow{margin-bottom:0}
.career-pos h3{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:1.5rem;letter-spacing:-.018em;margin:0;
  line-height:1.18;
}
.career-meta{display:flex;flex-direction:column;gap:6px;font-size:.84rem;color:var(--ash)}
.career-meta strong{
  color:var(--ash-d);font-weight:600;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.14em;display:block;margin-bottom:1px;
}
.career-pos p{color:var(--ash-d);line-height:1.7;font-size:.96rem;margin-bottom:14px}
.career-pos ul.req{
  list-style:none;padding:0;margin:14px 0;
  display:flex;flex-direction:column;gap:8px;
}
.career-pos ul.req li{
  padding-left:22px;position:relative;
  color:var(--ash-d);font-size:.92rem;line-height:1.6;
}
.career-pos ul.req li::before{
  content:'';position:absolute;left:0;top:11px;
  width:12px;height:1px;background:var(--gold);
}

/* === MOBILE MENU — tmavá jednolitá barva jako patička === */
@media(max-width:768px){
  .nl.open{
    background:var(--ink) !important;
    border-top:1px solid rgba(236,199,131,.18) !important;
    border-bottom:1px solid rgba(236,199,131,.12) !important;
    box-shadow:0 16px 40px rgba(0,0,0,.45) !important;
  }
  /* zlatá hairline navrchu jako u footeru */
  .nl.open::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent 0%,var(--gold) 30%,var(--gold-l) 50%,var(--gold) 70%,transparent 100%);
    opacity:.55;pointer-events:none;
  }
  .nl.open a{
    color:#c9bda7;
    text-shadow:none;
    padding:12px 0;
  }
  .nl.open a:hover{color:var(--champagne)}
  .nl.open a[aria-current="page"]{
    color:var(--bronze-shine);
    font-weight:600;
  }
}

/* === RESPONSIVE for new components === */
@media(max-width:900px){
  .action-pkgs{grid-template-columns:1fr;gap:32px}
  .qr-pay,.qr-pay.compact{grid-template-columns:1fr;gap:24px}
  .qr-canvas{max-width:280px;margin:0 auto}
  .career-pos{grid-template-columns:1fr;gap:20px}
  .app-banner{grid-template-columns:auto 1fr;padding:24px}
  .app-banner-btn{grid-column:1/-1;width:100%;justify-content:center;margin-top:6px}
}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .hero{min-height:auto;padding:120px 0 80px}
  .hero .wrap{grid-template-columns:1fr;gap:48px}
  .hero-img{max-height:480px;aspect-ratio:4/3;order:-1;min-height:auto}
  .hero h1{font-size:clamp(2.4rem,5.5vw,3.6rem);margin-bottom:28px}
  .hero-eyebrow{margin-bottom:24px}
  .hero-d{margin:0 0 32px;max-width:600px}
  .cards-3,.cards-4{grid-template-columns:repeat(2,1fr)}
  .edit-row,.edit-row:nth-child(even){grid-template-columns:1fr;direction:ltr;gap:40px}
  .edit-row:nth-child(even) > *{direction:ltr}
  .edit-img{aspect-ratio:5/4}
  .ft-top{grid-template-columns:1fr 1fr;gap:36px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:40px}
}

@media(max-width:768px){
  /* Navigation */
  .nl{display:none}
  .nl.open{
    display:flex;flex-direction:column;
    position:absolute;top:84px;left:0;right:0;
    padding:24px clamp(20px,4vw,72px);
    gap:14px;
  }
  .nav-cta{display:none}
  .mb{display:block;padding:10px;margin:-10px}
  .brand-logo{height:40px;width:40px}

  /* Section spacing */
  .sec{padding:72px 0}
  .sec-head{margin-bottom:48px}
  .sec h2{font-size:clamp(1.9rem,6.8vw,2.6rem)}
  .sec-sub{font-size:1rem}

  /* Layouts */
  .cards-2,.cards-3,.cards-4{grid-template-columns:1fr;gap:36px}
  .frow{grid-template-columns:1fr}
  .hero-btns{gap:14px;width:100%;flex-direction:column;align-items:stretch}
  .hero-btns .btn{width:100%}
  .hero-btns .btn-link{justify-content:center;text-align:center;margin-top:4px}
  .stats{padding:64px 0 72px}
  .stats .wrap{grid-template-columns:1fr;gap:32px;padding-top:48px}
  .stat{text-align:center}
  .stat-num,.stat-v{font-size:clamp(2.6rem,9vw,3.4rem)}

  /* Cards */
  .card{padding:36px 0 6px}
  .card-num{font-size:1.9rem;margin-bottom:24px}
  .card h3{font-size:1.25rem}

  /* CTA */
  .cta{padding-left:clamp(16px,4vw,32px);padding-right:clamp(16px,4vw,32px)}
  .cta-card{padding:64px 28px;border-radius:var(--rx)}
  .cta-card .corner-mark{top:20px;right:20px;font-size:.78rem}
  .cta-watermark{width:240px;height:240px;left:-80px}
  .cta-sub{font-size:.98rem;margin-bottom:32px}
  .cta-btns{flex-direction:column;gap:14px;align-items:stretch;width:100%}
  .cta-btns .btn{width:100%}
  .cta-btns .btn-link{justify-content:center;text-align:center}

  /* Forms */
  .contact-form{padding:24px}

  /* Pricing — horizontal scroll s vizuální indikací */
  .pricing-wrap{position:relative}

  /* Schedule (rozpis) — zachovat horizontální scroll s indikací */
  .schedule-wrap{position:relative}

  /* Footer */
  .ft{padding:64px 0 28px}
  .ft-top{padding-bottom:40px;gap:32px}
  .ft-col h4{margin-bottom:16px}

  /* Map */
  .map-frame iframe{height:360px !important}

  /* Hero mark menší a na svém místě */
  .hero-mark{bottom:16px;left:16px;padding:6px 12px;font-size:.66rem}

  /* Edit rows */
  .edit-img{min-height:auto;aspect-ratio:4/3;border-radius:var(--rx)}
  .edit-row{margin-bottom:56px;gap:32px}
  .edit-txt h3{font-size:clamp(1.5rem,5.5vw,2rem)}
  .edit-txt p{font-size:.96rem;line-height:1.7}
  .edit-txt .lead{font-size:1.04rem}

  /* Service tiles */
  .service-tile-body{padding:26px 24px 24px}
  .service-tile h3{font-size:1.3rem}
  .service-tile p{font-size:.92rem;margin-bottom:20px}

  /* Hours table */
  .hours-table{padding:26px 22px}
  .hours-row{font-size:.88rem;padding:10px 0}
}

@media(max-width:480px){
  .ft-top{grid-template-columns:1fr;gap:36px}
  .btn{padding:14px 28px;font-size:.84rem}
  .hero{padding:104px 0 56px;min-height:auto}
  .sec-head{margin-bottom:40px}

  /* Hero typografie ještě malilinko menší */
  .hero h1{font-size:clamp(2rem,8.5vw,2.6rem);margin-bottom:22px;letter-spacing:-.035em}
  .hero-d{font-size:1rem;margin-bottom:28px}
  .hero-eyebrow{margin-bottom:18px}

  /* Sec typography */
  .sec{padding:64px 0}
  .sec h2{font-size:clamp(1.7rem,7vw,2.2rem);letter-spacing:-.025em}
  .sec-sub{font-size:.96rem;margin-top:18px}

  /* Wrap dýchá */
  .wrap,.wrap-narrow{padding:0 18px}

  /* Cards */
  .card{padding:30px 0 6px}
  .card-icon{width:36px;height:36px;margin-bottom:18px}
  .card-icon svg{width:28px;height:28px}
  .card h3{font-size:1.18rem;margin-bottom:10px}
  .card p{font-size:.92rem}

  /* Action packages */
  .action-pkgs{gap:24px;margin-top:32px}
  .action-pkg{padding:32px 22px 26px}
  .action-pkg h3{font-size:1.4rem}
  .action-pkg .pkg-tag{font-size:.62rem;padding:4px 12px}
  .action-pkg .pkg-price-amount{font-size:1.9rem}
  .action-pkg .pkg-list li{font-size:.88rem;padding:10px 0 10px 22px}
  .action-pkg .pkg-list li::before{top:17px;width:12px}

  /* QR pay */
  .qr-pay,.qr-pay.compact{padding:22px 18px;margin:24px 0;gap:20px}
  .qr-pay h3{font-size:1.15rem}
  .qr-pay p.sub{font-size:.88rem;margin-bottom:14px}
  .qr-canvas{max-width:240px}
  .qr-meta-row{
    flex-direction:column;align-items:flex-start;gap:2px;
    padding:8px 0;
  }
  .qr-meta-row .val{text-align:left;font-size:.94rem}
  .qr-meta-row .lbl{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em}
  .qr-chooser{gap:8px}
  .qr-chooser button{padding:9px 14px;font-size:.82rem}

  /* Survey */
  .survey-intro{padding:24px 22px;border-radius:var(--rl)}
  .survey-intro h2{font-size:1.35rem}
  .survey-intro p{font-size:.92rem}
  .survey-q{padding:22px 20px}
  .survey-q legend,.survey-q .q-title{font-size:1.04rem;margin-bottom:14px;line-height:1.35}
  .survey-rating{gap:6px;justify-content:space-between}
  .survey-rating label{width:44px;height:44px;font-size:.94rem;flex:1}
  .survey-rating-label{font-size:.68rem;letter-spacing:.1em}
  .survey-q .choices label{padding:9px 12px;font-size:.92rem}
  .survey-thanks{padding:36px 24px}
  .survey-thanks h3{font-size:1.35rem}

  /* Career positions */
  .career-pos{padding:26px 22px;margin-bottom:18px;gap:18px}
  .career-pos h3{font-size:1.3rem}
  .career-pos p{font-size:.92rem}
  .career-pos ul.req li{font-size:.88rem;padding-left:20px}

  /* App banner — vertikální stack */
  .app-banner{
    grid-template-columns:1fr !important;
    text-align:center;
    padding:28px 22px;
    gap:18px;
    justify-items:center;
  }
  .app-banner-icon{margin:0 auto}
  .app-banner-txt h3{font-size:1.18rem}
  .app-banner-txt p{font-size:.9rem}
  .app-banner-btn{width:100%;justify-content:center;padding:14px 22px}

  /* CTA */
  .cta-card{padding:48px 22px}
  .cta-watermark{width:200px;height:200px;left:-90px}
  .cta h2{font-size:clamp(1.6rem,6.8vw,2.2rem)}
  .cta-sub{font-size:.94rem;margin-bottom:28px}
  .cta-card .corner-mark{top:14px;right:14px;font-size:.7rem}
  .cta-card .corner-mark::before{width:14px}

  /* Contact */
  .contact-form{padding:22px 18px;gap:16px}
  .hours-table{padding:24px 22px}

  /* Stats */
  .stat-num,.stat-v{font-size:clamp(2.4rem,10vw,3rem)}
  .stat-l{font-size:.68rem;letter-spacing:.16em}

  /* Footer */
  .ft{padding:56px 0 24px}
  .ft-top{gap:32px;padding-bottom:32px}
  .ft-brand p{font-size:.88rem}
  .ft-col a,.ft-col span{font-size:.88rem}
  .ft-bot{font-size:.72rem;text-align:center;justify-content:center}

  /* Map */
  .map-frame iframe{height:320px !important}

  /* Breadcrumb */
  .breadcrumb{padding:14px 0}

  /* Service tiles, content cards */
  .service-tile{border-radius:var(--rl)}

  /* Buttons — better tap target */
  .btn{min-height:46px;padding:13px 24px}

  /* Hero mark */
  .hero-mark{font-size:.62rem;padding:5px 10px;letter-spacing:.14em}

  /* Step list & number list — menší kruhy */
  .step-item{padding:14px 0 14px 56px}
  .step-num{width:40px;height:40px;font-size:1rem;top:14px}
  .step-h{font-size:1rem}
  .step-d{font-size:.9rem}

  .num-item{padding:12px 0 12px 44px;font-size:.94rem}
  .num-mark{font-size:1.35rem;top:12px}
}

/* === PRICING TABLE — přepsat na karty pod 600px === */
@media(max-width:600px){
  .pricing-wrap{
    overflow-x:visible;border:none;background:transparent;
    margin-top:28px;
  }
  .pricing-tbl{
    display:block;background:transparent;min-width:0;border-collapse:separate;
  }
  .pricing-tbl thead{display:none}
  .pricing-tbl tbody{display:block}
  .pricing-tbl tr{
    display:block;
    background:var(--w);
    border:1px solid var(--line);
    border-radius:var(--rl);
    padding:18px 20px;
    margin-bottom:14px;
  }
  .pricing-tbl tr:hover{background:var(--w)}
  .pricing-tbl tbody tr:last-child{margin-bottom:0}
  .pricing-tbl td{
    display:block;
    padding:0;border-bottom:none;
    text-align:left;font-size:.9rem;line-height:1.5;
  }
  /* 1. řádek: služba — velký nadpis */
  .pricing-tbl td.price-svc{
    font-size:1.04rem;font-weight:600;color:var(--ink);
    margin-bottom:6px;padding-bottom:10px;
    border-bottom:1px solid var(--line);
    font-family:'Playfair Display',serif;
  }
  /* 2. řádek: specifikace (Délka, Specifikace) — vlevo nahoře */
  .pricing-tbl td:nth-child(2){
    color:var(--ash);font-size:.82rem;margin-top:10px;
    font-style:italic;font-family:'Playfair Display',serif;
  }
  /* 3+4. řádek: ceny inline */
  .pricing-tbl td.price-base,
  .pricing-tbl td.price-best{
    display:inline-block;
    padding:8px 12px;border-radius:100px;
    font-size:.88rem;font-weight:600;
    margin-top:10px;margin-right:8px;
  }
  .pricing-tbl td.price-base{
    background:var(--paper-2);color:var(--ash-d);
  }
  .pricing-tbl td.price-base::before{
    content:'Karta: ';color:var(--ash);
    font-weight:500;font-size:.78rem;
    text-transform:uppercase;letter-spacing:.1em;
    margin-right:4px;
  }
  .pricing-tbl td.price-best{
    background:var(--gold-tint-2);color:var(--gold-d);
  }
  .pricing-tbl td.price-best::before{
    content:'Hotovost: ';color:var(--gold-d);opacity:.7;
    font-weight:500;font-size:.78rem;
    text-transform:uppercase;letter-spacing:.1em;
    margin-right:4px;
  }
  /* 5. řádek: poznámka */
  .pricing-tbl td:nth-child(5):not(.price-svc):not(.price-base):not(.price-best){
    color:var(--ash);font-size:.84rem;
    margin-top:12px;
    padding-top:10px;
    border-top:1px solid var(--line);
    line-height:1.55;
  }
  /* Tabulky bez 5 sloupců (např. permanentky bez "Poznámka") - obecnější fallback */
  .pricing-tbl td:not(.price-svc):not(.price-base):not(.price-best):empty{display:none}
}

/* === Nejmenší telefony (320–380px) === */
@media(max-width:380px){
  .wrap,.wrap-narrow{padding:0 14px}
  .sec{padding:54px 0}
  .hero{padding:96px 0 48px}
  .hero h1{font-size:1.85rem;line-height:1.06}
  .sec h2{font-size:1.55rem}
  .sec-head{margin-bottom:32px}
  .nav .wrap{height:72px}
  .nl.open{top:72px}
  .brand-logo{height:36px;width:36px}

  /* Cards a paddings */
  .action-pkg{padding:26px 18px 22px}
  .action-pkg h3{font-size:1.25rem}
  .action-pkg .pkg-price-amount{font-size:1.7rem}
  .qr-pay,.qr-pay.compact{padding:18px 14px}
  .survey-q{padding:20px 16px}
  .survey-rating label{width:40px;height:40px;font-size:.88rem}
  .survey-rating{gap:4px}
  .career-pos{padding:22px 18px}
  .cta-card{padding:40px 18px}
  .contact-form{padding:18px 14px}

  /* Pricing card padding */
  .pricing-tbl tr{padding:14px 16px}

  /* Buttons */
  .btn{padding:12px 20px;font-size:.82rem;min-height:44px}

  /* Footer */
  .ft{padding:48px 0 22px}

  /* Step list — ještě menší */
  .step-item{padding:12px 0 12px 48px}
  .step-num{width:36px;height:36px;font-size:.92rem}
  .num-item{padding:10px 0 10px 36px}
  .num-mark{font-size:1.2rem}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  html{scroll-behavior:auto}
}

@media print{
  .nav,.ft,.cta,.hero-img{display:none}
  body{background:#fff;color:#000}
  body::before{display:none}
}
