/* ============================================================
   VapeNova – Theme "Aurora" (professionell, clean, SEO-fokussiert)
   Systemschriften (schnell + DSGVO-sicher), ein Teal-Leitakzent.
   ============================================================ */
:root{
  --ink:#0f1729; --ink2:#1e293b; --muted:#5b6472; --faint:#8b93a3;
  --line:#e7eaf0; --line2:#f0f2f6;
  --page:#ffffff; --alt:#f6f8fb; --card:#ffffff;
  --brand:#0d9488; --brand-d:#0f766e; --brand-dd:#115e59;
  --brand-l:#d7f5f0; --brand-ink:#134e4a;
  --ok:#0f9d58; --danger:#e11d48; --star:#f59e0b;
  --radius:14px; --radius-sm:10px; --radius-lg:22px;
  --shadow:0 1px 2px rgba(15,23,41,.05),0 10px 26px rgba(15,23,41,.06);
  --shadow-lg:0 16px 48px rgba(15,23,41,.14);
  --ring:0 0 0 3px rgba(13,148,136,.30);
  --maxw:1200px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--page);color:var(--ink);font-size:16px;line-height:1.6;
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{line-height:1.18;margin:.2em 0 .5em;letter-spacing:-.02em;font-weight:800;color:var(--ink)}
h1{font-size:2.5rem} h2{font-size:1.85rem}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.muted{color:var(--muted)} .small{font-size:.82rem}
.accent{color:var(--brand)}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}

/* Buttons */
.btn{display:inline-block;border:0;cursor:pointer;font:inherit;font-weight:650;
  background:var(--brand);color:#fff;padding:11px 20px;border-radius:var(--radius-sm);
  box-shadow:0 1px 2px rgba(13,148,136,.2);transition:background .15s,transform .08s,box-shadow .15s;line-height:1.2}
.btn:hover{background:var(--brand-d);transform:translateY(-1px);box-shadow:0 8px 20px rgba(13,148,136,.28)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}
.btn-lg{padding:14px 28px;font-size:1.02rem}
.btn-sm{padding:8px 14px;font-size:.84rem}
.btn-block{display:block;width:100%;text-align:center}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn-ghost:hover{background:var(--alt);border-color:var(--brand);color:var(--brand-d)}
.btn-danger{background:var(--danger);box-shadow:none}
.btn-danger:hover{background:#be123c}
.link{color:var(--brand-d);font-weight:650}.link:hover{color:var(--brand-dd)}

/* Announcement */
.announce{background:var(--ink);color:#cbd5e1;text-align:center;font-size:.8rem;font-weight:600;
  padding:9px 16px;letter-spacing:.2px}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:22px;padding:15px 22px}
