:root{
  --paper:#f7f4ee;
  --paper2:#fffdf9;
  --ink:#14201b;
  --ink2:#46514a;
  --ink3:#6b756e;
  --green:#1f4a3d;
  --green-d:#163328;
  --green-l:#2a6051;
  --gold:#c8892f;
  --gold-l:#e0a13c;
  --line:#e3ddd0;
  --line2:#d4ccbb;
  --warn:#b4452f;
}

/* ============ GLOBAL RESET — pre konzistentnú responzívnosť ============ */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: hidden; max-width: 100vw; }
img, video, iframe { max-width: 100%; height: auto; }
table { max-width: 100%; }
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:'Manrope',system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--green);text-decoration:none}
a:hover{color:var(--green-d)}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.15;letter-spacing:-.01em;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(36px,5.4vw,68px);font-weight:500;line-height:1.05;letter-spacing:-.02em}
h1 em{font-style:italic;color:var(--green);font-weight:500}
h2{font-size:clamp(28px,3.6vw,44px);font-weight:500}
h2 em{font-style:italic;color:var(--green);font-weight:500}
h3{font-size:22px}
h4{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ink2);margin-bottom:14px}
p{margin:0 0 14px;color:var(--ink2)}
.lead{font-size:18px;color:var(--ink);margin-bottom:24px;max-width:580px}
.muted{color:var(--ink3)}.small{font-size:13px}
.center{text-align:center}
.kicker{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.kicker.center{display:block;text-align:center}
.container{max-width:1180px;margin:0 auto;padding:0 28px}

/* Buttons */
.btn,.btn-ghost{display:inline-flex;align-items:center;gap:8px;font:inherit;font-weight:700;font-size:15px;
  padding:13px 24px;border-radius:100px;cursor:pointer;border:1px solid transparent;
  transition:transform .12s ease, background .15s, color .15s, border-color .15s;
  text-decoration:none;white-space:nowrap}
.btn{background:var(--green);color:var(--paper)}
.btn:hover{background:var(--green-d);color:var(--paper)}
.btn:active{transform:translateY(1px)}
.btn.gold{background:var(--gold);color:var(--paper)}
.btn.gold:hover{background:#b1761f}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line2)}
.btn.ghost:hover{background:var(--paper2);border-color:var(--green)}
.btn.big,.btn-ghost.big{padding:16px 32px;font-size:16px}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line2)}
.btn-ghost:hover{background:var(--paper2);border-color:var(--ink)}

/* NAV */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;background:rgba(247,244,238,.92);backdrop-filter:saturate(1.1) blur(8px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand img{height:54px;width:auto;display:block}
.brand-text{font-family:'Fraunces',serif;font-weight:600;font-size:22px;color:var(--ink);letter-spacing:-.01em}
.nav-links{display:flex;gap:30px}
.nav-links a{color:var(--ink2);font-size:14px;font-weight:500}
.nav-links a:hover{color:var(--green)}
.nav-cta{display:flex;align-items:center;gap:18px}
.login-link{color:var(--ink2);font-size:14px;font-weight:500}
.login-link:hover{color:var(--green)}

/* HERO */
.hero{padding:80px 0 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 800px 400px at 80% 30%, rgba(31,74,61,.06), transparent 60%),
  radial-gradient(ellipse 600px 300px at 10% 80%, rgba(200,137,47,.05), transparent 70%);
  pointer-events:none}
