/*
Theme Name: Wtula
Description: Wtula — Nocna Cisza. Quiet-luxury Polish sleep brand theme, v2 conversion-dense DTC layout.
Version: 2.0.0
Author: Wtula
Text Domain: wtula
*/

:root{
  --atrament:#1A2340;
  --atrament-2:#232E52;
  --smietanka:#F3EAD9;
  --mgla:#8C99AD;
  --roz:#C9A296;
  --zloto:#B99B6B;
  --wegiel:#23262B;
  --linia:#E5DCC9;
  --paper:#FAF6EE;
  --shadow:0 20px 60px rgba(26,35,64,.16);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Lato',-apple-system,sans-serif;background:var(--smietanka);color:var(--wegiel);line-height:1.6;font-size:16.5px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,.serif{font-family:'Fraunces',Georgia,serif;font-weight:500;color:var(--atrament)}

.wrap{max-width:1140px;margin:0 auto;padding:0 24px}

/* reveal-on-scroll */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}

/* ===== announcement bar (rotating) ===== */
.wt-bar{background:var(--atrament);color:var(--smietanka);text-align:center;font-size:12.5px;letter-spacing:.8px;padding:9px 12px;position:relative;overflow:hidden;height:36px}
.wt-bar span{position:absolute;left:0;right:0;opacity:0;animation:barRot 12s infinite}
.wt-bar span:nth-child(2){animation-delay:4s}
.wt-bar span:nth-child(3){animation-delay:8s}
@keyframes barRot{0%{opacity:0;transform:translateY(8px)}4%,29%{opacity:1;transform:none}33%,100%{opacity:0;transform:translateY(-8px)}}

/* ===== sticky nav ===== */
.wt-navwrap{position:sticky;top:0;z-index:60;background:rgba(243,234,217,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--linia)}
.wt-nav{display:flex;justify-content:space-between;align-items:center;padding:14px 0}
.wt-logo{font-family:'Fraunces',Georgia,serif;font-size:27px;color:var(--atrament);letter-spacing:.5px}
.wt-logo em{color:var(--roz);font-style:normal}
.wt-links{display:flex;gap:26px;font-size:14.5px;align-items:center;font-weight:600}
.wt-links a{opacity:.85}
.wt-links a:hover{opacity:1;color:var(--atrament)}
.wt-nav-cta{background:var(--atrament);color:var(--smietanka)!important;padding:9px 22px;border-radius:99px;font-size:13.5px;opacity:1!important}
.wt-cart{border:1.5px solid var(--atrament);border-radius:99px;padding:7px 16px;font-weight:700;font-size:13px}

