/* =====================================================================
   SHOPTET GURU — PREMIUM motiv „Midnight Atelier"
   Tmavý, editorial-tech, luxusní. Stejné HTML jako Classic.
   Písma: Space Grotesk (nadpisy) + Fraunces (serif akcenty) + Inter (text).
   Princip škály: reset → velikost cíleně (tokeny --t-*).
   ===================================================================== */

:root {
  /* === 3 ZÁKLADNÍ BARVY (reinterpretace pro tmu) ==================== */
  --c-ink:    #f4f2ee;   /* 1. světlá – text/nadpisy na tmavém         */
  --c-accent: #ff6a3d;   /* 2. akcent – záře, CTA, gradienty           */
  --c-slate:  #8b909b;   /* 3. tlumená – sekundární text               */

  /* RGB složky akcentu – z nich se odvozují všechny záře a poloprůhledné
     plochy. Barevné varianty motivu stačí přepsat jen tyto „akcentní" tokeny. */
  --accent-rgb: 255, 106, 61;

  /* === Tmavé plochy a linky ======================================== */
  --c-bg:      #0a0b0e;
  --c-bg-2:    #0d0f14;
  --c-surface: #121419;
  --c-surface-2:#171a21;
  --c-line:    rgba(255,255,255,.08);
  --c-line-2:  rgba(255,255,255,.15);
  --c-text:    #b4b8c2;
  --c-accent-2:#ffa168;
  --c-accent-soft: rgba(var(--accent-rgb),.12);
  --grad-accent: linear-gradient(120deg, #ff6a3d 0%, #ff9a5a 100%);
  --grad-text:   linear-gradient(120deg, #fff 0%, #cdbcb0 100%);
  --glow-accent: 0 18px 50px rgba(var(--accent-rgb),.30);

  /* === Typografie =================================================== */
  --font:        "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  --font-display:"Space Grotesk", "Inter", sans-serif;
  --font-serif:  "Fraunces", Georgia, "Times New Roman", serif;
  --base: 1.0625rem;
  --lh:   1.72;

  --t-xs:  0.8rem;  --t-sm:  0.92rem; --t-base: 1rem;  --t-md:  1.22rem;
  --t-lg:  1.6rem;  --t-xl:  2.25rem; --t-2xl: 3.1rem; --t-3xl: 4.5rem;

  --container: 1280px;
  --container-narrow: 800px;
  --container-wide: 1680px;
  --radius: 18px;
  --radius-sm: 10px;
  --shadow: 0 2px 8px rgba(0,0,0,.35), 0 24px 70px rgba(0,0,0,.45);
  --shadow-lg: 0 40px 90px rgba(0,0,0,.6);
}

/* ---------------------------------------------------------------------
   RESET
   --------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font); font-size: var(--base); line-height: var(--lh);
  color: var(--c-text); background: var(--c-bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  background-image:
    radial-gradient(1100px 600px at 80% -5%, rgba(var(--accent-rgb),.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(var(--accent-rgb),.06), transparent 55%);
  background-attachment: fixed; background-repeat: no-repeat;
}
h1,h2,h3,h4,h5,h6,p,ul,ol,li,dl,dd,figure,blockquote,table { margin: 0; font-size: 1em; font-weight: 400; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-display); color: var(--c-ink); }
img,svg,video { max-width: 100%; height: auto; display: block; }
a { color: var(--c-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font: inherit; cursor: pointer; }
ul,ol { padding-left: 0; list-style: none; }
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--c-accent); color: #fff; padding: .6rem 1rem; z-index: 100; }
.skip-link:focus { left: 0; }
:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 2px; }
::selection { background: var(--c-accent); color: #0a0b0e; }

/* ---------------------------------------------------------------------
   LAYOUT
   --------------------------------------------------------------------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: clamp(1.25rem,3vw,2rem); }
.container.narrow { max-width: var(--container-narrow); }
.container-wide { width: 95%; max-width: var(--container-wide); margin-inline: auto; padding-inline: clamp(1.25rem,3vw,2rem); }

section { padding-block: clamp(3.25rem,7vw,7rem); position: relative; }
[id] { scroll-margin-top: 100px; }
.section-wash { background: var(--c-bg-2); border-block: 1px solid var(--c-line); }
.section-ink { background: linear-gradient(180deg, var(--c-surface), var(--c-bg)); }
.section-ink a { color: #fff; }

.section-head { max-width: 64ch; margin-bottom: 3.25rem; }
.section-head .eyebrow { margin-bottom: 1.1rem; }
.section-head h2 { margin-top: .25rem; }

.grid { display: grid; gap: 1.85rem; }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }

/* ---------------------------------------------------------------------
   TYPOGRAFIE / SCALE
   --------------------------------------------------------------------- */
.h-display { font-family: var(--font-display); font-size: var(--t-3xl); line-height: 1.02; font-weight: 700; letter-spacing: -.03em; color: var(--c-ink); }
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .h-display { background: var(--grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
}
.h1, h1.page-title { font-family: var(--font-display); font-size: var(--t-2xl); line-height: 1.08; font-weight: 700; letter-spacing: -.025em; color: var(--c-ink); }
.lead { font-size: var(--t-md); color: var(--c-slate); line-height: 1.6; }
.eyebrow { display: inline-flex; align-items: center; gap: .7rem; font-family: var(--font-display); font-size: var(--t-sm);
  letter-spacing: .2em; text-transform: uppercase; color: var(--c-accent); font-weight: 600; line-height: 1; }
.eyebrow::before { content: ""; width: 30px; height: 1px; background: var(--grad-accent); flex: none; }
.muted { color: var(--c-slate); }
.text-sm { font-size: var(--t-sm); }
.accent-text { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--c-accent-2); }
.mark-underline { font-family: var(--font-serif); font-style: italic; color: var(--c-accent-2); }

/* Obsah článků */
.prose { font-size: var(--base); color: var(--c-text); }
.prose > * + * { margin-top: 1.3rem; }
.prose h2 { font-size: var(--t-xl); font-weight: 700; line-height: 1.18; margin-top: 3rem; letter-spacing: -.02em; }
.prose h3 { font-size: var(--t-lg); font-weight: 600; line-height: 1.25; margin-top: 2.1rem; }
.prose h4 { font-size: var(--t-md); font-weight: 600; margin-top: 1.6rem; }
.prose p, .prose li { color: var(--c-text); }
.prose ul, .prose ol { margin-left: 1.15rem; }
.prose ul { list-style: none; }
.prose ul li { position: relative; padding-left: 1.5rem; }
.prose ul li::before { content: ""; position: absolute; left: 0; top: .62em; width: 7px; height: 7px; border-radius: 50%; background: var(--grad-accent); }
.prose ol { list-style: decimal; }
.prose li + li { margin-top: .55rem; }
.prose a { color: var(--c-accent-2); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.prose .btn, .prose .btn:hover { text-decoration: none; }
.prose strong { font-weight: 700; color: var(--c-ink); }
.prose img { border-radius: var(--radius); border: 1px solid var(--c-line); }

.article-figure { margin-block: 2.75rem; }
.article-figure figcaption, .gallery figcaption { font-size: var(--t-sm); color: var(--c-slate); margin-top: .7rem; text-align: center; }

.gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: .9rem; margin-block: 2.75rem; }
.gallery img { border-radius: var(--radius-sm); aspect-ratio: 4/3; object-fit: cover; border: 1px solid var(--c-line); }

.table-wrap { overflow-x: auto; margin-block: 1rem 2.75rem; border: 1px solid var(--c-line); border-radius: var(--radius); background: var(--c-surface); }
.prose table { width: 100%; border-collapse: collapse; font-size: var(--t-sm); }
.table-caption { text-align: left; color: var(--c-slate); font-size: var(--t-sm); margin-top: 2.75rem; margin-bottom: 0; font-family: var(--font-display); letter-spacing: .04em; text-transform: uppercase; }
.table-caption + .table-wrap { margin-top: .7rem; }
.prose th, .prose td { text-align: left; padding: .9rem 1.15rem; border-bottom: 1px solid var(--c-line); }
.prose tbody tr:last-child td { border-bottom: 0; }
.prose thead th { background: rgba(255,255,255,.03); font-weight: 700; font-family: var(--font-display); color: var(--c-ink); }

.prose blockquote { border-left: 2px solid var(--c-accent); padding: .4rem 0 .4rem 1.6rem; font-family: var(--font-serif); font-style: italic;
  font-size: var(--t-lg); line-height: 1.4; color: var(--c-ink); font-weight: 400; }
.prose blockquote cite { display: block; font-family: var(--font); font-style: normal; font-size: var(--t-sm); color: var(--c-slate); margin-top: .7rem; }

.cta-box { background: linear-gradient(135deg, rgba(var(--accent-rgb),.16), rgba(var(--accent-rgb),.04)); border: 1px solid var(--c-line-2);
  border-radius: var(--radius); padding: 2.1rem; display: flex; gap: 1.5rem; align-items: center; justify-content: space-between;
  flex-wrap: wrap; margin-block: 2.75rem; position: relative; overflow: hidden; }
.cta-box::before { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 160% at 0% 0%, rgba(var(--accent-rgb),.18), transparent 55%); pointer-events: none; }
.cta-box p { margin: 0; position: relative; color: var(--c-ink); font-family: var(--font-display); font-size: var(--t-md); font-weight: 500; }
.note { background: var(--c-accent-soft); border-left: 2px solid var(--c-accent); padding: 1.15rem 1.45rem; border-radius: var(--radius-sm); color: var(--c-text); }

/* ---------------------------------------------------------------------
   BUTTONS
   --------------------------------------------------------------------- */
.btn { display: inline-flex; align-items: center; gap: .55rem; background: var(--grad-accent); color: #100a06; font-weight: 600;
  font-family: var(--font-display); padding: .92rem 1.7rem; border-radius: 999px; border: 0; font-size: var(--t-sm);
  transition: transform .12s ease, box-shadow .25s ease; text-decoration: none; box-shadow: var(--glow-accent); }
.btn:hover { transform: translateY(-2px); box-shadow: 0 22px 60px rgba(var(--accent-rgb),.42); text-decoration: none; }
.btn:active { transform: translateY(0); }
.btn-sm { padding: .62rem 1.2rem; }
.btn-ghost { background: transparent; color: var(--c-ink); border: 1px solid var(--c-line-2); box-shadow: none; }
.btn-ghost:hover { border-color: var(--c-accent); color: var(--c-accent-2); box-shadow: none; }
.btn-ink { background: rgba(255,255,255,.06); color: var(--c-ink); border: 1px solid var(--c-line-2); box-shadow: none; }
.btn .ico { width: 18px; height: 18px; }

.link-arrow { font-family: var(--font-display); font-weight: 600; font-size: var(--t-sm); display: inline-flex; align-items: center; gap: .45rem; color: var(--c-accent-2); }
.link-arrow::after { content: "→"; transition: transform .15s ease; }
.link-arrow:hover { text-decoration: none; }
.link-arrow:hover::after { transform: translateX(4px); }

/* ---------------------------------------------------------------------
   HEADER / NAV
   --------------------------------------------------------------------- */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(10,11,14,.72); backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--c-line); }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; min-height: 86px; }
