:root {
  --ink: #111934;
  --brown: #151b2a;
  --cream: #f3f0e9;
  --paper: #e6e4df;
  --clay: #8d563a;
  --line: rgba(17, 25, 52, .18);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: "Manrope", sans-serif; font-size: 15px; }
body.menu-open, body.cart-open, body.checkout-open, body.product-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
button { color: inherit; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.section-pad { padding: 120px max(6vw, 32px); }
.eyebrow { margin: 0 0 22px; font-size: 11px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1, h2 { font-family: "Cormorant Garamond", serif; font-weight: 500; letter-spacing: -.035em; }
h2 { margin-bottom: 0; font-size: clamp(38px, 5vw, 72px); line-height: 1.12; }
em { color: var(--clay); font-style: italic; }

.header { position: absolute; z-index: 10; top: 0; left: 0; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; width: 100%; padding: 26px 5vw; color: #fff; border-bottom: 1px solid rgba(255,255,255,.18); }
.catalog-header { position:absolute; color:var(--ink); background:var(--cream); border-bottom-color:var(--line); }
.catalog-header .logo-flame, .catalog-header .menu-toggle span { background:var(--ink); }
.catalog-header .bag { color:var(--ink); }
.catalog-header .bag span { color:#fff; background:var(--ink); }
.logo { display: inline-flex; align-items: center; gap: 9px; width: max-content; font-family: "Cormorant Garamond", serif; font-size: 27px; font-weight: 500; text-transform: uppercase; letter-spacing: .08em; }
.logo-flame { width: 10px; height: 17px; background: #fff; border-radius: 80% 20% 65% 35%; transform: rotate(45deg); }
.nav { display: flex; gap: 34px; font-size: 13px; }
.nav a { position: relative; }
.nav a::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 0; height: 1px; background: currentColor; transition: width .25s; }
.nav a:hover::after { width: 100%; }
.header-actions { display: flex; justify-content: flex-end; align-items: center; gap: 24px; }
.bag { padding: 0; color: #fff; background: none; border: 0; cursor: pointer; }
.bag span { display: inline-grid; place-items: center; width: 22px; height: 22px; margin-left: 6px; color: var(--ink); background: #fff; border-radius: 50%; font-size: 11px; }
.menu-toggle { display: none; width: 28px; padding: 6px 0; background: none; border: 0; }
.menu-toggle span { display: block; height: 1px; margin: 5px 0; background: #fff; transition: .25s; }

.hero { position: relative; display: flex; align-items: center; min-height: 100vh; overflow: hidden; color: #fff; background: #090b0a; }
.hero-image { position: absolute; inset: 0; background: url("assets/photo_2026-06-13_10-44-28.jpg") 62% 54%/cover no-repeat; animation: hero-in 1.4s ease both; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,8,7,.92) 0%, rgba(5,8,7,.68) 43%, rgba(5,8,7,.08) 78%), linear-gradient(0deg, rgba(5,8,7,.42), transparent 45%); }
.hero-copy { position: relative; z-index: 1; width: min(760px, 75%); padding: 145px 0 80px 8vw; }
.hero h1 { margin: 0 0 30px; max-width: 920px; font-size: clamp(60px, 8.4vw, 130px); line-height: .82; }
.hero h1 em { color: #d5c8b2; }
.hero-text { max-width: 510px; margin-bottom: 36px; color: rgba(255,255,255,.8); font-size: 17px; line-height: 1.7; }
.button { display: inline-flex; align-items: center; justify-content: space-between; gap: 40px; min-width: 230px; padding: 17px 21px; border: 1px solid; font-size: 13px; transition: .25s; }
.button-light:hover { color: var(--ink); background: #fff; border-color: #fff; }
.hero-note { position: absolute; right: 5vw; bottom: 7vh; display: flex; align-items: flex-start; gap: 16px; max-width: 255px; font-size: 12px; line-height: 1.6; }
.hero-note span { color: #d5c8b2; }
.scroll { position: absolute; bottom: 6vh; left: 2.2vw; display: flex; gap: 20px; align-items: center; font-size: 10px; letter-spacing: .15em; text-transform: uppercase; transform: rotate(-90deg); transform-origin: left center; }
@keyframes hero-in { from { transform: scale(1.06); opacity: .35; } to { transform: scale(1); opacity: 1; } }

.intro { border-bottom: 1px solid var(--line); }
.intro-grid { display: grid; grid-template-columns: 1.35fr .65fr; gap: 10vw; align-items: end; }
.intro-grid p { max-width: 450px; margin-bottom: 6px; color: #75665f; font-size: 16px; line-height: 1.8; }

.catalog { background: var(--cream); }
.section-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 54px; }
.catalog-tabs { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 6px; }
.catalog-actions { display:flex; align-items:center; gap:18px; }
.tab { padding: 10px 17px; background: transparent; border: 1px solid var(--line); border-radius: 30px; cursor: pointer; font-size: 12px; }
.tab.active, .tab:hover { color: var(--cream); background: var(--ink); }
.product-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 22px; }
.catalog-slider { position:relative; }
.home-catalog .catalog-slider { margin-inline:-3.2vw; padding-inline:3.2vw; }
.home-catalog .product-grid { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; scroll-behavior:smooth; padding-right:9vw; }
.home-catalog .product-grid::-webkit-scrollbar { display:none; }
.home-catalog .product { flex:0 0 calc((100% - 55px)/3.45); scroll-snap-align:start; }
.slider-side { position:absolute; z-index:4; top:42%; display:grid; place-items:center; width:58px; height:58px; padding:0; color:var(--ink); background:rgba(243,240,233,.94); border:1px solid var(--line); border-radius:50%; box-shadow:0 10px 35px rgba(17,25,52,.12); cursor:pointer; transform:translateY(-50%); transition:color .2s,background .2s,transform .2s; }
.slider-side span { font-size:20px; transform:translateY(-1px); }
.slider-side:hover { color:var(--cream); background:var(--ink); transform:translateY(-50%) scale(1.06); }
.slider-side-prev { left:10px; }
.slider-side-next { right:10px; }
.view-all { display:flex; justify-content:space-between; align-items:center; margin-top:48px; padding:20px 0; border-top:1px solid var(--ink); border-bottom:1px solid var(--ink); font-size:12px; letter-spacing:.12em; text-transform:uppercase; }
.view-all b { font-size:20px; font-weight:400; }
.catalog-page { padding-top:150px; min-height:100vh; }
.catalog-page .section-head { align-items:start; }
.catalog-page-title { max-width:700px; }
.catalog-page-title h1 { margin:0; font-size:clamp(58px,8vw,110px); line-height:.85; }
.catalog-count { margin-top:18px; color:#777269; font-size:12px; }
.product { cursor:pointer; transition: opacity .3s, transform .3s; }
.product.is-hidden { display: none; }
.product-image { position: relative; aspect-ratio: 4/4.2; overflow: hidden; background-position: center; background-size: cover; transition: background-size .6s ease, filter .4s; }
.product:hover .product-image { background-size: 108%; }
.image-1 { background-image: linear-gradient(rgba(8,12,10,.02), rgba(8,12,10,.15)), url("assets/photo_2026-06-13_10-44-38.jpg"); background-position: center 48%; }
.image-2 { background-image: url("assets/photo_2026-06-13_10-44-49.jpg"); background-position: center 55%; }
.image-3 { background-image: url("assets/photo_2026-06-13_10-44-52.jpg"); background-position: center 50%; }
.badge { position: absolute; top: 16px; left: 16px; padding: 8px 12px; color: var(--cream); background: var(--clay); border-radius: 20px; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }
.product-info { display: flex; justify-content: space-between; gap: 12px; padding: 15px 2px 11px; }
.product-info h3 { margin-bottom: 5px; font-family: "Cormorant Garamond", serif; font-size: 22px; font-weight: 500; line-height: 1; }
.product-info p { margin: 0; color: #85766f; font-size: 12px; }
.product-info strong { white-space: nowrap; font-size: 13px; }
.add-button { display: flex; justify-content: space-between; width: 100%; padding: 13px 0; background: transparent; border: 0; border-top: 1px solid var(--line); cursor: pointer; font-size: 12px; text-transform: uppercase; letter-spacing: .1em; }
.add-button span { font-size: 18px; line-height: 12px; transition: transform .2s; }
.add-button:hover span { transform: rotate(90deg); }

.sachet { display: grid; grid-template-columns: 1fr 1fr; gap: 9vw; align-items: center; background: #dcd8cf; }
.sachet-visual { position: relative; min-height: 620px; overflow: hidden; background: #11182f; }
.sachet-visual::before { content: ""; position: absolute; inset: 0; opacity: .32; background: radial-gradient(circle at 25% 20%, #9ca58c 0 1px, transparent 2px), radial-gradient(circle at 75% 60%, #d5c8b2 0 1px, transparent 2px); background-size: 33px 33px, 47px 47px; }
.sachet-shadow { position: absolute; left: 16%; bottom: 12%; width: 65%; height: 20%; background: rgba(0,0,0,.45); filter: blur(35px); transform: rotate(-8deg); }
.sachet-piece { position: absolute; display: flex; align-items: center; justify-content: center; width: 245px; height: 330px; color: var(--ink); background: linear-gradient(145deg, #eee7d8, #cfc5b2); border-radius: 48% 52% 45% 55% / 42% 40% 60% 58%; box-shadow: inset -16px -12px 30px rgba(74,57,35,.18), 0 30px 60px rgba(0,0,0,.28); }
.sachet-piece::before { content: ""; position: absolute; top: 26px; width: 22px; height: 22px; border: 1px solid rgba(17,25,52,.35); border-radius: 50%; box-shadow: inset 0 0 0 6px #d9cfbd; }
.sachet-piece-back { top: 10%; left: 18%; color: rgba(17,25,52,.45); font-family: "Cormorant Garamond", serif; font-size: 37px; text-transform: uppercase; letter-spacing: .08em; transform: rotate(-14deg); }
.sachet-piece-front { right: 15%; bottom: 8%; flex-direction: column; gap: 16px; transform: rotate(9deg); }
.sachet-mark { font-family: "Cormorant Garamond", serif; font-size: 76px; line-height: .7; }
.sachet-piece small { font-size: 8px; line-height: 1.5; letter-spacing: .14em; text-align: center; text-transform: uppercase; }
.sachet-note { position: absolute; left: 25px; bottom: 22px; color: rgba(255,255,255,.55); font-size: 8px; letter-spacing: .14em; text-transform: uppercase; }
.sachet-copy h2 { font-size: clamp(42px, 5vw, 71px); }
.sachet-copy > p:not(.eyebrow) { max-width: 530px; margin: 32px 0; color: #68645d; font-size: 15px; line-height: 1.8; }
.sachet-features { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 38px; }
.sachet-features span { padding: 9px 13px; border: 1px solid rgba(17,25,52,.22); border-radius: 30px; font-size: 9px; letter-spacing: .08em; text-transform: uppercase; }
.sachet-link { display: flex; justify-content: space-between; max-width: 430px; padding: 17px 0; border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.sachet-link b { font-size: 17px; font-weight: 400; }

.story { display: grid; grid-template-columns: 1fr 1fr; min-height: 750px; color: var(--cream); background: var(--brown); }
.story-image { position: relative; min-height: 580px; background: linear-gradient(rgba(10,15,14,.04), rgba(10,15,14,.22)), url("assets/photo_2026-06-13_10-44-46.jpg") center/cover; }
.wax-seal { position: absolute; right: -52px; top: 50%; display: grid; place-items: center; width: 104px; height: 104px; padding-top: 10px; color: var(--ink); background: #d8d1c3; border-radius: 50%; font-family: "Cormorant Garamond", serif; font-size: 31px; line-height: .8; text-align: center; transform: translateY(-50%) rotate(-8deg); }
.wax-seal small { font-family: "Manrope", sans-serif; font-size: 7px; letter-spacing: .12em; line-height: 1.2; text-transform: uppercase; }
.story-copy { display: flex; flex-direction: column; justify-content: center; padding: 90px 9vw; }
.story-copy h2 { font-size: clamp(38px, 4.2vw, 64px); }
.story-copy h2 em { color: #d5c8b2; }
.story-copy > p:not(.eyebrow) { margin: 32px 0 45px; color: rgba(255,255,255,.64); line-height: 1.8; }
.story-copy ul { padding: 0; margin: 0; list-style: none; }
.story-copy li { padding: 18px 0; border-top: 1px solid rgba(255,255,255,.14); font-size: 13px; }
.story-copy li span { display: inline-block; width: 50px; color: #d5c8b2; font-size: 10px; }

.reviews { text-align: center; background: var(--paper); }
.reviews blockquote { max-width: 1000px; margin: 30px auto 42px; font-family: "Cormorant Garamond", serif; font-size: clamp(34px, 4vw, 59px); line-height: 1.25; }
.review-author { display: inline-flex; align-items: center; gap: 12px; text-align: left; }
.review-author > span { display: grid; place-items: center; width: 44px; height: 44px; color: var(--cream); background: var(--clay); border-radius: 50%; font-size: 12px; }
.review-author strong { font-size: 12px; }
.review-author p { margin: 4px 0 0; color: #85766f; font-size: 10px; }

.newsletter { display: grid; grid-template-columns: 1.1fr .9fr; gap: 10vw; align-items: end; color: var(--cream); background: #10162d; }
.newsletter h2 { font-size: clamp(40px, 5vw, 70px); }
.newsletter h2 em { color: #d5c8b2; }
.telegram-card > p { max-width: 480px; margin-bottom: 28px; color: rgba(255,255,255,.6); font-size: 14px; line-height: 1.8; }
.telegram-card > a { display: flex; align-items: center; justify-content: space-between; padding: 22px 0; border-top: 1px solid rgba(255,255,255,.35); transition: color .2s; }
.telegram-card > a:last-child { border-bottom: 1px solid rgba(255,255,255,.35); }
.telegram-card > a:hover { color: #d5c8b2; }
.telegram-card a span { display: flex; flex-direction: column; gap: 6px; font-family: "Cormorant Garamond", serif; font-size: 32px; }
.telegram-card a small { font-family: "Manrope", sans-serif; font-size: 9px; letter-spacing: .15em; text-transform: uppercase; }
.telegram-card a b { display: grid; place-items: center; width: 52px; height: 52px; color: var(--ink); background: var(--paper); border-radius: 50%; font-size: 20px; font-weight: 400; }
.footer { padding: 68px 5vw 28px; color: var(--cream); background: #090d1d; border-top: 1px solid rgba(255,255,255,.1); }
.footer-main { display: grid; grid-template-columns: 1fr minmax(300px, 460px); gap: 10vw; align-items: end; padding-bottom: 58px; }
.footer-brand p { margin: 24px 0 0; color: rgba(255,255,255,.48); font-size: 13px; line-height: 1.8; }
.footer-logo { font-size: 39px; }
.footer-support { display: flex; align-items: center; justify-content: space-between; padding: 18px 0; border-top: 1px solid rgba(255,255,255,.3); border-bottom: 1px solid rgba(255,255,255,.3); transition: color .2s; }
.footer-support:hover { color: #d5c8b2; }
.footer-support span { display: flex; flex-direction: column; gap: 6px; font-family: "Cormorant Garamond", serif; font-size: 27px; }
.footer-support small { color: rgba(255,255,255,.45); font-family: "Manrope", sans-serif; font-size: 8px; letter-spacing: .16em; text-transform: uppercase; }
.footer-support b { font-size: 20px; font-weight: 400; }
.footer-bottom { display: grid; grid-template-columns: 1fr auto 1fr; gap: 25px; align-items: center; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1); color: rgba(255,255,255,.36); font-size: 9px; letter-spacing: .06em; text-transform: uppercase; }
.footer-bottom a { justify-self: end; color: var(--cream); }
.toast { position: fixed; z-index: 20; right: 24px; bottom: 24px; padding: 15px 20px; color: #fff; background: var(--ink); box-shadow: 0 12px 40px rgba(0,0,0,.18); transform: translateY(90px); opacity: 0; transition: .3s; }
.toast.show { transform: translateY(0); opacity: 1; }
.cart-overlay { position: fixed; z-index: 30; inset: 0; background: rgba(4, 7, 15, .56); opacity: 0; visibility: hidden; backdrop-filter: blur(3px); transition: .35s; }
.cart-overlay.open { opacity: 1; visibility: visible; }
.cart-drawer { position: fixed; z-index: 31; top: 0; right: 0; display: flex; flex-direction: column; width: min(520px, 100%); height: 100dvh; padding: 38px 38px 28px; background: var(--cream); box-shadow: -25px 0 80px rgba(6, 10, 25, .2); transform: translateX(102%); visibility: hidden; transition: transform .42s cubic-bezier(.22,.8,.26,1), visibility .42s; }
.cart-drawer.open { transform: translateX(0); visibility: visible; }
.cart-head { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 25px; border-bottom: 1px solid var(--line); }
.cart-head .eyebrow { margin-bottom: 7px; }
.cart-head h2 { font-size: 45px; line-height: 1; }
.cart-head h2 span { color: #8d897f; font-family: "Manrope", sans-serif; font-size: 12px; vertical-align: top; }
.cart-close, .checkout-close { width: 42px; height: 42px; padding: 0 0 4px; background: transparent; border: 1px solid var(--line); border-radius: 50%; cursor: pointer; font-size: 27px; line-height: 1; transition: .2s; }
.cart-close:hover, .checkout-close:hover { color: var(--cream); background: var(--ink); }
.cart-items { flex: 1; overflow-y: auto; margin-right: -12px; padding-right: 12px; }
.cart-item { display: grid; grid-template-columns: 92px 1fr auto; gap: 16px; padding: 22px 0; border-bottom: 1px solid var(--line); }
.cart-item-image { width: 92px; height: 112px; background-position: center; background-size: cover; }
.cart-item-copy { display: flex; flex-direction: column; min-width: 0; }
.cart-item-copy h3 { margin-bottom: 5px; font-family: "Cormorant Garamond", serif; font-size: 23px; font-weight: 500; line-height: 1; }
.cart-item-copy p { margin: 0; color: #777268; font-size: 10px; }
.quantity { display: inline-flex; align-items: center; align-self: flex-start; margin-top: auto; border: 1px solid var(--line); }
.quantity button { width: 28px; height: 27px; padding: 0; background: transparent; border: 0; cursor: pointer; }
.quantity span { min-width: 25px; text-align: center; font-size: 11px; }
.cart-item-side { display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; }
.cart-item-side strong { font-size: 12px; white-space: nowrap; }
.cart-remove { padding: 0; color: #827d74; background: transparent; border: 0; border-bottom: 1px solid currentColor; cursor: pointer; font-size: 9px; text-transform: uppercase; letter-spacing: .08em; }
.cart-empty { display: none; flex: 1; flex-direction: column; align-items: center; justify-content: center; padding: 40px; text-align: center; }
.cart-empty.visible { display: flex; }
.empty-flame { width: 25px; height: 38px; margin-bottom: 25px; background: #d6ccba; border-radius: 80% 20% 65% 35%; transform: rotate(45deg); }
.cart-empty h3 { margin-bottom: 9px; font-family: "Cormorant Garamond", serif; font-size: 32px; font-weight: 500; }
.cart-empty p { max-width: 270px; color: #777268; font-size: 12px; line-height: 1.7; }
.cart-catalog-link { padding: 10px 0; background: transparent; border: 0; border-bottom: 1px solid var(--ink); cursor: pointer; font-size: 11px; text-transform: uppercase; letter-spacing: .1em; }
.cart-footer { padding-top: 22px; }
.cart-footer.hidden { display: none; }
.delivery-progress { height: 2px; overflow: hidden; background: #d7d2c8; }
.delivery-progress span { display: block; width: 0; height: 100%; background: var(--clay); transition: width .3s; }
.delivery-note { margin: 8px 0 25px; color: #777268; font-size: 10px; }
.cart-total { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px; }
.cart-total span { font-family: "Cormorant Garamond", serif; font-size: 28px; }
.cart-total strong { font-size: 18px; }
.checkout-button, .checkout-submit { display: flex; justify-content: space-between; width: 100%; padding: 18px 20px; color: #fff; background: var(--ink); border: 0; cursor: pointer; font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
.checkout-button:hover, .checkout-submit:hover { background: var(--clay); }
.cart-caption { margin: 10px 0 0; color: #888277; font-size: 9px; text-align: center; }
.product-modal { position:fixed; z-index:38; inset:0; padding:22px; background:rgba(4,7,15,.72); opacity:0; visibility:hidden; overflow-y:auto; backdrop-filter:blur(7px); transition:.3s; }
.product-modal.open { opacity:1; visibility:visible; }
.product-dialog { position:relative; display:grid; grid-template-columns:minmax(0,1.08fr) minmax(390px,.92fr); width:min(1240px,100%); min-height:min(760px,calc(100dvh - 44px)); margin:auto; background:var(--cream); transform:translateY(20px); transition:transform .3s; }
.product-modal.open .product-dialog { transform:translateY(0); }
.product-modal-close { position:absolute; z-index:2; top:20px; right:20px; width:44px; height:44px; padding:0 0 4px; color:#fff; background:rgba(9,13,29,.72); border:1px solid rgba(255,255,255,.35); border-radius:50%; cursor:pointer; font-size:28px; }
.product-gallery { display:grid; grid-template-columns:84px 1fr; min-height:720px; padding:22px; background:#151b2a; }
.product-gallery-main { grid-column:2; grid-row:1; min-width:0; overflow:hidden; }
.product-gallery-main img { width:100%; height:100%; min-height:676px; object-fit:cover; display:block; }
.product-thumbs { grid-column:1; grid-row:1; display:flex; flex-direction:column; gap:9px; padding-right:12px; overflow-y:auto; }
.product-thumb { width:100%; aspect-ratio:1; padding:0; overflow:hidden; background:none; border:1px solid transparent; cursor:pointer; opacity:.55; }
.product-thumb.active { border-color:#fff; opacity:1; }
.product-thumb img { width:100%; height:100%; object-fit:cover; }
.product-detail-copy { display:flex; flex-direction:column; padding:70px 55px 42px; overflow-y:auto; }
.product-detail-heading { display:flex; justify-content:space-between; gap:25px; align-items:flex-start; padding-bottom:28px; border-bottom:1px solid var(--line); }
.product-detail-heading h2 { max-width:480px; font-size:clamp(45px,5vw,72px); line-height:.95; }
.product-detail-heading strong { padding-top:12px; white-space:nowrap; font-size:15px; }
.product-detail-description { margin:29px 0; color:#666159; font-size:14px; line-height:1.85; white-space:pre-line; }
.note-pyramid { display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.note-level { padding:18px 14px 18px 0; }
.note-level + .note-level { padding-left:14px; border-left:1px solid var(--line); }
.note-level small { display:block; margin-bottom:8px; color:#827d73; font-size:8px; letter-spacing:.14em; text-transform:uppercase; }
.note-level p { margin:0; font-family:"Cormorant Garamond",serif; font-size:19px; line-height:1.2; }
.product-facts { margin:22px 0; }
.product-fact { padding:14px 0; border-bottom:1px solid var(--line); }
.product-fact summary { cursor:pointer; font-size:10px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; }
.product-fact p { margin:13px 0 2px; color:#68645d; font-size:12px; line-height:1.75; white-space:pre-line; }
.product-certificates { display:grid; gap:8px; margin-bottom:24px; }
.product-certificates h3 { margin:0 0 4px; font-size:9px; letter-spacing:.13em; text-transform:uppercase; }
.certificate-link { display:flex; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--line); font-family:"Cormorant Garamond",serif; font-size:19px; }
.product-detail-add { display:flex; justify-content:space-between; width:100%; margin-top:auto; padding:18px 20px; color:#fff; background:var(--ink); border:0; cursor:pointer; font-size:11px; letter-spacing:.12em; text-transform:uppercase; }
.product-detail-add:hover { background:var(--clay); }
.checkout-modal { position: fixed; z-index: 40; inset: 0; display: grid; place-items: center; padding: 22px; background: rgba(4,7,15,.72); opacity: 0; visibility: hidden; backdrop-filter: blur(7px); transition: .3s; }
.checkout-modal.open { opacity: 1; visibility: visible; }
.checkout-dialog { position: relative; width: min(680px, 100%); max-height: calc(100dvh - 44px); overflow-y: auto; padding: 48px; background: var(--cream); transform: translateY(20px); transition: transform .3s; }
.checkout-modal.open .checkout-dialog { transform: translateY(0); }
.checkout-dialog > h2 { margin-bottom: 30px; font-size: 50px; }
.checkout-close { position: absolute; top: 25px; right: 25px; }
.checkout-lead { max-width: 510px; margin: -8px 0 32px; color: #6f6a62; font-size: 14px; line-height: 1.8; }
.checkout-lead strong { color: var(--ink); }
.checkout-summary { display: flex; justify-content: space-between; margin-bottom: 18px; padding-top: 20px; border-top: 1px solid var(--line); font-family: "Cormorant Garamond", serif; font-size: 27px; }
.checkout-summary strong { font-family: "Manrope", sans-serif; font-size: 18px; }
.checkout-submit { text-align: left; }
.checkout-hint { margin: 12px 0 0; color: #888277; font-size: 10px; text-align: center; }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .section-pad { padding: 86px 24px; }
  .header { grid-template-columns: 1fr auto; padding: 22px 24px; }
  .nav { position: fixed; inset: 0; z-index: -1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 30px; color: var(--cream); background: var(--brown); font-family: "Cormorant Garamond", serif; font-size: 31px; opacity: 0; pointer-events: none; transition: .3s; }
  .nav.open { opacity: 1; pointer-events: auto; }
  .menu-toggle { position: relative; z-index: 2; display: block; }
  .menu-toggle.open span:first-child { transform: translateY(3px) rotate(45deg); }
  .menu-toggle.open span:last-child { transform: translateY(-3px) rotate(-45deg); }
  .hero-copy { width: 95%; padding: 130px 24px 100px; }
  .hero h1 { font-size: clamp(54px, 15vw, 90px); }
  .hero-note, .scroll { display: none; }
  .intro-grid, .newsletter { grid-template-columns: 1fr; gap: 44px; }
  .product-grid { grid-template-columns: 1fr 1fr; }
  .home-catalog .product { flex-basis:calc((100% - 22px)/2.15); }
  .catalog-actions { align-items:flex-start; flex-direction:column; }
  .slider-side { width:48px; height:48px; }
  .product-image { aspect-ratio: 4/4.4; }
  .sachet { grid-template-columns: 1fr; gap: 55px; }
  .sachet-visual { min-height: min(680px, 85vw); }
  .story { grid-template-columns: 1fr; }
  .story-image { min-height: 65vw; }
  .wax-seal { top: auto; right: 24px; bottom: -52px; transform: none; }
  .story-copy { padding: 90px 24px; }
  .footer-main { grid-template-columns: 1fr; gap: 48px; }
  .footer-bottom { grid-template-columns: 1fr auto; }
  .footer-bottom small:nth-child(2) { display: none; }
  .product-dialog { grid-template-columns:1fr; }
  .product-gallery { min-height:620px; }
  .product-gallery-main img { min-height:576px; }
  .product-detail-copy { padding:55px 35px 35px; }
}

@media (max-width: 600px) {
  .bag { font-size: 0; }
  .bag span { font-size: 11px; }
  .hero { min-height: 760px; }
  .hero-image { background-position: 64% center; }
  .hero h1 { font-size: 55px; }
  .hero-text { font-size: 14px; }
  .intro-grid { gap: 30px; }
  .section-head { align-items: flex-start; flex-direction: column; gap: 28px; }
  .product-grid { grid-template-columns: 1fr; }
  .catalog-actions { width:100%; }
  .catalog-tabs { justify-content:flex-start; }
  .home-catalog .product { flex-basis:78%; }
  .slider-side { display:none; }
  .home-catalog .catalog-slider { margin-inline:-24px; padding-inline:24px; }
  .home-catalog .product-grid { padding-right:14vw; }
  .product-image { aspect-ratio: 1/1.05; }
  .sachet-visual { min-height: 520px; }
  .sachet-piece { width: 180px; height: 255px; }
  .sachet-piece-back { left: 8%; }
  .sachet-piece-front { right: 7%; }
  .sachet-note { max-width: 210px; line-height: 1.5; }
  .story-image { min-height: 90vw; }
  .reviews blockquote { font-size: 28px; }
  .footer { padding: 55px 24px 24px; }
  .footer-main { padding-bottom: 45px; }
  .footer-logo { font-size: 34px; }
  .footer-support span { font-size: 24px; }
  .product-modal { padding:0; }
  .product-dialog { min-height:100dvh; }
  .product-gallery { grid-template-columns:1fr; min-height:auto; padding:0; }
  .product-gallery-main { grid-column:1; height:66vh; }
  .product-gallery-main img { min-height:0; height:100%; }
  .product-thumbs { grid-column:1; grid-row:2; flex-direction:row; padding:10px; }
  .product-thumb { width:64px; flex:0 0 64px; }
  .product-detail-copy { padding:42px 22px 28px; }
  .product-modal-close { position:fixed; }
  .note-pyramid { grid-template-columns:1fr; }
  .note-level + .note-level { padding-left:0; border-left:0; border-top:1px solid var(--line); }
  .cart-drawer { padding: 25px 20px 20px; }
  .cart-head h2 { font-size: 39px; }
  .cart-item { grid-template-columns: 75px 1fr; }
  .cart-item-image { width: 75px; height: 95px; }
  .cart-item-side { grid-column: 2; flex-direction: row-reverse; align-items: center; }
  .checkout-dialog { padding: 38px 22px 24px; }
  .checkout-dialog > h2 { padding-right: 35px; font-size: 39px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