/* ===== buttons ===== */
.btn{display:inline-block;background:var(--atrament);color:var(--smietanka);padding:17px 38px;border-radius:99px;font-size:16px;font-weight:700;letter-spacing:.2px;border:1.5px solid var(--atrament);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s}
.btn:hover{background:var(--atrament-2);transform:translateY(-2px);box-shadow:0 12px 30px rgba(26,35,64,.28)}
.btn.ghost{background:transparent;color:var(--atrament)}
.btn.ghost:hover{background:var(--atrament);color:var(--smietanka)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-note{font-size:12.5px;color:#6b7280;margin-top:10px}

/* ===== hero ===== */
.wt-hero{display:grid;grid-template-columns:1.02fr .98fr;min-height:560px;align-items:center;gap:52px;padding:64px 0 72px}
.wt-kicker{display:inline-block;font-size:11.5px;letter-spacing:3px;text-transform:uppercase;color:var(--roz);font-weight:800;margin-bottom:16px;border:1px solid #e0cfc6;background:#faf3ee;padding:5px 14px;border-radius:99px}
.wt-hero h1{font-size:60px;line-height:1.06;margin-bottom:18px;letter-spacing:-.5px}
.wt-hero h1 .accent{font-style:italic;color:var(--roz)}
.wt-hero p.lead{font-size:18px;color:#4c5265;max-width:460px;margin-bottom:30px}
.wt-chiprow{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.wt-chiprow span{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--atrament);background:#fff;border:1px solid var(--linia);padding:7px 13px;border-radius:99px}
.wt-chiprow svg{width:14px;height:14px;stroke:var(--roz)}
.wt-hero-vis{position:relative}
.wt-hero-vis img{border-radius:20px;box-shadow:var(--shadow)}
.wt-float{position:absolute;background:rgba(250,246,238,.95);backdrop-filter:blur(6px);border:1px solid var(--linia);border-radius:14px;padding:12px 18px;box-shadow:0 12px 34px rgba(26,35,64,.18)}
.wt-float b{font-family:'Fraunces',Georgia,serif;font-size:21px;color:var(--atrament);display:block;line-height:1.1}
.wt-float small{font-size:11.5px;color:#6b7280}
.wt-float.f1{bottom:26px;left:-24px}
.wt-float.f2{top:30px;right:-16px}

/* ===== marquee ===== */
.wt-marquee{background:var(--atrament);color:var(--smietanka);overflow:hidden;padding:13px 0;border-top:1px solid #33406e;border-bottom:1px solid #33406e}
.wt-marquee .track{display:flex;gap:0;white-space:nowrap;animation:mq 30s linear infinite;width:max-content}
.wt-marquee span{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:15.5px;padding:0 26px;opacity:.92}
.wt-marquee span::after{content:"·";margin-left:52px;color:var(--roz)}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== benefit icons ===== */
.wt-bene{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:58px 0 8px}
.wt-bene .b{text-align:center;padding:26px 18px;background:var(--paper);border:1px solid var(--linia);border-radius:16px;transition:transform .18s}
.wt-bene .b:hover{transform:translateY(-4px)}
.wt-bene svg{width:34px;height:34px;stroke:var(--atrament);margin:0 auto 12px}
.wt-bene h3{font-size:15.5px;margin-bottom:4px}
.wt-bene p{font-size:13px;color:#6b7280}

/* ===== sections ===== */
section{padding:76px 0}
.wt-eyebrow{font-size:11.5px;letter-spacing:3px;text-transform:uppercase;color:var(--roz);font-weight:800;margin-bottom:10px}
.wt-h2{font-size:40px;margin-bottom:12px;letter-spacing:-.3px}
.wt-sub{color:#4c5265;max-width:600px;margin-bottom:40px;font-size:16.5px}
.center{text-align:center}
.center .wt-sub{margin-left:auto;margin-right:auto}

/* ===== annotated diagram ===== */
.wt-diag{position:relative;max-width:640px;margin:0 auto}
.wt-diag img{border-radius:20px;box-shadow:var(--shadow)}
.wt-call{position:absolute;display:flex;align-items:center;gap:10px}
.wt-call .dot{width:14px;height:14px;border-radius:50%;background:var(--roz);border:3px solid #fff;box-shadow:0 0 0 3px rgba(201,162,150,.35);flex-shrink:0;animation:pulse 2.6s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(201,162,150,.35)}50%{box-shadow:0 0 0 8px rgba(201,162,150,.12)}}
.wt-call .lbl{background:#fff;border:1px solid var(--linia);border-radius:10px;padding:8px 13px;font-size:12.5px;font-weight:700;color:var(--atrament);box-shadow:0 8px 24px rgba(26,35,64,.14);max-width:190px;line-height:1.35}
.wt-call .lbl small{display:block;font-weight:400;color:#6b7280;font-size:11.5px}

/* ===== steps (night) ===== */
.wt-night{background:var(--atrament);color:var(--smietanka)}
.wt-night .wt-h2{color:var(--smietanka)}
.wt-night .wt-sub{color:#b8c0d4}
.wt-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.wt-step{background:#222C50;border:1px solid #33406e;border-radius:18px;overflow:hidden;transition:transform .18s}
.wt-step:hover{transform:translateY(-4px)}
.wt-step img{aspect-ratio:4/3;object-fit:cover;width:100%}
.wt-step .in{padding:22px 24px 26px}
.wt-step .n{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:15px;color:var(--roz);letter-spacing:1px}
.wt-step h3{font-size:22px;margin:6px 0 8px;color:var(--smietanka)}
.wt-step p{font-size:14px;color:#b8c0d4}

/* ===== comparison ===== */
.wt-cmp{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--linia);box-shadow:0 14px 44px rgba(26,35,64,.08)}
.wt-cmp th,.wt-cmp td{padding:16px 18px;font-size:14.5px;text-align:center;border-bottom:1px solid #f0ead9}
.wt-cmp th{background:var(--paper);font-family:'Fraunces',Georgia,serif;font-size:16px;color:var(--atrament);font-weight:600}
.wt-cmp th.wt-col{background:var(--atrament);color:var(--smietanka)}
.wt-cmp td:first-child{text-align:left;font-weight:600;color:#3d4356}
.wt-cmp td.wt-col{background:#f2f0ff0d;background:#f7f3ea;font-weight:800;color:var(--atrament)}
.wt-cmp tr:last-child td{border-bottom:none}
.ok{color:#166534;font-weight:900}
.no{color:#b3b8c4;font-weight:700}

/* ===== offer ===== */
.wt-offer{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.wt-offer-vis{position:relative}
.wt-offer-vis img{border-radius:20px;box-shadow:var(--shadow)}
.wt-badge{position:absolute;top:18px;left:18px;background:var(--roz);color:#fff;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:7px 15px;border-radius:99px;box-shadow:0 8px 20px rgba(201,162,150,.4)}
.wt-price{font-family:'Fraunces',Georgia,serif;font-size:44px;color:var(--atrament);margin:16px 0 4px}
.wt-price s{color:#9aa1b3;font-size:26px;margin-left:14px;font-weight:400}
.wt-save{display:inline-block;background:#EDE4D2;color:#7a6633;font-size:12.5px;font-weight:800;padding:5px 14px;border-radius:99px;margin-bottom:22px}
.wt-incl{list-style:none;margin:0 0 26px}
.wt-incl li{display:flex;align-items:center;gap:12px;padding:11px 0;font-size:15.5px;color:#3d4356;border-bottom:1px solid var(--linia)}
.wt-incl img{width:46px;height:46px;border-radius:10px;object-fit:cover;border:1px solid var(--linia)}
.wt-pay{display:flex;gap:8px;margin-top:16px;align-items:center}
.wt-pay span{font-size:11px;font-weight:800;letter-spacing:.5px;border:1px solid var(--linia);background:#fff;border-radius:6px;padding:5px 10px;color:#3d4356}

/* ===== product grid ===== */
.wt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.wt-card{background:var(--paper);border:1px solid var(--linia);border-radius:18px;overflow:hidden;transition:transform .18s,box-shadow .18s;position:relative}
.wt-card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(26,35,64,.14)}
.wt-card img{aspect-ratio:1;object-fit:cover}
.wt-card .in{padding:16px 18px 20px}
.wt-card h3{font-size:16.5px;margin-bottom:4px}
.wt-card .p{font-size:16px;color:var(--atrament);font-weight:800}
.wt-card .p small{color:#8b90a0;font-weight:400}
.wt-card .tag{position:absolute;top:12px;left:12px;background:var(--atrament);color:var(--smietanka);font-size:10.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;padding:5px 11px;border-radius:99px}

/* ===== guarantee band ===== */
.wt-guar{background:var(--atrament);color:var(--smietanka);padding:54px 0}
.wt-guar .row{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;text-align:center}
.wt-guar svg{width:30px;height:30px;stroke:var(--roz);margin:0 auto 10px}
.wt-guar b{font-family:'Fraunces',Georgia,serif;font-size:19px;font-weight:500;display:block;margin-bottom:4px;color:var(--smietanka)}
.wt-guar p{font-size:13.5px;color:#b8c0d4}

/* ===== FAQ ===== */
.wt-faq{max-width:760px;margin:0 auto}
.wt-faq details{background:#fff;border:1px solid var(--linia);border-radius:14px;padding:20px 24px;margin:10px 0;transition:box-shadow .15s}
.wt-faq details[open]{box-shadow:0 12px 34px rgba(26,35,64,.08)}
.wt-faq summary{cursor:pointer;font-weight:700;font-size:16.5px;color:var(--atrament);list-style:none;display:flex;justify-content:space-between;align-items:center}
.wt-faq summary::-webkit-details-marker{display:none}
.wt-faq summary::after{content:"+";font-family:'Fraunces',Georgia,serif;font-size:24px;color:var(--roz);transition:transform .2s}
.wt-faq details[open] summary::after{transform:rotate(45deg)}
.wt-faq p{margin-top:12px;color:#4c5265;font-size:15px}

/* ===== newsletter ===== */
.wt-news{background:var(--paper);border-top:1px solid var(--linia);border-bottom:1px solid var(--linia)}
.wt-news .inner{max-width:620px;margin:0 auto;text-align:center}
.wt-news form{display:flex;gap:10px;margin-top:24px}
.wt-news input[type=email]{flex:1;padding:15px 20px;border:1.5px solid var(--linia);border-radius:99px;font-size:15px;background:#fff;font-family:inherit}
.wt-news input[type=email]:focus{outline:none;border-color:var(--atrament)}
.wt-ok{background:#e8f5ee;border:1px solid #bfe3cf;color:#166534;border-radius:12px;padding:12px;margin-top:18px;font-size:14px}

/* ===== footer ===== */
.wt-footer{background:var(--atrament);color:#b8c0d4;padding:60px 0 36px;font-size:14px}
.wt-footer .wt-logo{color:var(--smietanka);margin-bottom:14px}
.wt-footer-cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;margin-bottom:34px}
.wt-footer a:hover{color:var(--smietanka)}
.wt-footer ul{list-style:none}
.wt-footer li{margin:8px 0}
.wt-footer .fine{border-top:1px solid #33406e;padding-top:22px;font-size:12px;color:#8b93ab;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}

/* ===== sticky mobile ATC ===== */
.wt-sticky{position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(250,246,238,.97);backdrop-filter:blur(10px);border-top:1px solid var(--linia);padding:10px 16px;display:none;align-items:center;justify-content:space-between;gap:12px;transform:translateY(110%);transition:transform .3s}
.wt-sticky.show{transform:none}
.wt-sticky .pr{font-family:'Fraunces',Georgia,serif;font-size:19px;color:var(--atrament)}
.wt-sticky .pr s{font-size:13px;color:#9aa1b3}
.wt-sticky .btn{padding:12px 24px;font-size:14px}

/* ===== woocommerce brand overrides ===== */
.woocommerce .button,.woocommerce button.button,.woocommerce a.button,.woocommerce input.button,.wc-block-components-button,.woocommerce #payment #place_order{background:var(--atrament)!important;color:var(--smietanka)!important;border-radius:99px!important;padding:14px 30px!important;font-weight:700!important;border:none!important}
.woocommerce ins{text-decoration:none}
.woocommerce div.product p.price{color:var(--atrament);font-family:'Fraunces',Georgia,serif;font-size:28px}
.woocommerce-message,.woocommerce-info{border-top-color:var(--roz)!important}
.wt-page{max-width:860px;margin:0 auto;padding:52px 24px}
.wt-page h1{font-size:38px;margin-bottom:20px}
.wt-page h2{font-size:23px;margin:28px 0 10px}
.wt-page p,.wt-page li{color:#3d4356;font-size:15px;margin-bottom:10px}

@media(max-width:920px){
  .wt-hero{grid-template-columns:1fr;padding:40px 0;min-height:0;gap:34px}
  .wt-hero h1{font-size:42px}
  .wt-bene{grid-template-columns:repeat(2,1fr)}
  .wt-offer{grid-template-columns:1fr;gap:30px}
  .wt-steps{grid-template-columns:1fr}
  .wt-grid{grid-template-columns:repeat(2,1fr)}
  .wt-guar .row{grid-template-columns:1fr;gap:20px}
  .wt-footer-cols{grid-template-columns:1fr}
  .wt-links{display:none}
  .wt-sticky{display:flex}
  .wt-float.f1{left:8px;bottom:12px}
  .wt-float.f2{right:8px;top:12px}
  .wt-h2{font-size:30px}
  .wt-news form{flex-direction:column}
  .wt-call .lbl{max-width:150px;font-size:11px}
}