.brand { display: inline-flex; align-items: center; gap: .7rem; font-family: var(--font-display); font-weight: 700; font-size: 1.55rem; letter-spacing: -.02em; color: var(--c-ink); }
.brand:hover { text-decoration: none; }
.brand .brand-icon { width: 42px; height: 42px; border-radius: 12px; background: var(--grad-accent); color: #0a0b0e;
  display: inline-flex; align-items: center; justify-content: center; font-size: 1.4rem; font-weight: 700; flex: none; box-shadow: var(--glow-accent); }
.brand-mark { color: var(--c-ink); }
.brand-mark.accent { color: var(--c-accent); }

.main-nav { display: flex; align-items: center; gap: 2rem; }
.main-nav > ul { display: flex; gap: 1.7rem; align-items: center; }
.main-nav li { position: relative; }
.main-nav > ul > li > a { color: var(--c-text); font-size: var(--t-sm); font-weight: 500; padding-block: .4rem; position: relative; }
.main-nav > ul > li > a::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 1px; background: var(--grad-accent); transition: width .2s ease; }
.main-nav > ul > li > a:hover { text-decoration: none; color: var(--c-ink); }
.main-nav > ul > li > a:hover::after, .main-nav a[aria-current="page"]::after { width: 100%; }
.main-nav a[aria-current="page"] { color: var(--c-accent); }
.main-nav .submenu { position: absolute; top: calc(100% + 12px); left: -.75rem; min-width: 290px; background: var(--c-surface);
  border: 1px solid var(--c-line-2); border-radius: var(--radius); box-shadow: var(--shadow); padding: .6rem;
  opacity: 0; visibility: hidden; transform: translateY(8px); transition: .18s ease; z-index: 60; }
