:root{
  --bg:#fffaf8;
  --surface:#ffffff;
  --surface-soft:#fff2f7;
  --surface-tint:#f7f7fb;
  --text:#1f2430;
  --muted:#667085;
  --line:#ece8ee;
  --line-strong:#ddd5e2;
  --brand:#c43b72;
  --brand-strong:#a22f5c;
  --brand-soft:#fce7f1;
  --accent:#6d55d8;
  --success:#1f8f5f;
  --shadow-sm:0 10px 30px rgba(22,24,35,.06);
  --shadow-md:0 20px 50px rgba(22,24,35,.08);
  --radius:20px;
  --radius-sm:14px;
  --container:min(1180px, calc(100vw - 32px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:linear-gradient(180deg,#fff9f8 0%,#fff 22%,#fff 100%);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
input,select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:14px;padding:13px 14px;background:#fff;color:var(--text);outline:none;transition:border-color .2s ease,box-shadow .2s ease}
input:focus,select:focus,textarea:focus{border-color:rgba(196,59,114,.5);box-shadow:0 0 0 4px rgba(196,59,114,.08)}
textarea{resize:vertical;min-height:120px}
.container{width:var(--container);margin:0 auto}
.mobile-only{display:none!important}
.desktop-only-inline{display:inline-flex}

.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(236,232,238,.95)}
.header-shell{display:grid;grid-template-columns:auto minmax(220px,420px) 1fr auto;align-items:center;gap:18px;min-height:82px}
.brand,.brand-inline{display:inline-flex;align-items:center;gap:12px;min-width:0}
.brand-mark{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),#e56895);color:#fff;font-weight:800;letter-spacing:.02em;box-shadow:var(--shadow-sm);flex:0 0 44px}
.brand-copy{display:grid;gap:2px;min-width:0}
.brand-copy strong{font-size:18px;line-height:1.1}
.brand-copy small{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.header-search{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.header-search input{background:#fff}
.header-search button{height:48px;padding:0 16px;border:none;border-radius:14px;background:var(--brand);color:#fff;font-weight:700}
.desktop-nav{display:flex;justify-content:center;gap:16px;align-items:center;overflow:auto}
.desktop-nav a{font-size:14px;color:#475467;font-weight:600;padding:8px 2px;white-space:nowrap}
.desktop-nav a:hover{color:var(--brand)}
.header-actions{display:flex;align-items:center;gap:10px;justify-self:end}
.icon-button{width:46px;height:46px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--text);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.cart-button{display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 12px;border-radius:16px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm);font-weight:700}
.cart-icon{width:20px;height:20px;display:grid;place-items:center;color:var(--text)}
.cart-count{min-width:22px;height:22px;padding:0 6px;border-radius:999px;display:grid;place-items:center;background:var(--brand);color:#fff;font-size:11px;font-weight:800}
.mobile-search-wrap{display:none;padding:0 0 14px}
.desktop-category-row{padding:0 0 14px}
.category-pills{display:flex;gap:10px;overflow:auto;scrollbar-width:none}
.category-pills::-webkit-scrollbar{display:none}
.category-pills a{white-space:nowrap;border:1px solid var(--line);background:#fff;padding:10px 14px;border-radius:999px;color:#475467;font-size:14px;font-weight:600}
.category-pills a:hover{border-color:rgba(196,59,114,.3);color:var(--brand)}

.mobile-menu{position:fixed;inset:0;z-index:80;pointer-events:none;opacity:0;transition:opacity .24s ease}
.mobile-menu.is-open{opacity:1;pointer-events:auto}
.mobile-menu-backdrop{position:absolute;inset:0;border:none;background:rgba(31,36,48,.38)}
.mobile-menu-panel{position:absolute;top:0;right:0;width:min(360px,100vw);height:100dvh;background:#fff;padding:18px 16px 22px;display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-md);transform:translateX(100%);transition:transform .24s ease;overflow:auto}
.mobile-menu.is-open .mobile-menu-panel{transform:translateX(0)}
.mobile-menu-head{display:flex;justify-content:space-between;align-items:center;gap:12px}
.mobile-menu-search{margin-top:4px}
.mobile-menu-links{display:grid;gap:8px}
.mobile-menu-links a{padding:13px 14px;border-radius:14px;background:var(--surface-tint);font-weight:600;color:#344054}
.whatsapp-cta{display:flex;align-items:center;justify-content:center;min-height:50px;padding:0 18px;border-radius:16px;background:#eafaf1;color:#11653f;font-weight:800;border:1px solid #ccefd9}

main{min-height:40vh}
.section{padding:56px 0}
.alt-bg{background:linear-gradient(180deg,#fff7fb 0%,#fff 100%)}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:18px;margin-bottom:22px}
.section-kicker,.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:var(--brand-soft);color:var(--brand-strong);font-size:12px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;margin-bottom:12px}
.section-head h2,.page-hero h1,.hero-content h1,.product-summary h1{margin:0;font-size:clamp(30px,4vw,54px);line-height:1.03;letter-spacing:-.03em}
.section-head p,.page-hero p,.hero-content p,.product-summary-text{margin:10px 0 0;color:var(--muted);font-size:16px;line-height:1.7;max-width:60ch}
.text-link{font-weight:700;color:var(--brand)}

.home-hero{padding:28px 0 14px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:20px;align-items:stretch}
.hero-slider{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:32px;background:linear-gradient(135deg,#fff6f8 0%,#f8f2ff 60%,#fff 100%);box-shadow:var(--shadow-md);min-height:520px}
.hero-slide{display:none;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:12px;align-items:center;height:100%;padding:30px}
.hero-slide.is-active{display:grid}
.hero-content{padding:8px 4px 8px 6px}
.hero-content h1{font-size:clamp(34px,5vw,62px)}
.hero-content p{font-size:17px;max-width:50ch}
.hero-actions-row{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 18px}
.hero-actions-row.center{justify-content:center}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;border-radius:16px;border:1px solid transparent;font-weight:800;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 18px 30px rgba(196,59,114,.18)}
.btn-primary:hover{background:var(--brand-strong)}
.btn-secondary{background:#fff;color:var(--text);border-color:var(--line)}
.btn.wide{width:100%}
.hero-points{display:flex;flex-wrap:wrap;gap:10px}
.hero-points span{padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.88);border:1px solid rgba(221,213,226,.9);font-size:13px;font-weight:700;color:#4c5565}
.hero-visual{display:flex;justify-content:center;align-items:center}
.hero-visual img{width:min(100%,430px);aspect-ratio:4/5;object-fit:cover;border-radius:24px;background:#fff;box-shadow:var(--shadow-sm)}
.hero-dots{position:absolute;left:24px;bottom:20px;display:flex;gap:8px}
.hero-dot{width:10px;height:10px;border-radius:999px;border:none;background:rgba(31,36,48,.18)}
.hero-dot.is-active{width:28px;background:var(--brand)}
.hero-side-cards{display:grid;gap:16px}
.side-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow-sm);display:grid;gap:8px;align-content:start}
.side-card strong{font-size:18px}
.side-card span,.side-card a{color:var(--muted);line-height:1.6}
.side-card.hot{background:linear-gradient(145deg,#fff0f5,#fff)}
.side-card.hot a{font-weight:800;color:var(--brand)}

.category-strip-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.category-tile{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-sm);display:grid;gap:14px}
.category-tile img{width:100%;aspect-ratio:4/3;object-fit:cover;background:#f8f7fb}
.category-tile div{padding:0 16px 18px}
.category-tile h3{margin:0 0 8px;font-size:20px}
.category-tile p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}

.product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.product-card{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.product-card-media{display:block;background:#faf7fb}
.product-card-media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.product-card-body{padding:16px}
.product-card-category{margin:0 0 8px;color:var(--brand);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.product-card h3{margin:0 0 14px;font-size:17px;line-height:1.4;min-height:48px}
.product-card-meta{display:flex;justify-content:space-between;gap:12px;align-items:center}
.product-card-meta strong{font-size:20px;letter-spacing:-.02em}
.mini-btn,.mini-link{display:inline-flex;align-items:center;justify-content:center;border:none;background:#151923;color:#fff;min-height:38px;padding:0 14px;border-radius:12px;font-weight:700}
.mini-link{background:none;color:var(--brand);padding:0;min-height:auto}

.comfort-panel{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:20px;align-items:stretch}
.comfort-panel article,.comfort-points{background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:var(--shadow-sm)}
.comfort-panel h2{margin:0 0 12px;font-size:clamp(28px,3.6vw,44px);line-height:1.05}
.comfort-panel p{margin:0;color:var(--muted);line-height:1.75}
.comfort-points{display:grid;gap:16px}
.comfort-points div{padding:14px 0;border-bottom:1px solid var(--line)}
.comfort-points div:last-child{border-bottom:none}
.comfort-points strong{display:block;margin-bottom:6px;font-size:18px}
.comfort-points span{color:var(--muted);line-height:1.6}

.page-hero{padding:26px 0 10px}
.page-hero-inner{display:flex;justify-content:space-between;align-items:end;gap:20px;padding:28px;border-radius:28px;background:linear-gradient(140deg,#fff 0%,#fff7fb 100%);border:1px solid var(--line)}
.page-hero-inner.split{align-items:center}
.shop-toolbar{display:grid;gap:16px}
.catalog-search{max-width:720px}
.mobile-scroll-pills{padding-bottom:4px}
.empty-state{padding:40px 20px;text-align:center;background:#fff;border:1px dashed var(--line-strong);border-radius:22px;color:var(--muted);font-weight:600}

.product-section{padding-top:28px}
.product-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,460px);gap:28px;align-items:start}
.product-gallery{display:grid;gap:14px}
.product-main-card,.detail-card,.summary-card,.info-card,.form-card,.cart-card,.success-card-clean{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow-sm)}
.product-main-card{padding:18px}
.product-main-image{width:100%;aspect-ratio:4/5;object-fit:contain;border-radius:20px;background:#faf7fb}
.product-thumb-row{display:flex;gap:10px;overflow:auto;padding-bottom:4px}
.product-thumb-row img{width:78px;height:94px;object-fit:cover;border:2px solid transparent;border-radius:16px;background:#faf7fb;cursor:pointer}
.product-thumb-row img.is-active{border-color:var(--brand)}
.product-summary{display:grid;gap:18px;position:sticky;top:100px}
.price-row strong{font-size:34px;letter-spacing:-.03em}
.product-summary-text{margin:0}
.mini-features{display:flex;flex-wrap:wrap;gap:10px}
.mini-features span{padding:9px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:13px;font-weight:700;color:#475467}
.purchase-box,.detail-card{padding:20px}
.purchase-box{display:grid;gap:14px}
.qty-field{display:grid;gap:8px;max-width:130px}
.detail-card h3,.summary-card h3,.info-card h2{margin:0 0 12px;font-size:22px}
.detail-card p,.summary-help,.info-card p,.info-list li,.footer-copy{color:var(--muted);line-height:1.7}

.cart-layout,.checkout-layout,.info-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px;align-items:start}
.cart-card,.form-card,.info-card,.summary-card{padding:22px}
.cart-list{display:grid;gap:18px}
.cart-item{display:grid;grid-template-columns:96px minmax(0,1fr) auto;gap:16px;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--line)}
.cart-item:last-child{border-bottom:none;padding-bottom:0}
.cart-item img{width:96px;height:120px;object-fit:cover;border-radius:18px;background:#faf7fb}
.cart-item-copy{display:grid;gap:8px}
.cart-item-copy strong{font-size:18px}
.cart-item-copy span{color:var(--muted);font-size:14px;line-height:1.6}
.cart-item-price{font-weight:800}
.cart-item-actions{display:grid;justify-items:end;gap:10px}
.cart-item-actions input{width:86px}
.cart-actions-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}
.summary-card{display:grid;gap:12px}
.summary-line{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line)}
.summary-line:last-child{border-bottom:none}
.summary-line.total{font-size:20px;font-weight:800}
.sticky-card{position:sticky;top:100px}
.form-card{display:grid;gap:16px}
.form-grid{display:grid;gap:16px}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.notice{padding:14px 16px;border-radius:16px;margin-bottom:16px;font-weight:600}
.notice.success{background:#eefaf4;color:var(--success);border:1px solid #cdebd9}.notice.error{background:#fff1f1;color:#9b1c1c;border:1px solid #ffd5d5}
.narrow-card-wrap{max-width:760px;margin:0 auto}
.success-card-clean{padding:34px;text-align:center}
.success-card-clean h1{margin:0 0 10px;font-size:clamp(30px,4vw,50px);line-height:1.04}
.success-card-clean p{margin:10px auto;color:var(--muted);line-height:1.7;max-width:54ch}
.info-layout.two-up{grid-template-columns:repeat(2,minmax(0,1fr))}
.info-list{margin:0;padding-left:18px;display:grid;gap:8px}

.site-footer{margin-top:32px;background:#181b24;color:#fff}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr .8fr;gap:24px;padding:42px 0}
.footer-brand .brand-mark{box-shadow:none}
.footer-copy{margin:12px 0 0;color:#bcc1cf}
.site-footer h4{margin:0 0 12px;font-size:16px}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.site-footer li,.site-footer a{color:#d8dce7}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08)}
.footer-bottom-wrap{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:14px 0;color:#b4b9c6;font-size:13px}

@media (max-width: 1080px){
  .header-shell{grid-template-columns:auto minmax(180px,1fr) auto;gap:14px}
  .desktop-nav{display:none}
  .hero-grid,.comfort-panel,.product-grid,.category-strip-grid,.footer-grid,.cart-layout,.checkout-layout,.info-layout,.info-layout.two-up{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr}
  .hero-side-cards{grid-template-columns:repeat(3,minmax(0,1fr))}
  .product-layout{grid-template-columns:1fr}
  .product-summary{position:static}
}

@media (max-width: 768px){
  .mobile-only{display:grid!important}
  .desktop-only,.desktop-only-inline,.desktop-search,.desktop-category-row{display:none!important}
  .site-header{backdrop-filter:none}
  .header-shell{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand actions";min-height:72px;padding:12px 0}
  .brand{grid-area:brand}
  .header-actions{grid-area:actions;gap:8px}
  .brand-copy small{display:none}
  .brand-mark{width:40px;height:40px;border-radius:14px}
  .cart-button{height:44px;padding:0 10px}
  .cart-text{display:none}
  body.search-open .mobile-search-wrap{display:block}
  .mobile-search-wrap{padding-bottom:12px}
  .home-hero{padding-top:12px}
  .hero-slider{min-height:unset}
  .hero-slide,.hero-slide.is-active{grid-template-columns:1fr;padding:18px}
  .hero-content{padding:4px 0 0}
  .hero-content h1{font-size:36px}
  .hero-content p{font-size:15px;max-width:none}
  .hero-visual img{width:100%;max-width:none;aspect-ratio:4/5}
  .hero-side-cards{display:none}
  .hero-dots{left:18px;bottom:16px}
  .section{padding:40px 0}
  .section-head,.page-hero-inner,.footer-bottom-wrap{display:grid;gap:12px}
  .page-hero{padding:12px 0 4px}
  .page-hero-inner{padding:22px}
  .page-hero h1,.section-head h2{font-size:30px}
  .category-strip-grid,.product-grid,.comfort-panel,.cart-layout,.checkout-layout,.info-layout,.info-layout.two-up,.footer-grid{grid-template-columns:1fr}
  .category-tile{grid-template-columns:110px 1fr;gap:0;align-items:center}
  .category-tile img{height:100%;aspect-ratio:auto}
  .category-tile div{padding:18px 16px}
  .product-card{border-radius:20px}
  .product-card h3{min-height:auto}
  .cart-item{grid-template-columns:74px minmax(0,1fr);align-items:start}
  .cart-item img{width:74px;height:94px}
  .cart-item-actions{grid-column:2;justify-items:start}
  .form-grid.two{grid-template-columns:1fr}
  .sticky-card{position:static}
  .footer-grid{padding:34px 0}
}

@media (max-width: 480px){
  :root{--container:min(100vw - 20px, 100vw)}
  .header-shell{min-height:68px}
  .brand-copy strong{font-size:16px}
  .icon-button,.cart-button{width:42px;height:42px;border-radius:12px}
  .cart-button{padding:0 8px;width:auto}
  .hero-content h1{font-size:32px}
  .hero-actions-row .btn{width:100%}
  .hero-points{display:grid;gap:8px}
  .section-head h2,.page-hero h1,.product-summary h1{font-size:28px}
  .product-main-card,.detail-card,.summary-card,.info-card,.form-card,.cart-card,.success-card-clean,.category-tile,.product-card,.hero-slider{border-radius:20px}
  .product-card-body,.cart-card,.summary-card,.form-card,.info-card{padding:18px}
  .category-tile{grid-template-columns:1fr}
  .category-tile img{aspect-ratio:4/3}
}