.logo{font-weight:800;font-size:1.4rem;letter-spacing:-.02em;color:var(--ink);white-space:nowrap}
.logo-mark{color:var(--brand);margin-right:3px}
.searchbar{flex:1;display:flex;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;max-width:540px;transition:border-color .15s,box-shadow .15s}
.searchbar:focus-within{border-color:var(--brand);box-shadow:var(--ring)}
.searchbar input{flex:1;border:0;padding:11px 16px;font:inherit;outline:none;background:transparent;color:var(--ink)}
.searchbar button{border:0;background:var(--brand);color:#fff;padding:0 18px;cursor:pointer;font-size:1rem}
.searchbar button:hover{background:var(--brand-d)}
.main-nav{display:flex;align-items:center;gap:20px;font-weight:650}
.main-nav a{color:var(--ink2)}.main-nav a:hover{color:var(--brand-d)}
.cart-link{position:relative}
.cart-count{background:var(--brand);color:#fff;border-radius:999px;padding:1px 8px;font-size:.72rem;margin-left:2px;font-weight:700}
.admin-link{color:var(--muted);font-size:.84rem;border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.admin-link:hover{border-color:var(--brand);color:var(--brand-d)}
.catbar{background:var(--alt);border-bottom:1px solid var(--line)}
.catbar .wrap{display:flex;gap:4px;flex-wrap:wrap;padding:8px 22px}
.catbar a{color:var(--ink2);font-size:.86rem;font-weight:600;padding:6px 13px;border-radius:8px}
.catbar a:hover{background:#fff;color:var(--brand-d);box-shadow:var(--shadow)}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);font-size:1.5rem;cursor:pointer;line-height:1}

/* Flash */
.flashes{margin-top:16px}
.flash{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:8px;font-weight:600;border:1px solid transparent}
.flash.success{background:#e7f7ef;color:#0b7a45;border-color:#bfe9d3}
.flash.error{background:#fdeaef;color:#b4123f;border-color:#f7c9d6}

/* Hero */
.hero{background:linear-gradient(180deg,var(--alt) 0%,#fff 100%);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hero-inner{display:flex;align-items:center;gap:40px;padding:70px 22px 80px}
.hero-text{flex:1;max-width:640px;position:relative;z-index:2}
.eyebrow{display:inline-block;background:var(--brand-l);color:var(--brand-ink);padding:6px 14px;border-radius:999px;
  font-size:.78rem;font-weight:700;letter-spacing:.3px;margin-bottom:16px}
.hero h1{font-size:3.1rem;margin:0 0 16px}
.hero p{color:var(--muted);font-size:1.12rem;max-width:520px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0 20px}
.hero-trust{list-style:none;display:flex;gap:20px;flex-wrap:wrap;padding:0;margin:8px 0 0;
  color:var(--ink2);font-size:.9rem;font-weight:600}
.hero-art{position:absolute;right:0;top:0;bottom:0;width:42%;z-index:1}
.blob{position:absolute;right:8%;top:50%;width:380px;height:380px;margin-top:-190px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,rgba(13,148,136,.20),rgba(13,148,136,0) 70%)}
.puff{position:absolute;color:var(--brand);opacity:.10;font-size:120px}
.puff1{right:16%;top:20%} .puff2{right:32%;bottom:14%;font-size:64px}

/* Sections */
.section{padding:54px 22px}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:12px}
.section h2{margin:0}
.alt-bg{background:var(--alt)}

/* Product grid */
.grid{display:flex;flex-wrap:wrap;margin:0 -10px}
.card{width:25%;padding:10px;box-sizing:border-box;display:flex}
.card-inner{display:flex;flex-direction:column;width:100%;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;transition:transform .14s,box-shadow .2s,border-color .2s}
.card-inner:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:#dfe3ea}
.card-img{position:relative;display:block;background:#fff}
.card-img img{width:100%;height:auto;display:block}
.badge-puffs{position:absolute;top:11px;left:11px;background:rgba(15,23,41,.85);color:#fff;
  font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.3px}
.badge-out{position:absolute;top:11px;right:11px;background:var(--danger);color:#fff;
  font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:999px}
.card-body{padding:16px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.6px;color:var(--brand-d);font-weight:700}
.card-title{font-size:1.02rem;margin:6px 0 4px;letter-spacing:-.01em}
.card-title a:hover{color:var(--brand-d)}
.card-meta{font-size:.82rem;color:var(--muted)}
.card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px;gap:8px;flex-wrap:wrap;row-gap:10px}
.price{font-size:1.25rem;font-weight:800;letter-spacing:-.02em;white-space:nowrap}

/* Category tiles (clean, uniform) */
.cats{display:flex;gap:16px;flex-wrap:wrap}
.cat-tile{flex:1;min-width:210px;background:#fff;border:1px solid var(--line);color:var(--ink);
  border-radius:var(--radius);padding:24px 22px;font-weight:700;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:6px;transition:transform .14s,box-shadow .2s,border-color .2s;
  border-left:4px solid var(--brand)}
.cat-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-left-color:var(--brand-dd)}
.cat-tile span{font-size:1.12rem} .cat-tile em{font-style:normal;color:var(--brand-d);font-weight:650;font-size:.85rem}

/* USP band */
.usp-band{background:var(--alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.usp-grid{display:flex;gap:20px;flex-wrap:wrap;padding:30px 22px}
.usp-grid>div{flex:1;min-width:210px;display:flex;flex-direction:column}
.usp-grid strong{font-size:1rem;color:var(--ink)} .usp-grid span{color:var(--muted);font-size:.88rem}

/* SEO copy */
.seo-copy{max-width:920px} .seo-copy p{color:var(--ink2)} .seo-copy a{color:var(--brand-d);font-weight:600}

/* Breadcrumb */
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.breadcrumb a:hover{color:var(--brand-d)}

/* Reviews */
.reviews{display:flex;gap:18px;flex-wrap:wrap}
.review{flex:1;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);margin:0}
.stars{color:var(--star);font-size:1.05rem;letter-spacing:2px}
.review blockquote{margin:10px 0;font-size:.96rem;color:var(--ink2)}
.review figcaption{color:var(--muted);font-weight:650;font-size:.85rem}

/* FAQ */
.faq-teaser details,.faq-list details{background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:15px 20px;margin-bottom:10px;box-shadow:var(--shadow)}
.faq-teaser summary,.faq-list summary{font-weight:700;cursor:pointer;list-style:none;color:var(--ink)}
.faq-teaser summary::-webkit-details-marker,.faq-list summary::-webkit-details-marker{display:none}
.faq-teaser summary::after,.faq-list summary::after{content:"+";float:right;color:var(--brand);font-weight:800;font-size:1.2rem;line-height:1}
.faq-teaser details[open] summary::after,.faq-list details[open] summary::after{content:"–"}
.faq-list p,.faq-teaser p{color:var(--ink2);margin:12px 0 0}

/* Newsletter */
.newsletter{background:var(--ink);color:#fff}
.nl-inner{display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;padding:36px 22px}
.nl-inner h3{margin:0 0 4px;font-size:1.45rem;color:#fff} .nl-inner .muted{color:#9fb0c4}
.nl-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.nl-form input{padding:13px 18px;border:1px solid #2b3a52;border-radius:var(--radius-sm);font:inherit;min-width:280px;background:#162236;color:#fff}
.nl-form input::placeholder{color:#7d8aa0}
.nl-done{font-weight:700;color:#5ee3c9}

/* Footer */
.site-footer{background:var(--ink);color:#9aa3b2;margin-top:0;border-top:1px solid #1d2940}
.footer-grid{display:flex;gap:34px;flex-wrap:wrap;padding:50px 22px}
.footer-grid>div{flex:1;min-width:170px}
.footer-grid .logo{color:#fff}
.footer-grid h4{color:#fff;font-size:.95rem;margin-bottom:.8em}
.footer-grid a{display:block;color:#9aa3b2;padding:4px 0;font-size:.9rem}
.footer-grid a:hover{color:#fff}
.pay-icons{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px}
.pay-icons span{background:#172234;border:1px solid #28354c;color:#aeb8c9;font-size:.68rem;font-weight:700;
  padding:5px 9px;border-radius:6px;letter-spacing:.4px}
.subfooter{border-top:1px solid #1d2940;font-size:.82rem;padding:16px 0;color:#6f7a8d}

/* Shop layout */
.shop-layout{display:flex;gap:30px;align-items:flex-start}
.filters{width:240px;flex:none;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);position:sticky;top:90px}
.filters h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);margin-top:18px}
.filters h3:first-child{margin-top:0}
.filter{display:block;padding:8px 11px;border-radius:8px;color:var(--ink2);font-size:.9rem;font-weight:600}
.filter:hover{background:var(--alt)} .filter.on{background:var(--brand);color:#fff}
.filters input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;margin-bottom:8px}
.shop-main{flex:1;min-width:0}
.cat-intro{color:var(--muted);margin:-8px 0 20px;max-width:780px}
.empty{padding:48px;text-align:center;color:var(--muted);background:#fff;border-radius:var(--radius);border:1px dashed var(--line)}

/* Product detail */
.product-detail{display:flex;gap:44px;align-items:flex-start}
.pd-media{flex:none;width:48%;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.pd-info{flex:1}
.pd-info h1{font-size:2.1rem;margin:8px 0 12px}
.pd-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-weight:600;font-size:.9rem;margin-bottom:16px}
.pd-price{font-size:2.1rem;font-weight:800;margin:10px 0;letter-spacing:-.02em}
.pd-stock{font-weight:700;margin:0 0 18px}.pd-stock.ok{color:var(--ok)}.pd-stock.no{color:var(--danger)}
.pd-buy{display:flex;gap:10px;align-items:center;margin-bottom:18px}
.pd-buy input{width:78px;padding:13px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;text-align:center}
.pd-trust{list-style:none;padding:16px 18px;margin:0 0 20px;background:var(--alt);border:1px solid var(--line);
  border-radius:var(--radius);display:grid;gap:8px;font-size:.88rem;font-weight:600;color:var(--ink2)}
.pd-desc{border-top:1px solid var(--line);padding-top:20px;color:var(--ink2)}
.pd-desc h3{margin-top:0}.pd-desc ul{padding-left:18px} .pd-desc li{margin:4px 0}

/* Cart */
.cart-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.cart-table th,.cart-table td{padding:14px 15px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
.cart-table th{background:var(--alt);font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;color:var(--faint)}
.ct-prod{display:flex;align-items:center;gap:12px}.ct-prod img{border-radius:8px;border:1px solid var(--line)}
.cart-table input{width:66px;padding:9px;border:1px solid var(--line);border-radius:8px;text-align:center}
.remove{color:var(--danger);font-weight:800}
.cart-foot{display:flex;justify-content:space-between;align-items:center;margin:18px 0;gap:14px}
.cart-total{font-size:1.05rem}.cart-total strong{font-size:1.6rem;margin-left:12px;letter-spacing:-.02em}
.cart-actions{display:flex;justify-content:space-between;gap:12px}

/* Checkout */
.checkout-grid{display:flex;gap:34px;align-items:flex-start}
.checkout-form{flex:1;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.checkout-form h3{margin-top:20px}.checkout-form h3:first-child{margin-top:0}
.checkout-form label{display:block;margin-bottom:13px;font-weight:600;font-size:.9rem}
.checkout-form input,.checkout-form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;margin-top:5px;font-weight:400}
.checkout-form input:focus,.checkout-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring)}
.check{display:flex !important;align-items:flex-start;gap:9px;font-weight:500 !important;font-size:.88rem}
.check input{width:auto !important;margin:3px 0 0 !important}
.pay-mock{border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--alt)}
.pay-opt{display:flex !important;align-items:center;gap:8px;padding:6px 0;font-weight:600 !important}
.pay-opt input{width:auto !important;margin:0 !important}
.order-summary{width:340px;flex:none;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);position:sticky;top:90px}
.os-row{display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.os-row.total{border-bottom:0;border-top:2px solid var(--ink);margin-top:6px;padding-top:13px;font-size:1.15rem}

/* Boxes */
.center-box{text-align:center;max-width:640px;margin:0 auto}
.success-icon{width:84px;height:84px;line-height:84px;border-radius:50%;background:var(--brand);color:#fff;font-size:2.4rem;margin:10px auto 20px;box-shadow:var(--shadow)}
.order-recap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin:22px 0;text-align:left;box-shadow:var(--shadow)}
.narrow{max-width:720px}
.legal-box,.login-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.login-box{max-width:420px;margin:24px auto}
.login-box label{display:block;font-weight:600;margin-bottom:13px;font-size:.9rem}
.login-box input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;margin-top:5px}
.big-404{font-size:6rem;font-weight:800;line-height:1;color:var(--brand)}

/* Article */
.article .lead{font-size:1.16rem;color:var(--ink2)} .article h2{margin-top:30px} .article ul{color:var(--ink2)}
.article a{color:var(--brand-d);font-weight:600}

/* ===== Admin ===== */
.admin-wrap{display:flex;gap:26px;align-items:flex-start}
.admin-side{width:230px;flex:none;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);position:sticky;top:90px}
.admin-side h3{margin:4px 8px 10px;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;color:var(--faint)}
.admin-side a{display:block;padding:10px 12px;border-radius:9px;font-weight:600;font-size:.92rem;color:var(--ink2)}
.admin-side a:hover{background:var(--alt);color:var(--brand-d)}
.admin-side .logout{color:var(--danger)}
.admin-main{flex:1;min-width:0}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:22px}
.stat-grid{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.stat{flex:1;min-width:150px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.stat-num{display:block;font-size:1.8rem;font-weight:800;color:var(--brand-d);letter-spacing:-.02em}
.stat-lbl{color:var(--muted);font-size:.85rem;font-weight:600}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid var(--line);font-size:.9rem}
.data-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--faint)}
.data-table tbody tr:hover{background:var(--alt)}
.thumb{border-radius:7px;object-fit:cover;border:1px solid var(--line)}
.pill{display:inline-block;background:#eef1f6;color:#475069;padding:3px 11px;border-radius:999px;font-size:.78rem;font-weight:700}
.pill.ok{background:#e7f7ef;color:#0b7a45}
.row-actions{display:flex;gap:7px;align-items:center}.row-actions form{margin:0}
.admin-form .form-row{display:flex;gap:14px;flex-wrap:wrap}
.admin-form .form-row>label{flex:1;min-width:160px}
.admin-form label{display:block;font-weight:600;font-size:.88rem;margin-bottom:13px}
.admin-form input,.admin-form textarea,.admin-form select{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;margin-top:5px;font-weight:400}
.admin-form input:focus,.admin-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring)}
.admin-form .check input{width:auto}
.form-actions{display:flex;gap:12px;margin-top:8px}
.admin-grid2{display:flex;gap:22px;flex-wrap:wrap}.admin-grid2>div{flex:1;min-width:280px}
.status-form{display:flex;gap:10px}.status-form select{flex:1;padding:11px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit}

/* Age gate */
.agegate{display:none;position:fixed;inset:0;z-index:9999;background:rgba(15,23,41,.6);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:18px}
.agegate.show{display:flex}
.agegate-box{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 32px;max-width:430px;text-align:center;box-shadow:var(--shadow-lg)}
.agegate-box h2{font-size:1.6rem;margin:8px 0 10px}.agegate-box p{color:var(--muted)}
.agegate-btns{display:flex;gap:10px;justify-content:center;margin-top:20px;flex-wrap:wrap}
.logo-mark.big{font-size:2.6rem;color:var(--brand)}

/* Back to top */
.to-top{position:fixed;right:20px;bottom:20px;width:46px;height:46px;line-height:46px;text-align:center;background:var(--ink);color:#fff;border-radius:50%;font-size:1.3rem;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:50}
.to-top:hover{background:var(--brand)}
.to-top.show{opacity:1;pointer-events:auto}

/* Responsive */
@media(max-width:980px){
  .card{width:50%}
  .hero h1{font-size:2.3rem}.hero-art{display:none}.hero-inner{padding:50px 22px 56px}
  .product-detail,.checkout-grid,.shop-layout{flex-direction:column}
  .pd-media,.filters,.order-summary{width:100%;position:static}
  .admin-wrap{flex-direction:column}.admin-side{width:100%;position:static}
  .nav-toggle{display:block;order:-1}
  .header-inner{flex-wrap:wrap}
  .searchbar{order:3;width:100%;max-width:none;flex-basis:100%}
  .main-nav{display:none;width:100%;flex-direction:column;gap:2px;padding-top:6px;flex-basis:100%}
  .main-nav a{padding:11px 4px;border-top:1px solid var(--line)}
  body.nav-open .main-nav{display:flex}
  .nl-inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){ .card{width:100%} h1{font-size:1.9rem}.hero h1{font-size:1.95rem} .reviews{flex-direction:column} .section{padding:40px 22px} }