.main-nav .has-children:hover .submenu, .main-nav .has-children:focus-within .submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.main-nav .submenu a { display: block; padding: .65rem .85rem; border-radius: var(--radius-sm); color: var(--c-text); font-size: var(--t-sm); }
.main-nav .submenu a:hover { background: rgba(255,255,255,.05); text-decoration: none; color: var(--c-accent-2); }
.submenu-toggle, .nav-toggle { display: none; background: none; border: 0; }
.nav-toggle { flex-direction: column; gap: 5px; padding: .5rem; }
.nav-toggle span { width: 24px; height: 2px; background: var(--c-ink); display: block; transition: .2s; }

/* ---------------------------------------------------------------------
   HERO
   --------------------------------------------------------------------- */
.hero { padding-block: clamp(2.75rem,5vw,4.5rem) clamp(3.5rem,8vw,6.5rem); overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 4rem; align-items: center; }
.hero .eyebrow { margin-bottom: 1.4rem; }
.hero p.lead { margin-top: 1.6rem; max-width: 50ch; color: var(--c-text); }
.hero-actions { display: flex; gap: 1rem; margin-top: 2.6rem; flex-wrap: wrap; }
.hero-trust { margin-top: 3.25rem; display: flex; gap: 0; flex-wrap: wrap; border-top: 1px solid var(--c-line); padding-top: 1.9rem; }
.hero-trust .stat { padding-right: 2.25rem; margin-right: 2.25rem; border-right: 1px solid var(--c-line); }
.hero-trust .stat:last-child { border-right: 0; margin-right: 0; padding-right: 0; }
.hero-trust .stat strong { font-family: var(--font-serif); font-size: var(--t-xl); font-weight: 600; display: block; line-height: 1; color: var(--c-ink); }
.hero-trust .stat span { font-size: var(--t-sm); color: var(--c-slate); }
.hero-visual { position: relative; aspect-ratio: 1/1; border-radius: 28px; border: 1px solid var(--c-line-2);
  background: linear-gradient(160deg, var(--c-surface-2), var(--c-bg)); display: flex; align-items: center; justify-content: center;
  overflow: hidden; box-shadow: var(--shadow-lg); }