.hero-grid{max-width:1180px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.hero-text{position:relative;z-index:1}
.hero-actions{display:flex;gap:14px;margin:30px 0 28px;flex-wrap:wrap}
.hero-bullets{display:flex;gap:24px;margin:0;padding:0;list-style:none;flex-wrap:wrap;color:var(--ink2);font-size:14px}
.hero-bullets li{display:flex;align-items:center;gap:6px}

/* Hero mockups */
.hero-visual{position:relative;height:520px}
.mock{position:absolute;background:var(--paper2);border:1px solid var(--line);border-radius:18px;
  box-shadow:0 30px 60px -25px rgba(20,32,27,.25), 0 10px 25px -15px rgba(20,32,27,.15);
  padding:14px;transition:transform .3s ease}
.mock-img{height:280px;border-radius:10px;background:
  linear-gradient(135deg,#e8dfc8 0%,#c8b896 60%,#a89870 100%);
  position:relative;overflow:hidden}
.mock-img::before{content:'CARNO Q';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'Fraunces',serif;font-size:28px;color:#fff;letter-spacing:.05em;text-shadow:0 2px 8px rgba(0,0,0,.2)}
.mock-img.alt{background:linear-gradient(135deg,#2a6051,#1f4a3d 70%);height:240px}
.mock-img.alt::before{content:'Wellness';color:rgba(255,255,255,.95)}
.mock-img.alt2{background:linear-gradient(160deg,#c8892f,#a07020);height:300px}
.mock-img.alt2::before{content:'Príroda';color:#fff}
.mock-label{font-size:11px;color:var(--ink3);text-align:center;margin-top:8px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.m1{width:220px;left:0;top:30px;transform:rotate(-4deg)}
.m2{width:240px;right:30px;top:0;transform:rotate(3deg);z-index:2}
.m3{width:200px;left:60px;bottom:0;transform:rotate(2deg)}
.m1:hover,.m2:hover,.m3:hover{transform:rotate(0) scale(1.04);z-index:5}

/* Formats strip */
.formats{padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper2)}
.formats-row{display:flex;justify-content:center;flex-wrap:wrap;gap:18px;font-family:'Fraunces',serif;font-size:17px;color:var(--ink2);font-weight:500;margin-top:6px}
.formats-row .dot{color:var(--line2)}

/* STEPS */
.steps{padding:90px 0}
.steps h2{max-width:680px;margin-bottom:50px}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.step{background:var(--paper2);border:1px solid var(--line);border-radius:18px;padding:36px 30px;position:relative}
.step-num{font-family:'Fraunces',serif;font-size:46px;color:var(--gold);font-weight:500;line-height:1;margin-bottom:14px}
.step h3{margin-bottom:10px}

/* FEATURES */
.features{padding:90px 0;background:var(--paper2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.features h2{max-width:700px;margin-bottom:50px}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature{padding:28px 24px;border:1px solid var(--line);border-radius:14px;background:var(--paper);transition:transform .2s, box-shadow .2s}
.feature:hover{transform:translateY(-3px);box-shadow:0 12px 30px -15px rgba(20,32,27,.15);border-color:var(--green-l)}
.feature-icon{font-size:32px;margin-bottom:14px;line-height:1}
.feature h3{font-size:18px;margin-bottom:8px;font-weight:600}
.feature p{font-size:14px;margin:0}

/* PRICING */
.pricing{padding:90px 0}
.pricing h2{margin-bottom:14px}
.pricing .sub{max-width:540px;margin:0 auto 50px}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:980px;margin:0 auto}
.plan{background:var(--paper2);border:1px solid var(--line);border-radius:20px;padding:36px 30px;position:relative;display:flex;flex-direction:column}
.plan.featured{border:2px solid var(--gold);box-shadow:0 20px 50px -20px rgba(200,137,47,.3)}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:100px}
.plan h3{font-size:24px;margin-bottom:18px}
.price{display:flex;align-items:baseline;gap:4px;margin-bottom:24px}
.price .amount{font-family:'Fraunces',serif;font-size:54px;font-weight:500;line-height:1;color:var(--ink)}
.price .cur{font-family:'Fraunces',serif;font-size:24px;color:var(--ink);margin-right:6px}
.price .per{color:var(--ink3);font-size:14px}
.plan-feats{list-style:none;padding:0;margin:0 0 28px;flex:1}
.plan-feats li{padding:9px 0 9px 24px;font-size:14px;color:var(--ink2);position:relative;border-bottom:1px solid var(--line)}
.plan-feats li:last-child{border-bottom:none}
.plan-feats li::before{content:'✓';position:absolute;left:0;color:var(--green);font-weight:700}
.plan .btn{width:100%;justify-content:center}

/* AFFILIATE */
.affiliate{padding:90px 0;background:var(--green);color:var(--paper)}
.affiliate .kicker{color:var(--gold-l)}
.affiliate h2{color:var(--paper)}
.affiliate h2 em{color:var(--gold-l)}
.affiliate p,.affiliate .lead{color:rgba(247,244,238,.85)}
.affiliate-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.aff-bullets{list-style:none;padding:0;margin:0 0 30px}
.aff-bullets li{padding:8px 0;color:rgba(247,244,238,.9);font-size:15px;display:flex;gap:10px}
.aff-bullets li span{color:var(--gold-l);font-weight:700}
.affiliate .btn{background:var(--gold);color:#fff}
.affiliate .btn:hover{background:var(--gold-l)}
.aff-card{display:grid;grid-template-columns:1fr 1fr;gap:14px;background:rgba(247,244,238,.06);border:1px solid rgba(247,244,238,.15);border-radius:20px;padding:30px}
.aff-stat{padding:16px;text-align:center}
.aff-stat .v{font-family:'Fraunces',serif;font-size:42px;font-weight:500;color:var(--gold-l);line-height:1}
.aff-stat .l{font-size:12px;color:rgba(247,244,238,.7);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}

/* FINAL CTA */
.final-cta{padding:90px 0;text-align:center;background:var(--paper2);border-top:1px solid var(--line)}
.final-cta h2{max-width:720px;margin:0 auto 14px}
.final-cta .sub{max-width:520px;margin:0 auto 30px;color:var(--ink2)}

/* FOOTER */
.footer{background:var(--ink);color:rgba(247,244,238,.7);padding:60px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(247,244,238,.1)}
.footer .brand-text{color:var(--paper)}
.footer .brand img{height:90px;width:auto;background:rgba(255,255,255,.95);border-radius:10px;padding:8px 14px}
.footer h4{color:var(--paper);margin-bottom:16px}
.footer a{display:block;color:rgba(247,244,238,.65);padding:4px 0;font-size:14px}
.footer a:hover{color:var(--paper)}
.footer-bottom{padding-top:24px}
.footer .muted{color:rgba(247,244,238,.5)}

/* Responsive */
@media (max-width: 980px){
  .hero{padding:50px 0 40px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{height:380px;max-width:380px;margin:0 auto}
  .m1{width:180px}.m2{width:200px}.m3{width:170px}
  .steps-grid{grid-template-columns:1fr;gap:20px}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .plans{grid-template-columns:1fr;max-width:420px}
  .affiliate-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .nav-links{display:none}
  .nav{padding:14px 20px}
}
@media (max-width: 560px){
  .features-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn,.hero-actions .btn-ghost{justify-content:center}
}

/* --- Hero workflow animácia (4 kroky, jeden z nich = REÁLNA ukážka) --- */
.hero-visual{position:relative;height:560px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.demo-stage{position:relative;width:100%;max-width:380px;height:500px;
  background:var(--paper2);border:1px solid var(--line);border-radius:24px;
  box-shadow:0 30px 60px -25px rgba(20,32,27,.2), 0 10px 25px -15px rgba(20,32,27,.1);
  overflow:hidden}
.demo-screen{position:absolute;inset:0;padding:32px 28px;opacity:0;transform:translateY(10px);
  animation:demoFlow 16s ease-in-out infinite}
.demo-screen:nth-child(1){animation-delay:0s}
.demo-screen:nth-child(2){animation-delay:4s}
.demo-screen:nth-child(3){animation-delay:8s}
.demo-screen:nth-child(4){animation-delay:12s}
@keyframes demoFlow{
  0%, 25%   { opacity:1; transform:translateY(0); }
  27%, 100% { opacity:0; transform:translateY(-10px); }
}
.demo-label{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}

/* Krok 1: feed */
.demo-url{background:#fff;border:1px solid var(--line2);border-radius:10px;padding:14px 16px;font-family:'DM Mono',monospace;font-size:12px;color:var(--ink2);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.demo-url::before{content:'→';color:var(--green);font-weight:700}
.demo-products{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.demo-p{height:80px;background:linear-gradient(135deg,#e8dfc8,#c8b896);border-radius:8px;position:relative;animation:demoPulse 1.6s ease-in-out infinite}
.demo-p:nth-child(2){background:linear-gradient(135deg,#d4e4d4,#9fbf9f);animation-delay:.2s}
.demo-p:nth-child(3){background:linear-gradient(135deg,#dbcdb4,#b0986e);animation-delay:.4s}
.demo-p:nth-child(4){background:linear-gradient(135deg,#1f4a3d,#2a6051);animation-delay:.6s}
.demo-p.active{box-shadow:0 0 0 3px var(--gold);transform:scale(1.04)}
@keyframes demoPulse{0%,100%{opacity:.85}50%{opacity:1}}

/* Krok 2: AI */
.demo-ai{background:linear-gradient(135deg,#1f4a3d 0%,#2a6051 100%)}
.demo-ai .demo-label{color:#e0a13c}
.demo-sparkles{font-size:80px;text-align:center;margin:30px 0 24px;animation:demoSpin 2.4s ease-in-out infinite}
@keyframes demoSpin{0%,100%{transform:scale(1) rotate(0)}50%{transform:scale(1.15) rotate(15deg)}}
.demo-progress{height:6px;background:rgba(255,255,255,.15);border-radius:100px;overflow:hidden;margin-bottom:14px}
.demo-bar{height:100%;background:#e0a13c;border-radius:100px;animation:demoFill 4s ease-out infinite}
@keyframes demoFill{0%{width:0}90%,100%{width:100%}}
.demo-style{text-align:center;color:rgba(247,244,238,.85);font-size:14px;font-family:'Fraunces',serif;font-style:italic}

/* Krok 3: hotový post — REÁLNA vygenerovaná grafika */
.demo-real{width:100%;height:calc(100% - 38px);border-radius:14px;overflow:hidden;
  box-shadow:0 8px 24px -10px rgba(20,32,27,.25);
  background:linear-gradient(180deg,#faf7f0 0%,#f3ead8 100%);
  display:flex;align-items:center;justify-content:center}
.demo-real img{width:100%;height:100%;object-fit:cover;display:block;animation:demoReveal 1.2s ease-out both}
@keyframes demoReveal{
  0%{opacity:0;transform:scale(.96)}
  100%{opacity:1;transform:scale(1)}
}

/* Krok 4: publikované */
.demo-pub{background:var(--paper2)}
.demo-platforms{display:flex;flex-direction:column;gap:12px;margin:30px 0 24px}
.demo-pl{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.demo-pl-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:18px}
.demo-pl.fb .demo-pl-icon{background:#1877f2}
.demo-pl.ig .demo-pl-icon{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)}
.demo-pl-name{flex:1;font-weight:600;font-size:14px}
.demo-pl-status{color:#236b48;font-weight:700;font-size:18px;animation:demoCheck .4s ease-out}
.demo-pl.ig .demo-pl-status{animation-delay:.3s;animation-fill-mode:both;opacity:0;animation-name:demoFadeIn}
@keyframes demoCheck{0%{transform:scale(0)}70%{transform:scale(1.3)}100%{transform:scale(1)}}
@keyframes demoFadeIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
.demo-stat{text-align:center;font-size:13px;color:var(--ink2);background:rgba(31,74,61,.06);padding:10px 14px;border-radius:10px;font-family:'Fraunces',serif;font-style:italic}

/* Progres bodky */
.demo-dots{display:flex;gap:8px;margin-top:18px}
.demo-dot{width:8px;height:8px;border-radius:50%;background:var(--line2);transition:background .3s;animation:demoDots 16s ease-in-out infinite}
.demo-dot:nth-child(1){animation-delay:0s}
.demo-dot:nth-child(2){animation-delay:4s}
.demo-dot:nth-child(3){animation-delay:8s}
.demo-dot:nth-child(4){animation-delay:12s}
@keyframes demoDots{0%,25%{background:var(--green);transform:scale(1.3)}26%,100%{background:var(--line2);transform:scale(1)}}

@media (max-width: 980px){
  .hero-visual{height:auto;min-height:520px}
  .demo-stage{max-width:340px;height:460px}
  .demo-sparkles{font-size:64px}
}

/* ============ MOBILE (max 600px) — hero demo-stage problémy ============ */
@media (max-width: 600px){
  .hero{padding:30px 0 24px}
  .hero-grid{padding:0 16px;gap:24px}
  .hero h1{font-size:30px;line-height:1.15}
  .hero .lead{font-size:15px}
  .hero-bullets li{font-size:13px}

  /* Hero visual — schováme animovaný carousel (zlomený layout), zobrazíme statický screenshot */
  .hero-visual{min-height:auto;height:auto;margin-top:8px}
  .demo-stage{
    max-width:100%;width:100%;height:auto;aspect-ratio:9/12;
    background:linear-gradient(180deg,#faf7f0 0%,#f3ead8 100%);
    border:1px solid var(--line);border-radius:18px;overflow:hidden;
    background-image:url('/assets/img/showcase/sample-1-editorial.jpg');
    background-size:cover;background-position:center
  }
  /* Skry všetky animované demo-screen + dots — ukážeme len statickú grafiku ako background */
  .demo-screen, .demo-dots{display:none !important}
}


/* --- Plan card extras --- */
.plan-tagline{font-size:13px;color:var(--ink2);font-style:italic;margin:0 0 16px;line-height:1.45}
.plan-usage{background:rgba(31,74,61,.05);border-radius:10px;padding:14px 16px;margin-bottom:18px}
.plan.featured .plan-usage{background:rgba(200,137,47,.10)}
.plan-usage-title{font-size:12px;font-weight:700;color:var(--green);margin-bottom:8px;letter-spacing:.04em}
.plan.featured .plan-usage-title{color:var(--gold)}
.plan-usage-list{list-style:none;padding:0;margin:0}
.plan-usage-list li{font-size:13px;color:var(--ink2);padding:4px 0 4px 16px;position:relative;line-height:1.4}
.plan-usage-list li::before{content:'·';position:absolute;left:6px;color:var(--green);font-weight:700;font-size:18px;line-height:1}
.plan.featured .plan-usage-list li::before{color:var(--gold)}

@media (max-width: 720px){
}

/* === Language switcher === */
.lang-switcher{position:relative;display:inline-block;margin-right:8px}
.lang-btn{background:rgba(31,74,61,.05);border:1px solid var(--line);border-radius:100px;padding:7px 14px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;font-family:inherit;transition:all .2s}
.lang-btn:hover{background:rgba(31,74,61,.1)}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 30px -8px rgba(20,32,27,.18);min-width:170px;padding:6px;display:none;z-index:100;flex-direction:column}
.lang-menu.open{display:flex}
.lang-menu a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;font-size:14px;color:var(--ink);transition:background .2s;white-space:nowrap}
.lang-menu a:hover{background:var(--paper2)}
.lang-menu a.active{background:rgba(31,74,61,.06);font-weight:600}
@media (max-width: 720px){
  .lang-switcher{margin-right:6px}
  .lang-btn{padding:6px 10px;font-size:12px}
  /* Lang-menu na mobile — narrower, scroll ak treba */
  .lang-menu{
    min-width: 160px;
    max-width: calc(100vw - 32px);
    right: 0;
    max-height: 70vh;
    overflow-y: auto;
  }
  .lang-menu a{font-size:13px;padding:7px 10px}
}

/* ============ SHOWCASE — interaktívne new features ============ */
.showcase{padding:80px 0;background:linear-gradient(180deg,#fdfaf3 0%,#faf6ea 100%);position:relative;overflow:hidden}
.showcase:before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(200,154,46,.12),transparent 70%);border-radius:50%;pointer-events:none}
.showcase:after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(31,74,61,.08),transparent 70%);border-radius:50%;pointer-events:none}

.showcase-tabs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px;position:relative;z-index:2}
.sc-tab{display:flex;align-items:center;gap:14px;padding:14px 28px;background:#fff;border:2px solid #e8e2d0;border-radius:100px;cursor:pointer;font:inherit;color:#666;transition:all .25s ease;font-weight:500}
.sc-tab:hover{border-color:#c89a2e;color:#1f4a3d;transform:translateY(-1px)}
.sc-tab.active{background:#1f4a3d;border-color:#1f4a3d;color:#fff;box-shadow:0 8px 24px rgba(31,74,61,.18)}
.sc-tab-num{font-family:'Fraunces',serif;font-size:14px;font-weight:500;opacity:.5;letter-spacing:.05em}
.sc-tab.active .sc-tab-num{color:#c89a2e;opacity:1}
.sc-tab-label{font-size:15px;font-weight:600;letter-spacing:.01em}

.sc-panel{display:none;animation:fadeUp .35s ease-out}
.sc-panel.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.sc-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-template-rows:auto auto;gap:18px;position:relative;z-index:2}
.sc-card{background:#fff;border:1px solid #ede5cf;border-radius:18px;padding:24px;transition:all .25s ease;position:relative}
.sc-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(31,74,61,.1);border-color:#c89a2e}
.sc-card.sc-card-lg{grid-column:1;grid-row:1 / span 2;background:linear-gradient(135deg,#1f4a3d 0%,#0e1a12 100%);color:#fff;padding:36px 32px;border:none}
.sc-card.sc-card-lg:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(31,74,61,.3);border:none}
.sc-card.sc-card-lg h3{color:#fff !important;font-size:28px;margin:18px 0 12px;font-weight:500;line-height:1.2}
.sc-card.sc-card-lg p{color:rgba(255,255,255,.92) !important;font-size:15px;line-height:1.6;margin:0 0 22px}
.sc-card h3{font-family:'Fraunces',serif;font-weight:500;font-size:19px;color:#1f4a3d;margin:14px 0 6px;line-height:1.25}
.sc-card p{color:#666;font-size:14px;line-height:1.55;margin:0}
.sc-card-icon{font-size:34px;line-height:1}
.sc-badge{display:inline-block;background:rgba(227,201,122,.25);color:#f5dd9a;padding:6px 14px;border-radius:100px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border:1px solid rgba(227,201,122,.3)}
.sc-bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.sc-bullets li{color:rgba(255,255,255,.95);font-size:14px;font-weight:500;line-height:1.4}

@media(max-width:880px){
  .sc-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .sc-card-lg{grid-column:1;grid-row:auto}
  .sc-tab{padding:10px 18px;gap:8px}
  .sc-tab-label{font-size:13px}
  .showcase{padding:48px 0}
}

/* ============ LIVE DEMO WIDGET ============ */
.livedemo{padding:80px 0;background:linear-gradient(180deg,#0e1a12 0%,#1f4a3d 100%);color:#fff;position:relative}
.livedemo .kicker{color:#e3c97a;font-weight:600}
.livedemo h2{color:#fff;text-align:center}
.livedemo .lead{color:rgba(255,255,255,.85);text-align:center}
.livedemo h2 em{color:#e3c97a;font-style:italic}
.demo-card{max-width:840px;margin:0 auto;background:#fff;color:#0e1a12;border-radius:20px;padding:32px;box-shadow:0 24px 60px rgba(0,0,0,.25);position:relative}
.demo-input-row{display:flex;gap:10px;margin-bottom:8px}
.demo-input{flex:1;padding:14px 16px;border:2px solid #e8e2d0;border-radius:12px;font:inherit;font-size:15px;background:#fafaf6;color:#0e1a12;transition:border-color .15s}
.demo-input:focus{outline:none;border-color:#c89a2e;background:#fff}
.demo-go{flex:0 0 auto;white-space:nowrap}
.demo-hint{font-size:12px;color:#888;margin:8px 0 0;text-align:center}
.demo-loading{text-align:center;padding:32px 0}
.demo-spinner{width:36px;height:36px;margin:0 auto 14px;border:3px solid #e8e2d0;border-top-color:#1f4a3d;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.demo-result{margin-top:24px;padding-top:24px;border-top:1px solid #ede5cf;animation:fadeUp .4s ease-out}
.demo-result-grid{display:grid;grid-template-columns:200px 1fr;gap:20px;align-items:start}
.demo-prod-img{width:200px;height:200px;object-fit:cover;border-radius:14px;background:#f0ebe0;display:block}
.demo-prod-info{margin-top:10px}
.demo-prod-title{font-family:'Fraunces',serif;font-size:15px;font-weight:500;line-height:1.3;margin-bottom:6px}
.demo-prod-price{font-size:14px;color:#1f4a3d;font-weight:700}
.demo-caption{background:#faf6ea;border:1px solid #ede5cf;border-radius:14px;padding:18px}
.demo-cap-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:#1f4a3d;margin-bottom:8px}
.demo-cap-text{font-size:14px;line-height:1.55;color:#0e1a12;white-space:pre-wrap;margin-bottom:10px}
.demo-cap-tags{font-size:13px;color:#c89a2e;font-weight:600;margin-bottom:14px}
.demo-cap-cta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.demo-remaining{font-size:11px;color:#888}
.demo-error{margin-top:18px;padding:14px 18px;background:#fbe8e4;color:#a03020;border-radius:10px;border:1px solid #e3b2a8;font-size:14px}
@media(max-width:680px){
  .demo-input-row{flex-direction:column}
  .demo-result-grid{grid-template-columns:1fr}
  .demo-prod-img{width:100%;height:auto;max-height:280px}
}

/* ============ BEFORE / AFTER ============ */
.beforeafter{padding:80px 0;background:#faf6ea}
.ba-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:22px;align-items:stretch;max-width:980px;margin:0 auto}
.ba-col{background:#fff;border-radius:18px;padding:32px 28px;position:relative;display:flex;flex-direction:column}
.ba-before{border:1px solid #e3b2a8}
.ba-after{border:2px solid #1f4a3d;background:linear-gradient(180deg,#fff,#f5f9f7)}
.ba-tag{display:inline-block;background:#fbe8e4;color:#a03020;padding:5px 14px;border-radius:100px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;align-self:flex-start}
.ba-tag-after{background:#dff0e6;color:#1f4a3d}
.ba-col h3{font-family:'Fraunces',serif;font-weight:500;font-size:22px;color:#0e1a12;margin:0 0 18px;line-height:1.25}
.ba-list{list-style:none;padding:0;margin:0 0 22px;flex:1}
.ba-list li{padding:8px 0;font-size:14px;color:#3a3a3a;line-height:1.45;border-bottom:1px dashed #ede5cf}
.ba-list li:last-child{border:none}
.ba-after .ba-list li{color:#1f4a3d;font-weight:500}
.ba-time{padding-top:18px;border-top:1px solid #ede5cf;display:flex;align-items:baseline;gap:10px}
.ba-time-val{font-family:'Fraunces',serif;font-size:34px;font-weight:500;color:#a03020;line-height:1}
.ba-time-after .ba-time-val{color:#1f4a3d}
.ba-time-lbl{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#888;font-weight:600}
.ba-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.ba-arrow-circle{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#c89a2e,#e3c97a);color:#fff;font-size:26px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(200,154,46,.35)}
.ba-arrow-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#888;font-weight:600;max-width:80px;text-align:center}
@media(max-width:780px){
  .ba-grid{grid-template-columns:1fr}
  .ba-arrow{flex-direction:row;padding:10px 0}
  .ba-arrow-circle{transform:rotate(90deg)}
}

/* ============ STATS social proof ============ */
.stats{padding:60px 0;background:#1f4a3d;color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center;max-width:980px;margin:0 auto}
.stat-block{padding:0 16px}
.stat-val{font-family:'Fraunces',serif;font-size:54px;font-weight:500;line-height:1;color:#e3c97a;letter-spacing:-.02em}
.stat-suffix{font-size:36px}
.stat-lbl{font-size:14px;font-weight:600;margin-top:8px;color:#fff}
.stat-sub{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px;line-height:1.4}
@media(max-width:680px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px}
  .stat-val{font-size:42px}
}

/* ============ TESTIMONIALS ============ */
.testimonials{padding:80px 0;background:#fdfaf3}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1100px;margin:0 auto}
.testi-card{background:#fff;border:1px solid #ede5cf;border-radius:18px;padding:28px;position:relative;transition:all .25s}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(31,74,61,.12);border-color:#c89a2e}
.testi-sample{position:absolute;top:14px;right:14px;background:rgba(200,154,46,.18);color:#c89a2e;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.testi-rating{color:#c89a2e;font-size:15px;letter-spacing:2px;margin-bottom:14px}
.testi-quote{font-family:'Fraunces',serif;font-size:16px;line-height:1.55;color:#0e1a12;margin:0 0 22px;font-weight:400}
.testi-author{display:flex;align-items:center;gap:12px;padding-top:18px;border-top:1px solid #ede5cf}
.testi-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-family:'Fraunces',serif;font-size:18px;flex-shrink:0}
.testi-avatar-a{background:linear-gradient(135deg,#1f4a3d,#2d6b54)}
.testi-avatar-b{background:linear-gradient(135deg,#c89a2e,#e3c97a)}
.testi-avatar-c{background:linear-gradient(135deg,#a03020,#d05a4e)}
.testi-name{font-size:14px;font-weight:700;color:#0e1a12}
.testi-role{font-size:12px;color:#888;margin-top:2px}
@media(max-width:880px){.testi-grid{grid-template-columns:1fr;max-width:540px}}

/* ============ COMPARISON tabuľka ============ */
.comparison{padding:80px 0;background:#fff}
.cmp-wrap{max-width:1000px;margin:0 auto;overflow-x:auto}
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;min-width:680px}
.cmp-table th{padding:18px 14px;text-align:center;vertical-align:bottom;border-bottom:2px solid #ede5cf;background:#faf6ea;font-weight:600;color:#0e1a12}
.cmp-table th.cmp-feat{background:transparent;border-bottom:none}
.cmp-table th.cmp-us{background:#1f4a3d;color:#fff;border-radius:14px 14px 0 0;border-bottom:none;position:relative}
.cmp-table th.cmp-us:before{content:'⭐ ODPORÚČAME';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:#c89a2e;color:#fff;padding:4px 12px;border-radius:100px;font-size:10px;font-weight:700;letter-spacing:.06em;white-space:nowrap}
.cmp-logo{font-family:'Fraunces',serif;font-size:20px;font-weight:500;color:#e3c97a;letter-spacing:-.02em}
.cmp-name{font-weight:700;font-size:15px;color:#0e1a12}
.cmp-price{font-size:11px;color:#888;font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:.04em}
.cmp-us .cmp-price{color:rgba(255,255,255,.7)}
.cmp-table td{padding:14px;text-align:center;border-bottom:1px solid #f0ebe0;color:#666;font-size:14px}
.cmp-table td.cmp-feat{text-align:left;font-weight:500;color:#0e1a12;font-size:14px}
.cmp-table td.cmp-us{background:rgba(200,154,46,.06);color:#1f4a3d;font-weight:700;border-left:2px solid #1f4a3d;border-right:2px solid #1f4a3d}
.cmp-table tr:last-child td.cmp-us{border-bottom:2px solid #1f4a3d;border-radius:0 0 14px 14px}
.cmp-note{text-align:center;font-size:12px;color:#888;margin-top:16px;max-width:600px;margin-left:auto;margin-right:auto}

/* Comparison table — mobile ============ */
@media (max-width: 780px) {
  .comparison { padding: 50px 0; }
  .cmp-wrap {
    /* Vizuálny indikátor že je scroll-able pre desku konkurentov */
    position: relative;
    margin: 0 -16px;  /* fullwidth aby user vedel scrollnut */
    padding: 0 16px;
  }
  /* Gradient na pravom okraji aby user vedel "ešte je obsah vpravo" */
  .cmp-wrap::after {
    content: '';
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 30px;
    background: linear-gradient(to right, transparent, #fff);
    pointer-events: none;
    z-index: 2;
  }
  .cmp-table {
    font-size: 13px;
    min-width: 560px;  /* znížené z 680px */
  }
  .cmp-table th { padding: 12px 8px; font-size: 12px; }
  .cmp-table td { padding: 10px 8px; font-size: 12px; }
  .cmp-table th.cmp-us:before {
    font-size: 9px;
    padding: 3px 8px;
    top: -10px;
  }
  .cmp-logo, .cmp-name { font-size: 13px; }
  .cmp-price { font-size: 11px; }
}
@media (max-width: 560px) {
  .cmp-table { min-width: 480px; font-size: 12px; }
  .cmp-table td.cmp-feat { font-size: 12px; }
}

/* ============ ROI kalkulačka ============ */
.roi{padding:80px 0;background:linear-gradient(180deg,#fdfaf3,#faf6ea)}
.roi-card{max-width:880px;margin:0 auto;background:#fff;border:1px solid #ede5cf;border-radius:20px;padding:36px;box-shadow:0 12px 36px rgba(31,74,61,.08);display:grid;grid-template-columns:1.2fr 1fr;gap:32px}
.roi-field{margin-bottom:22px}
.roi-field label{display:block;font-size:13px;font-weight:600;color:#0e1a12;margin-bottom:10px}
.roi-slider-wrap{display:flex;align-items:center;gap:14px}
.roi-slider-wrap input[type=range]{flex:1;accent-color:#1f4a3d;height:6px}
.roi-output{flex:0 0 80px;text-align:right;font-family:'Fraunces',serif;font-size:18px;font-weight:500;color:#1f4a3d}
.roi-results{background:linear-gradient(135deg,#1f4a3d,#0e1a12);color:#fff;border-radius:14px;padding:26px;display:flex;flex-direction:column;justify-content:center}
.roi-row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px;color:rgba(255,255,255,.85)}
.roi-row strong{font-family:'Fraunces',serif;font-size:18px;color:#fff;font-weight:500}
.roi-row-big{border-bottom:none;border-top:2px solid rgba(227,201,122,.4);padding-top:16px;margin-top:8px;font-size:15px;color:#e3c97a}
.roi-row-big strong{font-size:28px;color:#e3c97a}
.roi-row-tiny{font-size:11px;color:rgba(255,255,255,.5);justify-content:flex-end;border:none;padding:6px 0 12px}
.roi-cta{margin-top:14px;background:#c89a2e;color:#fff;text-align:center;text-decoration:none;display:block}
.roi-cta:hover{background:#e3c97a}
@media(max-width:780px){
  .roi{padding:50px 0}
  .roi .container{padding:0 16px}
  .roi-card{
    grid-template-columns:1fr;
    padding:20px;
    max-width:100%;
    width:100%;
    overflow:hidden;
    box-sizing:border-box;
  }
}
@media(max-width:560px){
  .roi .container{padding:0 12px}
  .roi-card{padding:16px;gap:18px;border-radius:14px}
  .roi-field{margin-bottom:16px;min-width:0}
  .roi-field label{font-size:12px;margin-bottom:6px}
  /* Output čísla pod slider, nie vedľa neho */
  .roi-slider-wrap{flex-wrap:wrap;gap:6px;align-items:center;min-width:0}
  .roi-slider-wrap input[type=range]{flex:1 1 100%;min-width:0;width:100%;order:1}
  .roi-output{flex:0 0 auto;font-size:15px;order:2;margin-left:auto}
  .roi-results{padding:16px;border-radius:12px;min-width:0}
  .roi-row{font-size:13px;min-width:0;gap:8px}
  .roi-row > span:first-child{flex-shrink:1;min-width:0}
  .roi-row strong{font-size:16px;white-space:nowrap}
  .roi-row-big strong{font-size:19px;white-space:nowrap}
  .roi-row-tiny{font-size:10px;line-height:1.4;text-align:right}
}

/* ============ FAQ ============ */
.faq{padding:80px 0;background:#fff}
.faq-container{max-width:780px}
.faq h2{font-size:38px;text-align:left}
.faq .lead{text-align:left;max-width:none;margin-bottom:32px}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:#faf6ea;border:1px solid #ede5cf;border-radius:14px;overflow:hidden;transition:all .2s}
.faq-item[open]{background:#fff;border-color:#c89a2e;box-shadow:0 4px 16px rgba(31,74,61,.06)}
.faq-item summary{padding:18px 22px;cursor:pointer;font-weight:600;font-size:15px;color:#0e1a12;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;line-height:1.4}
.faq-item summary::-webkit-details-marker{display:none}
.faq-chev{flex:0 0 24px;width:24px;height:24px;border-radius:50%;background:#1f4a3d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:300;transition:transform .25s}
.faq-item[open] .faq-chev{transform:rotate(45deg);background:#c89a2e}
.faq-a{padding:0 22px 22px;color:#3a3a3a;font-size:14px;line-height:1.65}
.faq-a strong{color:#1f4a3d}

/* ============ ROADMAP ============ */
.roadmap{padding:80px 0;background:linear-gradient(180deg,#fdfaf3,#faf6ea)}
.roadmap .kicker{color:#c89a2e;font-weight:600}
.roadmap h2{text-align:center}
.roadmap h2 em{color:#c89a2e;font-style:italic}
.rm-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1100px;margin:0 auto}
.rm-col{background:#fff;border:1px solid #ede5cf;border-radius:16px;padding:22px;display:flex;flex-direction:column;transition:all .2s}
.rm-col:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(31,74,61,.08)}
.rm-done{background:linear-gradient(180deg,#fff,#f5f9f7);border-color:#c4ddd0}
.rm-progress{background:linear-gradient(180deg,#fff,#fdf8ea);border-color:#e3c97a;box-shadow:0 8px 24px rgba(200,154,46,.12);transform:scale(1.02)}
.rm-progress:hover{transform:scale(1.02) translateY(-3px)}
.rm-planned{background:#fff;border-color:#e0d8c8}
.rm-col-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #ede5cf}
.rm-col-badge{display:inline-block;padding:5px 12px;border-radius:100px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.rm-badge-done{background:#dff0e6;color:#1f4a3d}
.rm-badge-progress{background:#fdf0c4;color:#8a6d20;animation:rm-pulse 2.5s ease-in-out infinite}
.rm-badge-planned{background:#f0ebe0;color:#888}
@keyframes rm-pulse{0%,100%{box-shadow:0 0 0 0 rgba(200,154,46,.4)}50%{box-shadow:0 0 0 8px rgba(200,154,46,0)}}
.rm-col-count{font-family:'Fraunces',serif;font-size:24px;font-weight:500;color:#888}
.rm-done .rm-col-count{color:#1f4a3d}
.rm-progress .rm-col-count{color:#c89a2e}
.rm-items{display:flex;flex-direction:column;gap:10px;flex:1}
.rm-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px dashed #f0ebe0;font-size:13px;line-height:1.4}
.rm-item:last-child{border-bottom:none}
.rm-item strong{color:#0e1a12;font-weight:600;display:block;margin-bottom:2px}
.rm-item .muted{font-size:11px;color:#888;display:block}
.rm-dot{flex:0 0 8px;width:8px;height:8px;border-radius:50%;background:#d8d2c2;margin-top:6px}
.rm-done .rm-dot{background:#1f4a3d}
.rm-progress .rm-dot{background:#c89a2e;box-shadow:0 0 0 3px rgba(200,154,46,.2)}
.rm-fresh{position:relative}
.rm-fresh:after{content:'NOVÉ';position:absolute;top:8px;right:0;background:#c89a2e;color:#fff;padding:1px 7px;border-radius:100px;font-size:9px;font-weight:700;letter-spacing:.04em}
.rm-cta-text{text-align:center;margin:36px auto 0;max-width:560px;font-size:14px;color:#666;line-height:1.55}
.rm-cta-text strong{color:#1f4a3d}
@media(max-width:880px){
  .rm-timeline{grid-template-columns:1fr;max-width:540px}
  .rm-progress{transform:none}
  .rm-progress:hover{transform:translateY(-3px)}
}
