/* ==========================================================================
   OZCORP fishing — unified site prototype
   Design language: Superior Fishing Products (rugged premium) + Scotty (clean
   nautical grid). Palette: deep slate navy + warm amber accent + steel tones.
   ========================================================================== */

:root{
  --bg:#f4f3ef;
  --surface:#ffffff;
  --ink:#13232e;          /* deep slate navy — primary dark */
  --ink-2:#1d3340;
  --ink-soft:#33444f;
  --muted:#6b7984;
  --line:#e4e2db;
  --line-2:#d6d3ca;
  --accent:#d6892f;       /* amber / rugged outdoor */
  --accent-dk:#b56f1f;
  --accent-soft:#fbf1e3;
  --steel-1:#cfd6db;
  --steel-2:#9aa6ae;
  --ok:#2e7d4f;
  --danger:#c0492f;
  --shadow-sm:0 1px 3px rgba(19,35,46,.08), 0 1px 2px rgba(19,35,46,.06);
  --shadow:0 10px 30px -12px rgba(19,35,46,.25);
  --shadow-lg:0 30px 60px -20px rgba(19,35,46,.4);
  --radius:14px;
  --radius-sm:9px;
  --maxw:1240px;
  --header-h:76px;
  --font-head:"Oswald",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  --font-script:"Satisfy",cursive;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}

/* ---- Typography ---------------------------------------------------------- */
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.08;letter-spacing:.01em;color:var(--ink)}
.eyebrow{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.22em;
  font-size:.78rem;font-weight:600;color:var(--accent-dk)}
.section-head{max-width:680px;margin:0 auto 48px;text-align:center}
.section-head h2{font-size:clamp(1.9rem,4vw,2.9rem);text-transform:uppercase;margin:.4rem 0 .6rem}
.section-head p{color:var(--muted);font-size:1.05rem}
.section-pad{padding:clamp(64px,9vw,112px) 0}

/* ---- Buttons ------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-head);
  text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:.92rem;
  padding:.85em 1.6em;border-radius:var(--radius-sm);transition:.18s ease;
  white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px -6px rgba(214,137,47,.7)}
.btn-primary:hover{background:var(--accent-dk);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-2);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn-outline{border:1.5px solid var(--line-2);color:var(--ink);background:var(--surface)}
.btn-outline:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn-block{width:100%;justify-content:center}
.btn-lg{padding:1.05em 2em;font-size:1rem}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ---- Announcement bar ---------------------------------------------------- */
.topbar{background:var(--ink);color:#dfe6ea;font-size:.82rem;text-align:center;
  padding:8px 16px;letter-spacing:.03em}