.hero-visual::before { content: ""; position: absolute; inset: 0; background:
  radial-gradient(circle at 30% 25%, rgba(var(--accent-rgb),.4), transparent 55%),
  linear-gradient(0deg, rgba(255,255,255,.02) 1px, transparent 1px) 0 0 / 100% 40px,
  linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px) 0 0 / 40px 100%; }
.hero-visual .hv-brand { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: 2.8rem; color: #fff; letter-spacing: -.02em; }
.hero-visual .hv-brand .accent { color: var(--c-accent); }

/* ---------------------------------------------------------------------
   CARDS
   --------------------------------------------------------------------- */
.card { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius); overflow: hidden;
  display: flex; flex-direction: column; transition: .25s ease; }
.card:hover { transform: translateY(-5px); border-color: var(--c-line-2); box-shadow: var(--shadow); }
.card .card-media { aspect-ratio: 16/10; background: var(--c-bg-2); object-fit: cover; width: 100%; border-bottom: 1px solid var(--c-line); }
.card .card-body { padding: 1.6rem 1.7rem 1.8rem; display: flex; flex-direction: column; gap: .7rem; flex: 1; }
.card .card-cat { font-family: var(--font-display); font-size: var(--t-xs); letter-spacing: .12em; text-transform: uppercase; color: var(--c-accent); font-weight: 600; }
.card h3 { font-size: var(--t-md); font-weight: 600; line-height: 1.3; letter-spacing: -.01em; }
.card h3 a { color: var(--c-ink); }
.card h3 a:hover { color: var(--c-accent-2); text-decoration: none; }
.card .card-perex { color: var(--c-slate); font-size: var(--t-sm); }
.card .card-meta { margin-top: auto; padding-top: .5rem; font-size: var(--t-xs); color: var(--c-slate); font-family: var(--font-display); }

.headline-list { border-top: 1px solid var(--c-line); }
.headline-list li { border-bottom: 1px solid var(--c-line); }
.headline-list a { display: flex; justify-content: space-between; gap: 1.5rem; padding: 1.3rem .5rem; color: var(--c-ink); align-items: baseline; transition: padding .15s ease, background .15s ease; }
.headline-list a:hover { color: var(--c-accent-2); text-decoration: none; padding-left: 1.15rem; background: linear-gradient(90deg, rgba(var(--accent-rgb),.08), transparent); }
.headline-list a > span:first-child { font-family: var(--font-display); font-weight: 500; font-size: var(--t-md); }
.headline-list .hl-cat { font-size: var(--t-xs); color: var(--c-slate); white-space: nowrap; text-transform: uppercase; letter-spacing: .1em; }

.feature { display: flex; flex-direction: column; padding: 2rem; border: 1px solid var(--c-line); border-radius: var(--radius);
  background: var(--c-surface); height: 100%; transition: .25s ease; position: relative; overflow: hidden; }
.feature::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: var(--grad-accent); opacity: 0; transition: opacity .25s ease; }
.feature:hover { transform: translateY(-5px); border-color: var(--c-line-2); box-shadow: var(--shadow); }
.feature:hover::before { opacity: 1; }
.feature .feature-ico { width: 54px; height: 54px; border-radius: 15px; background: var(--c-accent-soft); border: 1px solid var(--c-line-2);
  color: var(--c-accent); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.45rem; font-weight: 700; margin-bottom: 1.3rem; }
.feature h3 { font-size: var(--t-md); font-weight: 600; line-height: 1.2; margin-bottom: .5rem; letter-spacing: -.01em; }
.feature p { color: var(--c-slate); font-size: var(--t-sm); }
.feature .feature-link { margin-top: auto; padding-top: 1.3rem; }
.feature .tag { align-self: flex-start; }
a.feature { color: inherit; text-decoration: none; }
a.feature:hover { text-decoration: none; }

/* ---------------------------------------------------------------------
   PAGE HEADER
   --------------------------------------------------------------------- */
.page-header { padding-block: clamp(2.75rem,5vw,4.25rem); border-bottom: 1px solid var(--c-line); background: var(--c-bg-2); position: relative; overflow: hidden; }
.page-header::before { content: ""; position: absolute; inset: 0; background: radial-gradient(800px 300px at 85% 0%, rgba(var(--accent-rgb),.1), transparent 60%); pointer-events: none; }
.page-header > .container { position: relative; }
.breadcrumbs { font-size: var(--t-sm); color: var(--c-slate); margin-bottom: 1rem; font-family: var(--font-display); }
.breadcrumbs a { color: var(--c-slate); }
.breadcrumbs a:hover { color: var(--c-accent-2); }
.page-header .lead { margin-top: 1rem; max-width: 66ch; }

article.post-detail { padding-block: 3.5rem; }
.post-detail .post-meta { font-size: var(--t-sm); color: var(--c-slate); margin-bottom: 1.5rem; font-family: var(--font-display); }
.post-detail .post-cover { border-radius: var(--radius); margin-bottom: 2.5rem; width: 100%; aspect-ratio: 16/8; object-fit: cover; border: 1px solid var(--c-line); }

/* ---------------------------------------------------------------------
   FORMS
   --------------------------------------------------------------------- */
.form { display: grid; gap: 1.1rem; }
.form-row { display: grid; gap: .4rem; }
.form label { font-size: var(--t-sm); font-weight: 600; font-family: var(--font-display); color: var(--c-ink); }
.form input, .form textarea, .form select { font: inherit; font-size: var(--t-sm); padding: .9rem 1.05rem; border: 1px solid var(--c-line-2);
  border-radius: var(--radius-sm); background: rgba(255,255,255,.03); color: var(--c-ink); width: 100%; transition: border-color .15s ease, box-shadow .15s ease; }