.topbar strong{color:#fff}

/* ---- Header -------------------------------------------------------------- */
.header{position:sticky;top:0;z-index:60;background:rgba(19,35,46,.0);
  transition:background .25s ease,box-shadow .25s ease;height:var(--header-h)}
.header.solid{background:rgba(19,35,46,.97);box-shadow:0 6px 24px -10px rgba(0,0,0,.5);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.header-inner{display:flex;align-items:center;gap:28px;height:var(--header-h)}
.logo{display:flex;align-items:baseline;gap:.18em;line-height:1}
.logo .mark{font-family:var(--font-head);font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;font-size:1.5rem;color:#fff}
.logo .script{font-family:var(--font-script);font-size:1.7rem;color:var(--accent);
  margin-left:.05em;transform:translateY(2px)}
.nav{display:flex;gap:26px;margin-left:auto}
.nav a{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.09em;
  font-size:.86rem;font-weight:500;color:#e7edf0;padding:6px 0;position:relative;opacity:.9}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--accent);transition:width .2s}
.nav a:hover{opacity:1}.nav a:hover::after{width:100%}
.header-tools{display:flex;align-items:center;gap:14px}
.lang{display:flex;align-items:center;border:1px solid rgba(255,255,255,.3);border-radius:30px;overflow:hidden}
.lang button{padding:5px 11px;font-family:var(--font-head);font-size:.78rem;font-weight:600;
  letter-spacing:.06em;color:#cdd7dd}
.lang button.active{background:var(--accent);color:#fff}
.icon-btn{position:relative;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  color:#fff;transition:.18s}
.icon-btn:hover{background:rgba(255,255,255,.12)}
.icon-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8}
.cart-count{position:absolute;top:2px;right:0;background:var(--accent);color:#fff;
  font-family:var(--font-body);font-size:.66rem;font-weight:700;min-width:18px;height:18px;
  border-radius:10px;display:grid;place-items:center;padding:0 5px;transform:scale(0);transition:transform .2s}
.cart-count.show{transform:scale(1)}
.burger{display:none}

/* ---- Hero ---------------------------------------------------------------- */
.hero{position:relative;min-height:clamp(560px,92vh,860px);display:flex;align-items:center;
  margin-top:calc(-1 * var(--header-h));color:#fff}
.hero-bg{position:absolute;inset:0;z-index:-2;background:#0c1820 center/cover no-repeat}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg,rgba(10,22,30,.86) 0%,rgba(10,22,30,.55) 45%,rgba(10,22,30,.15) 100%)}
.hero-inner{padding-top:var(--header-h);max-width:660px}
.hero .eyebrow{color:#f0c98a}
.hero h1{font-size:clamp(2.6rem,6.2vw,4.7rem);text-transform:uppercase;color:#fff;margin:.5rem 0 1.1rem}
.hero h1 .hl{color:var(--accent)}
.hero p{font-size:1.18rem;color:#dde6ea;max-width:520px;margin-bottom:2rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:28px;margin-top:46px;flex-wrap:wrap}
.hero-badges div{font-size:.86rem;color:#cdd8de}
.hero-badges b{display:block;font-family:var(--font-head);font-size:1.5rem;color:#fff;letter-spacing:.02em}

/* ---- Feature strip ------------------------------------------------------- */
.features{background:var(--ink);color:#fff}
.features .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.08);
  border-radius:var(--radius);overflow:hidden;transform:translateY(-50%);box-shadow:var(--shadow)}
.feature{background:var(--ink);padding:30px 26px;display:flex;gap:16px;align-items:flex-start}
.feature svg{width:34px;height:34px;stroke:var(--accent);fill:none;stroke-width:1.6;flex:none}
.feature h4{font-size:1rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}
.feature p{font-size:.85rem;color:#a9b6bd;line-height:1.45}
.features-spacer{height:0}

/* ---- Categories ---------------------------------------------------------- */
.cats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat-card{position:relative;border:1px solid var(--line);background:var(--surface);
  border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;gap:10px;
  transition:.2s;overflow:hidden;cursor:pointer}
.cat-card::before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:var(--accent);
  transform:scaleY(0);transform-origin:top;transition:transform .25s}
.cat-card:hover{border-color:var(--line-2);box-shadow:var(--shadow);transform:translateY(-3px)}
.cat-card:hover::before{transform:scaleY(1)}
.cat-card .cnum{font-family:var(--font-head);font-size:.8rem;color:var(--accent-dk);letter-spacing:.1em}
.cat-card h3{font-size:1.32rem;text-transform:uppercase}
.cat-card p{font-size:.9rem;color:var(--muted)}
.cat-card .more{margin-top:auto;font-family:var(--font-head);text-transform:uppercase;
  font-size:.8rem;letter-spacing:.1em;color:var(--ink);display:flex;align-items:center;gap:6px}
.cat-card .more span{transition:transform .2s}.cat-card:hover .more span{transform:translateX(4px)}

/* ---- Shop / products ----------------------------------------------------- */
.shop{background:var(--surface)}
.filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:38px}
.filters button{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;
  font-size:.82rem;font-weight:500;padding:.6em 1.15em;border-radius:30px;border:1px solid var(--line-2);
  color:var(--ink-soft);background:var(--surface);transition:.16s}
.filters button:hover{border-color:var(--ink)}
.filters button.active{background:var(--ink);color:#fff;border-color:var(--ink)}

.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:var(--line-2)}
.card .thumb{position:relative;aspect-ratio:1/1;background:#f0eee9;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .thumb img{transform:scale(1.05)}
.card .thumb .ph{width:100%;height:100%;display:grid;place-items:center;color:var(--steel-2)}
.card .thumb .ph svg{width:60px;height:60px;stroke:currentColor;fill:none;stroke-width:1}
.card .quick{position:absolute;inset:auto 10px 10px;display:flex;justify-content:center;
  opacity:0;transform:translateY(8px);transition:.2s}
.card:hover .quick{opacity:1;transform:none}
.card .quick button{background:rgba(19,35,46,.92);color:#fff;font-family:var(--font-head);
  text-transform:uppercase;font-size:.74rem;letter-spacing:.08em;padding:.6em 1.1em;border-radius:30px;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.card .quick button:hover{background:var(--accent)}
.tag{position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;font-family:var(--font-head);
  font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;padding:.35em .7em;border-radius:4px}
.card .body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-dk);font-weight:600}
.card h3{font-size:1.04rem;font-family:var(--font-body);font-weight:600;line-height:1.3}
.card .price{font-family:var(--font-head);font-size:1.3rem;font-weight:600;margin-top:2px}
.card .add{margin-top:12px;display:flex;align-items:center;justify-content:center;gap:.5em;
  width:100%;background:var(--accent-soft);color:var(--accent-dk);border:1px solid #f0dcc0;
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;
  padding:.7em;border-radius:var(--radius-sm);transition:.16s}
.card .add:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.card .add svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.9}

/* ---- Custom manufacturing (split) --------------------------------------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:0;
  background:var(--ink);color:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.split .media{position:relative;min-height:420px}
.split .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split .copy{padding:clamp(34px,5vw,64px)}
.split .copy h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.6rem);text-transform:uppercase;margin:.5rem 0 1rem}
.split .copy p{color:#bcc8cf;margin-bottom:1.4rem}
.split .copy .eyebrow{color:#f0c98a}
.checklist{display:grid;gap:12px;margin-bottom:2rem}
.checklist li{display:flex;gap:11px;align-items:flex-start;font-size:.96rem;color:#dde5e9}
.checklist svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:2;flex:none;margin-top:3px}

/* ---- Brand / story ------------------------------------------------------- */
.story{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.story .imgs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.story .imgs img{border-radius:var(--radius);height:100%;object-fit:cover;box-shadow:var(--shadow)}
.story .imgs img:first-child{grid-row:span 2;height:100%}
.story h2{font-size:clamp(1.9rem,3.6vw,2.8rem);text-transform:uppercase;margin:.5rem 0 1rem}
.story p{color:var(--ink-soft);margin-bottom:1rem}
.stats{display:flex;gap:36px;margin-top:26px}
.stats b{font-family:var(--font-head);font-size:2.2rem;color:var(--accent-dk);display:block;line-height:1}
.stats span{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* ---- Reviews ------------------------------------------------------------- */
.reviews{background:var(--ink);color:#fff}
.reviews .section-head h2{color:#fff}.reviews .section-head p{color:#aebac1}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:var(--ink-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:28px}
.stars{color:var(--accent);letter-spacing:3px;margin-bottom:12px;font-size:1.05rem}
.review p{color:#dbe3e7;font-style:italic;margin-bottom:16px}
.review .who{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;font-size:.9rem}
.review .who span{display:block;font-family:var(--font-body);text-transform:none;letter-spacing:0;
  color:#93a1a9;font-size:.8rem;font-style:normal}

/* ---- Contact ------------------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px}
.contact-info h2{font-size:clamp(1.8rem,3.4vw,2.6rem);text-transform:uppercase;margin:.4rem 0 1.2rem}
.contact-info .row{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.contact-info .row svg{width:24px;height:24px;stroke:var(--accent-dk);fill:none;stroke-width:1.7;flex:none;margin-top:2px}
.contact-info .row b{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}
.contact-info .row span{color:var(--muted)}
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;
  font-size:.76rem;color:var(--ink-soft);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;border:1px solid var(--line-2);border-radius:var(--radius-sm);
  padding:.8em .9em;font-family:inherit;font-size:.95rem;color:var(--ink);background:#fcfcfb;transition:.16s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(214,137,47,.15)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---- Footer -------------------------------------------------------------- */
.footer{background:#0c1820;color:#9fadb4;padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.footer .logo .mark{font-size:1.35rem}.footer .logo{margin-bottom:14px}
.footer p{font-size:.9rem;max-width:280px}
.footer h4{color:#fff;text-transform:uppercase;letter-spacing:.08em;font-size:.92rem;margin-bottom:16px}
.footer ul li{margin-bottom:9px}
.footer ul a{font-size:.9rem;transition:.15s}.footer ul a:hover{color:var(--accent)}
.socials{display:flex;gap:10px;margin-top:16px}
.socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);
  display:grid;place-items:center;transition:.18s}
.socials a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.socials svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;
  justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:.82rem}
.pay{display:flex;gap:8px;align-items:center}
.pay span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:5px;
  padding:4px 9px;font-family:var(--font-head);font-size:.7rem;letter-spacing:.05em;color:#c4ced3}

/* ---- Cart drawer --------------------------------------------------------- */
.overlay{position:fixed;inset:0;background:rgba(8,16,22,.55);z-index:90;opacity:0;visibility:hidden;
  transition:.25s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,100%);background:var(--bg);z-index:100;
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:var(--shadow-lg)}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;
  border-bottom:1px solid var(--line);background:var(--surface)}
.drawer-head h3{text-transform:uppercase;font-size:1.2rem}
.drawer-close{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:var(--ink)}
.drawer-close:hover{background:var(--line)}
.drawer-close svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none}
.cart-items{flex:1;overflow-y:auto;padding:16px 24px}
.cart-empty{text-align:center;color:var(--muted);padding:60px 20px}
.cart-empty svg{width:64px;height:64px;stroke:var(--line-2);fill:none;stroke-width:1.2;margin:0 auto 16px}
.citem{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.citem img{width:74px;height:74px;object-fit:cover;border-radius:var(--radius-sm);background:#eee;flex:none}
.citem .ci-body{flex:1;min-width:0}
.citem h4{font-family:var(--font-body);font-size:.95rem;font-weight:600;margin-bottom:2px}
.citem .ci-cat{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.citem .ci-price{font-family:var(--font-head);font-size:1.05rem;margin-top:6px}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line-2);border-radius:30px;margin-top:8px}
.qty button{width:30px;height:30px;font-size:1.1rem;color:var(--ink-soft);display:grid;place-items:center}
.qty button:hover{color:var(--accent-dk)}
.qty span{min-width:26px;text-align:center;font-weight:600;font-size:.9rem}
.ci-remove{margin-left:auto;align-self:flex-start;color:var(--muted);font-size:.78rem;
  display:flex;align-items:center;gap:4px}
.ci-remove:hover{color:var(--danger)}
.ci-remove svg{width:15px;height:15px;stroke:currentColor;stroke-width:1.8;fill:none}
.drawer-foot{border-top:1px solid var(--line);background:var(--surface);padding:22px 24px}
.sumrow{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.92rem;color:var(--ink-soft)}
.sumrow.total{font-family:var(--font-head);font-size:1.35rem;color:var(--ink);margin:14px 0 18px;
  padding-top:14px;border-top:1px solid var(--line)}

/* ---- Modal (product quickview + checkout + confirmation) ----------------- */
.modal{position:fixed;inset:0;z-index:110;display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;visibility:hidden;transition:.22s}
.modal.open{opacity:1;visibility:visible}
.modal-box{background:var(--bg);border-radius:var(--radius);max-width:920px;width:100%;
  max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg);transform:translateY(16px) scale(.98);transition:.25s}
.modal.open .modal-box{transform:none}
.modal-box.narrow{max-width:560px}
.modal-x{position:absolute;top:18px;right:18px;z-index:5;width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.9);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.modal-x svg{width:22px;height:22px;stroke:var(--ink);stroke-width:2;fill:none}
/* quickview */
.qv{display:grid;grid-template-columns:1fr 1fr}
.qv .qv-img{background:#f0eee9;aspect-ratio:1/1}
.qv .qv-img img{width:100%;height:100%;object-fit:cover}
.qv .qv-info{padding:38px 36px}
.qv .cat{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-dk);font-weight:600}
.qv h2{font-size:1.7rem;font-family:var(--font-body);font-weight:700;margin:6px 0 10px}
.qv .price{font-family:var(--font-head);font-size:1.9rem;margin-bottom:16px}
.qv .desc{color:var(--ink-soft);font-size:.95rem;margin-bottom:24px}
.qv .qv-actions{display:flex;gap:12px;align-items:center}

/* checkout */
.checkout{padding:34px 36px}
.checkout h2{text-transform:uppercase;font-size:1.6rem;margin-bottom:4px}
.checkout .sub{color:var(--muted);margin-bottom:24px;font-size:.92rem}
.co-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:32px}
.pay-opts,.ship-opts{display:grid;gap:10px;margin-top:6px}
.opt{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line-2);border-radius:var(--radius-sm);
  padding:14px 16px;cursor:pointer;transition:.15s;background:#fcfcfb}
.opt:hover{border-color:var(--ink-soft)}
.opt.sel{border-color:var(--accent);background:var(--accent-soft)}
.opt input{margin-top:3px;accent-color:var(--accent)}
.opt b{font-family:var(--font-head);text-transform:uppercase;font-size:.86rem;letter-spacing:.04em}
.opt small{color:var(--muted);display:block;font-size:.8rem}
.co-summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;height:fit-content}
.co-summary h3{text-transform:uppercase;font-size:1.05rem;margin-bottom:16px}
.co-line{display:flex;justify-content:space-between;gap:10px;font-size:.88rem;margin-bottom:10px;color:var(--ink-soft)}
.co-line .qn{color:var(--muted)}
.co-total{display:flex;justify-content:space-between;font-family:var(--font-head);font-size:1.3rem;
  margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.legal{font-size:.78rem;color:var(--muted);margin-top:14px}

/* confirmation */
.confirm{padding:48px 40px;text-align:center}
.confirm .ok-ic{width:84px;height:84px;border-radius:50%;background:var(--accent-soft);display:grid;
  place-items:center;margin:0 auto 22px}
.confirm .ok-ic svg{width:44px;height:44px;stroke:var(--accent-dk);stroke-width:2.2;fill:none}
.confirm h2{text-transform:uppercase;font-size:1.8rem;margin-bottom:8px}
.confirm p{color:var(--ink-soft);max-width:440px;margin:0 auto 8px}
.confirm .ordno{font-family:var(--font-head);font-size:1.1rem;color:var(--accent-dk);margin:18px 0 26px}

/* ---- Misc ---------------------------------------------------------------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120%);
  background:var(--ink);color:#fff;padding:14px 24px;border-radius:30px;z-index:200;display:flex;gap:10px;
  align-items:center;box-shadow:var(--shadow-lg);transition:transform .3s;font-size:.92rem}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast svg{width:20px;height:20px;stroke:var(--accent);stroke-width:2;fill:none}
[hidden]{display:none!important}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---- Responsive ---------------------------------------------------------- */
@media(max-width:1080px){
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .features .wrap{grid-template-columns:1fr 1fr;transform:translateY(-30px)}
  .cats-grid{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}.split .media{min-height:280px}
  .story{grid-template-columns:1fr;gap:34px}
  .reviews-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .co-grid{grid-template-columns:1fr}
  .qv{grid-template-columns:1fr}.qv .qv-img{aspect-ratio:16/10}
}
@media(max-width:680px){
  .nav{display:none}
  .burger{display:grid}
  .products-grid{grid-template-columns:1fr 1fr;gap:14px}
  .cats-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-badges{gap:20px}
  .field-row{grid-template-columns:1fr}
  .header-tools .lang{order:-1}
}
@media(max-width:420px){
  .products-grid{grid-template-columns:1fr}
}

/* ---- Cookie consent ------------------------------------------------------ */
.cookiebar{position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--ink);color:#dfe6ea;
  box-shadow:0 -10px 30px -12px rgba(0,0,0,.5);transform:translateY(110%);transition:transform .35s ease}
.cookiebar.show{transform:none}
.cookiebar .wrap{display:flex;align-items:center;gap:24px;padding:18px 24px;flex-wrap:wrap}
.cookiebar p{font-size:.9rem;flex:1;min-width:240px;color:#c4ced3}
.cookiebar p a{color:var(--accent);text-decoration:underline}
.cookiebar .cb-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookiebar .btn{font-size:.82rem;padding:.7em 1.3em}

/* ---- Legal page ---------------------------------------------------------- */
.legal-hero{background:var(--ink);color:#fff;padding:calc(var(--header-h) + 40px) 0 40px}
.legal-hero .eyebrow{color:#f0c98a}
.legal-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);text-transform:uppercase;margin-top:.4rem}
.legal-layout{display:grid;grid-template-columns:280px 1fr;gap:48px;padding:48px 0 90px}
.legal-nav{position:sticky;top:calc(var(--header-h) + 20px);height:fit-content;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.legal-nav a{display:block;padding:13px 18px;font-size:.9rem;color:var(--ink-soft);
  border-bottom:1px solid var(--line);transition:.15s}
.legal-nav a:last-child{border-bottom:none}
.legal-nav a:hover{background:var(--bg)}
.legal-nav a.active{background:var(--accent-soft);color:var(--accent-dk);font-weight:600;
  box-shadow:inset 3px 0 0 var(--accent)}
.legal-content{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(28px,4vw,56px);min-height:400px}
.prose{color:var(--ink-soft);font-size:.96rem;line-height:1.7;max-width:760px}
.prose h1,.prose h2,.prose h3{font-family:var(--font-body);color:var(--ink);margin:1.6em 0 .5em;line-height:1.3}
.prose h1{font-size:1.7rem}.prose h2{font-size:1.3rem}.prose h3{font-size:1.1rem}
.prose h1:first-child,.prose h2:first-child,.prose h3:first-child{margin-top:0}
.prose p{margin:0 0 .9em}
.prose ul,.prose ol{margin:0 0 1em 1.3em}.prose li{margin-bottom:.4em}
.prose a{color:var(--accent-dk);text-decoration:underline}
.prose strong{color:var(--ink)}
.prose table{border-collapse:collapse;width:100%;margin:1em 0;font-size:.9rem}
.prose td,.prose th{border:1px solid var(--line-2);padding:8px 10px;text-align:left}
.prose .note{font-size:.85rem;color:var(--muted);border-left:3px solid var(--line-2);
  padding:8px 0 8px 14px;margin-top:1.4em;font-style:italic}
.prose hr{border:none;border-top:1px solid var(--line);margin:1.6em 0}
.legal-update{font-size:.82rem;color:var(--muted);margin-top:28px;padding-top:18px;border-top:1px solid var(--line)}

/* ---- Withdrawal (odstoupení) modal --------------------------------------- */
.wd-box{padding:36px}
.wd-box h2{text-transform:uppercase;font-size:1.55rem;margin-bottom:6px}
.wd-box .sub{color:var(--muted);font-size:.92rem;margin-bottom:22px}
.wd-step{display:none}.wd-step.active{display:block}
.wd-info{background:var(--accent-soft);border:1px solid #f0dcc0;border-radius:var(--radius-sm);
  padding:14px 16px;font-size:.86rem;color:var(--accent-dk);margin-bottom:20px;display:flex;gap:10px}
.wd-info svg{width:20px;height:20px;stroke:var(--accent-dk);fill:none;stroke-width:1.8;flex:none;margin-top:1px}
.wd-confirm-line{display:flex;gap:10px;align-items:flex-start;margin:18px 0;font-size:.9rem}
.wd-confirm-line input{margin-top:3px;accent-color:var(--accent)}
.seller-block{font-size:.86rem;color:var(--muted);line-height:1.6}
.seller-block b{color:#fff;font-family:var(--font-head);letter-spacing:.03em;display:block;margin-bottom:4px}

/* footer legal link button */
.foot-legal-btn{background:none;border:1px solid rgba(255,255,255,.25);color:#cdd7dd;
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;
  padding:.6em 1.1em;border-radius:var(--radius-sm);transition:.16s;display:inline-flex;align-items:center;gap:.5em}
.foot-legal-btn:hover{border-color:var(--accent);color:#fff}
.foot-legal-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}

@media(max-width:880px){.legal-layout{grid-template-columns:1fr;gap:24px}
  .legal-nav{position:static;display:flex;flex-wrap:wrap}
  .legal-nav a{border-bottom:none;border-right:1px solid var(--line);flex:1;text-align:center;min-width:140px}}

/* mobile nav panel */
.mnav{position:fixed;inset:0 0 0 auto;width:min(320px,85%);background:var(--ink);z-index:105;
  transform:translateX(100%);transition:transform .3s;padding:90px 30px 30px;display:flex;flex-direction:column;gap:8px}
.mnav.open{transform:none}
.mnav a{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;color:#e7edf0;
  font-size:1.1rem;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