.form input::placeholder, .form textarea::placeholder { color: #5d626c; }
.form input:focus, .form textarea:focus { outline: none; border-color: var(--c-accent); box-shadow: 0 0 0 3px rgba(var(--accent-rgb),.18); }
.form-consent label { font-weight: 400; font-size: var(--t-sm); color: var(--c-slate); display: flex; gap: .55rem; align-items: flex-start; font-family: var(--font); }
.form-consent label > span { line-height: 1.45; }
.form-consent input { width: 18px; height: 18px; margin: .1rem 0 0; accent-color: var(--c-accent); flex: none; }
.hp { position: absolute; left: -9999px; height: 0; overflow: hidden; }
.form-note { padding: 1rem 1.25rem; border-radius: var(--radius-sm); font-size: var(--t-sm); margin-bottom: 1.25rem; }
.form-note.ok { background: rgba(34,197,94,.12); color: #7ee2a8; border: 1px solid rgba(34,197,94,.3); }
.form-note.err { background: rgba(239,68,68,.12); color: #f3a3a3; border: 1px solid rgba(239,68,68,.3); }
.form .is-error { border-color: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,.18); }
.field-err { display: block; color: #f3a3a3; font-size: var(--t-xs); font-weight: 600; margin-top: .35rem; font-family: var(--font-display); }

/* ---------------------------------------------------------------------
   FOOTER CTA (poptávka)
   --------------------------------------------------------------------- */
.footer-cta { background: linear-gradient(180deg, var(--c-bg-2), var(--c-bg)); position: relative; overflow: hidden; border-top: 1px solid var(--c-line); }
.footer-cta::before { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 150% at 12% 30%, rgba(var(--accent-rgb),.16), transparent 55%); pointer-events: none; }
.footer-cta .footer-cta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; position: relative; }
.footer-cta .eyebrow { color: var(--c-accent-2); }
.footer-cta h2 { font-size: var(--t-2xl); font-weight: 700; line-height: 1.06; letter-spacing: -.025em; margin-top: .8rem; color: var(--c-ink); }
.footer-cta .cta-sub { color: var(--c-text); margin-top: 1.3rem; font-size: var(--t-md); max-width: 42ch; line-height: 1.6; }
.footer-cta .cta-sub strong { color: var(--c-ink); font-weight: 600; }
.footer-cta .form { background: rgba(255,255,255,.035); border: 1px solid var(--c-line-2); padding: 2.1rem; border-radius: var(--radius); box-shadow: var(--shadow-lg); backdrop-filter: blur(6px); }
.footer-cta .form label { color: var(--c-ink); }
.footer-cta .form-consent label { color: var(--c-slate); }

.contact-list { margin-top: 2.1rem; display: grid; gap: 1rem; }
.contact-list li { display: flex; gap: .9rem; align-items: center; font-size: var(--t-md); }
.contact-list li > span:last-child { display: flex; flex-direction: column; gap: 2px; }
.contact-list .ci-ico { width: 52px; height: 52px; border-radius: 14px; background: var(--c-accent-soft); border: 1px solid var(--c-line-2);
  display: inline-flex; align-items: center; justify-content: center; color: var(--c-accent-2); flex: none; }
.contact-list .ci-ico svg { width: 22px; height: 22px; }
.contact-list .ci-label { font-size: var(--t-xs); color: var(--c-slate); text-transform: uppercase; letter-spacing: .1em; font-family: var(--font-display); line-height: 1; margin: 0; }
.contact-list a, .contact-list .ci-val { color: var(--c-ink); font-family: var(--font-display); font-weight: 500; line-height: 1.1; }
.contact-list a:hover { color: var(--c-accent-2); }

/* ---------------------------------------------------------------------
   FOOTER
   --------------------------------------------------------------------- */
.site-footer { background: var(--c-bg); color: var(--c-slate); padding-block: 0 2.5rem; font-size: var(--t-sm); border-top: 1px solid var(--c-line); }
.site-footer::before { content: ""; display: block; height: 1px; background: var(--grad-accent); margin: 0 0 7rem; opacity: .8; }
.site-footer .btn { color: #100a06; }
.footer-grid { display: grid; grid-template-columns: 1.75fr 1.9fr 1fr 1.4fr; gap: 2.5rem 3rem; }
.site-footer .brand { color: var(--c-ink); font-size: 1.6rem; margin-bottom: 1rem; }
.footer-motto { color: var(--c-text); font-family: var(--font-serif); font-style: italic; font-size: var(--t-md); max-width: 34ch; }
.footer-owner { color: var(--c-slate); margin-top: 1.25rem; }
.footer-col h3 { font-family: var(--font-display); font-size: var(--t-xs); text-transform: uppercase; letter-spacing: .14em; color: #5d626c; margin-bottom: 1.15rem; font-weight: 600; }
.footer-col ul { display: grid; gap: .72rem; }
.footer-col ul a { white-space: nowrap; }
.footer-col a { color: var(--c-text); }
.footer-col a:hover { color: var(--c-accent-2); }
.footer-contact-line { display: flex; gap: .6rem; align-items: center; margin-bottom: .7rem; color: var(--c-text); }
.footer-contact-line svg { width: 17px; height: 17px; color: var(--c-accent-2); flex: none; }
.footer-bottom { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; align-items: center;
  margin-top: 6rem; padding-top: 2.75rem; border-top: 1px solid var(--c-line); color: #5d626c; font-size: var(--t-xs); }
.footer-bottom a { color: var(--c-slate); }
.footer-bottom a:hover { color: var(--c-accent-2); }
.footer-bottom .fb-links { display: flex; gap: 1.5rem; }

/* ---------------------------------------------------------------------
   FAQ
   --------------------------------------------------------------------- */
.faq { display: grid; gap: .85rem; }
.faq details { border: 1px solid var(--c-line); border-radius: var(--radius); background: var(--c-surface); transition: border-color .15s ease; }
.faq details[open] { border-color: var(--c-line-2); background: var(--c-surface-2); }
.faq summary { padding: 1.3rem 1.5rem; font-weight: 600; font-family: var(--font-display); color: var(--c-ink); cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; gap: 1rem; align-items: center; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--c-accent); font-size: var(--t-lg); line-height: 1; }
.faq details[open] summary::after { content: "–"; }
.faq .faq-body { padding: 0 1.5rem 1.5rem; color: var(--c-text); }
.faq .faq-body > * + * { margin-top: .8rem; }

/* ---------------------------------------------------------------------
   TESTIMONIALS
   --------------------------------------------------------------------- */
.testimonial { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius); padding: 2.4rem; height: 100%;
  display: flex; flex-direction: column; position: relative; overflow: hidden; transition: .25s ease; }
.testimonial:hover { transform: translateY(-5px); border-color: var(--c-line-2); box-shadow: var(--shadow); }
.testimonial::before { content: "\201C"; position: absolute; top: .2rem; right: 1.5rem; font-family: var(--font-serif); font-size: 6rem; line-height: 1; color: var(--c-accent); opacity: .22; }
.testimonial .stars { color: var(--c-accent); letter-spacing: 3px; margin-bottom: 1rem; font-size: var(--t-sm); }
.testimonial blockquote { font-family: var(--font-serif); font-style: italic; font-size: var(--t-md); line-height: 1.5; font-weight: 400; color: var(--c-ink); }
.testimonial .t-author { margin-top: auto; padding-top: 1.6rem; display: flex; align-items: center; gap: .9rem; font-size: var(--t-sm); }
.testimonial .t-avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--grad-accent); color: #0a0b0e;
  display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; flex: none; }
.testimonial .t-name { font-weight: 700; color: var(--c-ink); font-family: var(--font-display); }
.testimonial .t-role { color: var(--c-slate); }

/* ---------------------------------------------------------------------
   O MNĚ
   --------------------------------------------------------------------- */
.about-section { background: linear-gradient(180deg, var(--c-bg), var(--c-bg-2)); position: relative; overflow: hidden; border-block: 1px solid var(--c-line); }
.about-section::before { content: ""; position: absolute; bottom: -40%; right: -10%; width: 55%; height: 150%; background: radial-gradient(circle, rgba(var(--accent-rgb),.13), transparent 60%); pointer-events: none; }
.about-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 4rem; align-items: center; position: relative; }
.about-portrait { aspect-ratio: 4/5; border-radius: 24px; background: linear-gradient(160deg, var(--c-surface-2), var(--c-bg));
  border: 1px solid var(--c-line-2); display: flex; align-items: flex-end; padding: 2rem; position: relative; overflow: hidden; box-shadow: var(--shadow-lg); }
.about-portrait::before { content: ""; position: absolute; top: -20%; left: -10%; width: 70%; height: 70%; background: radial-gradient(circle, rgba(var(--accent-rgb),.32), transparent 60%); }
.about-portrait .ap-initials { position: absolute; top: 1.75rem; left: 1.75rem; font-family: var(--font-serif); font-style: italic; font-size: 1.6rem; font-weight: 500; color: var(--c-accent-2); }
.about-portrait .ap-name { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: var(--t-lg); color: #fff; }
.about-portrait .ap-role { position: relative; z-index: 1; color: var(--c-slate); font-size: var(--t-sm); }
.about-section .eyebrow { color: var(--c-accent-2); }
.about-section h2 { color: var(--c-ink); margin-top: .8rem; }
.about-lead { color: var(--c-text); font-size: var(--t-md); line-height: 1.65; margin-top: 1.6rem; max-width: 52ch; }
.about-lead strong { color: var(--c-ink); }
.about-points { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.3rem; margin-top: 2.1rem; }
.about-points li { display: flex; gap: .7rem; align-items: flex-start; color: var(--c-text); font-size: var(--t-sm); }
.about-points li::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--grad-accent); margin-top: .55em; flex: none; }
.about-section .hero-actions { margin-top: 2.6rem; }

/* ---------------------------------------------------------------------
   PROCES (kroky)
   --------------------------------------------------------------------- */
.steps { counter-reset: step; display: grid; gap: 1.6rem; }
.steps .step { display: grid; grid-template-columns: auto 1fr; gap: 1.3rem; align-items: start; }
.steps .step::before { counter-increment: step; content: counter(step); width: 46px; height: 46px; background: var(--c-accent-soft);
  border: 1px solid var(--c-line-2); color: var(--c-accent-2); border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif); font-style: italic; font-weight: 500; flex: none; }
.steps .step h3 { font-size: var(--t-md); font-weight: 600; }
.steps .step p { color: var(--c-slate); font-size: var(--t-sm); }

.tag { display: inline-block; font-family: var(--font-display); font-size: var(--t-xs); background: var(--c-accent-soft); color: var(--c-accent-2);
  padding: .32rem .72rem; border-radius: 999px; font-weight: 600; letter-spacing: .03em; border: 1px solid var(--c-line-2); }

.pagination { display: flex; gap: .5rem; justify-content: center; margin-top: 3rem; }
.pagination a, .pagination span { padding: .55rem .9rem; border: 1px solid var(--c-line); border-radius: var(--radius-sm); font-size: var(--t-sm); color: var(--c-text); }
.pagination .current { background: var(--grad-accent); color: #0a0b0e; border-color: transparent; }

/* ---------------------------------------------------------------------
   PŘEPÍNAČ DESIGNU
   --------------------------------------------------------------------- */
.theme-switch { position: fixed; right: 1.25rem; bottom: 1.25rem; z-index: 80; display: flex; align-items: center; gap: .35rem;
  background: rgba(18,20,25,.9); border: 1px solid var(--c-line-2); border-radius: 999px; padding: .35rem .5rem; box-shadow: var(--shadow); backdrop-filter: blur(8px); font-family: var(--font-display); }
.theme-switch .ts-base { font-size: var(--t-sm); font-weight: 600; color: var(--c-text); padding: .4rem .9rem; border-radius: 999px; text-decoration: none; }
.theme-switch .ts-base:hover { background: rgba(255,255,255,.06); color: var(--c-ink); text-decoration: none; }
.theme-switch .ts-base.is-active { background: var(--grad-accent); color: #0a0b0e; }
.theme-switch .ts-sep { font-size: var(--t-xs); color: var(--c-slate); text-transform: uppercase; letter-spacing: .1em; padding: 0 .15rem 0 .5rem; }
.theme-switch .ts-dot { width: 20px; height: 20px; border-radius: 50%; background: var(--dot); display: inline-block; text-decoration: none; transition: transform .12s ease; }
.theme-switch .ts-dot:hover { transform: scale(1.15); text-decoration: none; }
.theme-switch .ts-dot.is-active { outline: 2px solid var(--c-ink); outline-offset: 2px; }
@media (max-width: 600px) { .theme-switch .ts-sep { display: none; } .theme-switch { right: .75rem; bottom: .75rem; } }

/* Overlay při odesílání formuláře */
.sg-sending { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; background: rgba(5,6,8,.72); backdrop-filter: blur(6px); }
.sg-sending-box { display: flex; align-items: center; gap: 1rem; background: var(--c-surface); color: var(--c-ink); border: 1px solid var(--c-line-2); font-family: var(--font-display); font-weight: 600; padding: 1.6rem 2.1rem; border-radius: var(--radius); box-shadow: var(--shadow-lg); }
.sg-spinner { width: 26px; height: 26px; border: 3px solid var(--c-line-2); border-top-color: var(--c-accent); border-radius: 50%; animation: sg-spin .8s linear infinite; flex: none; }
@keyframes sg-spin { to { transform: rotate(360deg); } }

/* ---------------------------------------------------------------------
   RESPONSIVE
   --------------------------------------------------------------------- */
@media (max-width: 980px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2,1fr); }
  .hero-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .hero-visual { order: -1; aspect-ratio: 16/10; }
  .footer-cta .footer-cta-grid, .about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .about-portrait { max-width: 360px; aspect-ratio: 16/10; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .footer-grid .footer-brand { grid-column: 1 / -1; }
  .footer-col ul a { white-space: normal; }
  .gallery { grid-template-columns: repeat(2,1fr); }
  .nav-toggle { display: flex; }
  .main-nav { position: fixed; inset: 86px 0 auto 0; background: var(--c-bg); flex-direction: column; align-items: stretch; gap: 0;
    border-bottom: 1px solid var(--c-line); padding: 1rem 1.5rem 1.75rem; transform: translateY(-130%); transition: transform .25s ease; box-shadow: var(--shadow); max-height: calc(100vh - 86px); overflow-y: auto; }
  .main-nav.open { transform: translateY(0); }
  .main-nav > ul { flex-direction: column; align-items: stretch; gap: 0; }
  .main-nav > ul > li { border-bottom: 1px solid var(--c-line); }
  .main-nav > ul > li > a { display: block; padding: 1rem 0; font-size: var(--t-md); }
  .main-nav .submenu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: 0; padding: 0 0 .5rem .75rem; display: none; background: transparent; }
  .main-nav .submenu.open { display: block; }
  .submenu-toggle { display: block; position: absolute; right: 0; top: .65rem; width: 44px; height: 44px; font-size: var(--t-lg); color: var(--c-accent); }
  .header-cta { display: none; }
  .about-points { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: 1fr; }
  :root { --t-3xl: 2.9rem; --t-2xl: 2.2rem; --t-xl: 1.8rem; }
  .hero-trust .stat { padding-right: 1.25rem; margin-right: 1.25rem; }
  .cta-box { flex-direction: column; align-items: flex-start; }
  .footer-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
  body { background-attachment: scroll; }
}
