/* ============================================
   KEYS GIFTS — Global Stylesheet
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400;1,600&family=Barlow+Condensed:wght@600;700;800&family=Jost:wght@300;400;500;600&display=swap');

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

:root {
  --navy:   #0e2233;
  --teal:   #1a8f8f;
  --blue:   #3a7fc1;
  --blue-l: #5aa0e0;
  --sand:   #f8f3ec;
  --sand2:  #f0e9de;
  --coral:  #c8522a;
  --gold:   #b8861e;
  --white:  #fff;
  --text:   #1c1c1c;
  --muted:  #666;
  --border: #e5ddd3;
  --success:#2a8a4a;
}

body { font-family:'Jost',sans-serif; background:var(--white); color:var(--text); overflow-x:hidden; font-size:16px; }

/* ── ANNOUNCEMENT ── */
.ann { background:var(--navy); color:rgba(255,255,255,.82); text-align:center; padding:11px 16px; font-size:12px; font-weight:500; letter-spacing:1.1px; text-transform:uppercase; }
.ann strong { color:#c8a84b; font-weight:700; }

/* ── HEADER ── */
header { background:var(--white); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:500; }
.header-inner { max-width:1240px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; padding:16px 32px; position:relative; min-height:64px; }

.burger { background:none; border:none; cursor:pointer; display:flex; flex-direction:column; gap:5px; padding:6px; border-radius:4px; }
.burger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; transform-origin:center; }
.burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.logo { font-family:'Barlow Condensed',sans-serif; font-size:30px; font-weight:800; color:var(--blue); text-decoration:none; letter-spacing:1px; text-transform:uppercase; position:absolute; left:50%; transform:translateX(-50%); white-space:nowrap; }

.hdr-right { display:flex; align-items:center; gap:22px; }
.hdr-btn { background:none; border:none; cursor:pointer; color:var(--text); transition:opacity .2s; display:flex; align-items:center; gap:6px; font-family:inherit; position:relative; padding:4px; }
.hdr-btn:hover { opacity:.55; }
.hdr-btn svg { width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.cart-badge { background:var(--coral); color:#fff; border-radius:50%; width:18px; height:18px; font-size:10px; display:none; align-items:center; justify-content:center; font-weight:700; position:absolute; top:-5px; right:-6px; font-family:'Jost',sans-serif; }
.cart-badge.show { display:flex; }

/* ── OVERLAY ── */
.overlay { position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:800; opacity:0; pointer-events:none; transition:opacity .3s; }
.overlay.open { opacity:1; pointer-events:all; }

/* ── NAV DRAWER ── */
.drawer { position:fixed; left:0; top:0; bottom:0; width:300px; background:var(--white); z-index:900; transform:translateX(-100%); transition:transform .32s cubic-bezier(.4,0,.2,1); display:flex; flex-direction:column; border-right:1px solid var(--border); }
.drawer.open { transform:translateX(0); }
.drawer-top { display:flex; align-items:center; justify-content:space-between; padding:20px 24px; border-bottom:1px solid var(--border); }
.drawer-logo { font-family:'Barlow Condensed',sans-serif; font-size:24px; font-weight:800; color:var(--blue); letter-spacing:1px; text-transform:uppercase; }
.drawer-x { background:none; border:none; font-size:22px; color:var(--muted); cursor:pointer; line-height:1; }
.drawer-x:hover { color:var(--text); }
.drawer-body { flex:1; overflow-y:auto; padding:8px 0 24px; }
.d-label { padding:16px 24px 6px; font-size:10px; font-weight:700; letter-spacing:1.8px; text-transform:uppercase; color:var(--muted); }
.d-link { display:flex; align-items:center; justify-content:space-between; padding:13px 24px; font-size:15px; font-weight:400; color:var(--text); text-decoration:none; cursor:pointer; transition:background .15s; background:none; border:none; font-family:inherit; width:100%; text-align:left; border-left:3px solid transparent; }
.d-link:hover { background:var(--sand); border-left-color:var(--teal); }
.d-chev { font-size:11px; color:var(--muted); transition:transform .25s; flex-shrink:0; }
.d-link.open .d-chev { transform:rotate(90deg); }
.d-sub { max-height:0; overflow:hidden; transition:max-height .35s ease; background:var(--sand); }
.d-sub.open { max-height:800px; }
.d-sub-group { padding:12px 24px 4px 32px; font-size:10px; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; color:var(--teal); }
.d-sub-link { display:block; padding:10px 24px 10px 38px; font-size:14px; color:var(--muted); text-decoration:none; transition:color .15s; }
.d-sub-link:hover { color:var(--text); }
.drawer-foot { padding:18px 24px; border-top:1px solid var(--border); font-size:13px; color:var(--muted); font-weight:300; line-height:1.5; }

/* ── CART PANEL ── */
.cart-panel { position:fixed; right:0; top:0; bottom:0; width:420px; max-width:100vw; background:var(--white); z-index:910; transform:translateX(100%); transition:transform .32s cubic-bezier(.4,0,.2,1); display:flex; flex-direction:column; border-left:1px solid var(--border); box-shadow:-4px 0 32px rgba(0,0,0,.1); }
.cart-panel.open { transform:translateX(0); }
.cart-top { display:flex; align-items:center; justify-content:space-between; padding:20px 24px; border-bottom:1px solid var(--border); }
.cart-top h2 { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:700; color:var(--navy); letter-spacing:.5px; text-transform:uppercase; }
.cart-x { background:none; border:none; font-size:22px; color:var(--muted); cursor:pointer; }
.cart-body { flex:1; overflow-y:auto; padding:20px 24px; }
.cart-empty { text-align:center; padding:60px 20px; }
.cart-empty p { font-size:15px; color:var(--muted); font-weight:300; margin-bottom:24px; line-height:1.6; }

.cart-item { display:flex; gap:14px; padding:18px 0; border-bottom:1px solid var(--border); }
.cart-item-thumb { width:76px; height:92px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:11px; color:var(--muted); text-transform:uppercase; font-weight:400; }
.cart-item-info { flex:1; min-width:0; }
.ci-name  { font-size:15px; font-weight:500; color:var(--text); margin-bottom:4px; line-height:1.3; }
.ci-price { font-size:14px; font-weight:600; color:var(--navy); margin-bottom:10px; }
.ci-qty   { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.qty-btn  { background:none; border:1px solid var(--border); width:28px; height:28px; cursor:pointer; font-size:16px; display:flex; align-items:center; justify-content:center; transition:background .15s; font-family:inherit; color:var(--text); border-radius:2px; }
.qty-btn:hover { background:var(--sand); }
.qty-n    { font-size:14px; font-weight:600; min-width:20px; text-align:center; }
.ci-remove { font-size:12px; color:var(--muted); cursor:pointer; text-decoration:underline; background:none; border:none; font-family:inherit; }
.ci-remove:hover { color:var(--coral); }

/* Gift address */
.gift-toggle { display:flex; align-items:center; gap:8px; margin-top:6px; cursor:pointer; }
.gift-toggle input { accent-color:var(--teal); width:15px; height:15px; cursor:pointer; flex-shrink:0; }
.gift-toggle label { font-size:13px; color:var(--teal); font-weight:500; cursor:pointer; line-height:1.35; }
.gift-form { margin-top:12px; padding:14px; background:var(--sand); border:1px solid var(--border); display:none; }
.gift-form.show { display:block; }
.gift-form-note { font-size:12px; color:var(--muted); margin-bottom:12px; line-height:1.55; font-weight:300; }
.gift-field { width:100%; border:1px solid var(--border); background:#fff; font-family:'Jost',sans-serif; font-size:14px; padding:10px 12px; outline:none; color:var(--text); margin-bottom:8px; border-radius:2px; }
.gift-field:focus { border-color:var(--teal); }
.gift-row2 { display:grid; grid-template-columns:1fr 80px 90px; gap:8px; }
.gift-saved { font-size:12px; color:var(--success); font-weight:500; margin-top:6px; }
.gift-save-btn { width:100%; background:var(--teal); color:#fff; border:none; padding:10px; font-family:'Jost',sans-serif; font-size:12px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; cursor:pointer; transition:background .2s; margin-top:4px; }
.gift-save-btn:hover { background:var(--navy); }

/* Cart footer */
.cart-footer { padding:20px 24px; border-top:1px solid var(--border); }
.subtotal-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:5px; }
.subtotal-row span { font-size:14px; color:var(--muted); }
.subtotal-row strong { font-size:18px; font-weight:700; color:var(--navy); }
.ship-progress { margin-bottom:16px; }
.ship-bar-bg { height:4px; background:#eee; border-radius:2px; margin:6px 0; overflow:hidden; }
.ship-bar-fill { height:100%; background:var(--teal); border-radius:2px; transition:width .4s ease; }
.ship-note { font-size:12px; font-weight:500; }

/* Payment buttons */
.pay-divider { display:flex; align-items:center; gap:10px; margin:14px 0; }
.pay-divider hr { flex:1; border:none; border-top:1px solid var(--border); }
.pay-divider span { font-size:11px; color:var(--muted); white-space:nowrap; }
.pay-buttons { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.pay-apple { background:#000; color:#fff; border:none; border-radius:6px; padding:13px; font-size:14px; font-weight:600; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:6px; font-family:inherit; transition:opacity .2s; }
.pay-apple:hover { opacity:.85; }
.pay-paypal { background:#003087; color:#fff; border:none; border-radius:6px; padding:13px; font-size:14px; font-weight:600; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:6px; font-family:inherit; transition:opacity .2s; }
.pay-paypal:hover { opacity:.85; }
.pay-paypal em { color:#009cde; font-style:normal; }
.checkout-btn { width:100%; background:var(--navy); color:#fff; border:none; padding:15px; font-family:'Jost',sans-serif; font-size:13px; font-weight:600; letter-spacing:1px; text-transform:uppercase; cursor:pointer; transition:background .2s; margin-bottom:10px; }
.checkout-btn:hover { background:var(--teal); }
.cart-continue-btn { width:100%; background:none; border:1.5px solid var(--border); color:var(--muted); padding:13px; font-family:'Jost',sans-serif; font-size:12px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; cursor:pointer; transition:all .2s; }
.cart-continue-btn:hover { border-color:var(--navy); color:var(--navy); }
.cart-footnote { font-size:11px; color:var(--muted); text-align:center; margin-top:10px; font-weight:300; }

/* ── BUTTONS ── */
.btn-primary { background:var(--navy); color:#fff; border:none; padding:14px 34px; font-family:'Jost',sans-serif; font-size:13px; font-weight:600; letter-spacing:1.1px; text-transform:uppercase; cursor:pointer; transition:background .2s; text-decoration:none; display:inline-block; }
.btn-primary:hover { background:var(--teal); }
.btn-white { background:#fff; color:var(--navy); border:none; padding:14px 34px; font-family:'Jost',sans-serif; font-size:13px; font-weight:600; letter-spacing:1.1px; text-transform:uppercase; cursor:pointer; transition:background .2s,color .2s; text-decoration:none; display:inline-block; }
.btn-white:hover { background:var(--teal); color:#fff; }
.btn-outline { display:inline-block; border:1.5px solid var(--navy); color:var(--navy); padding:13px 30px; font-family:'Jost',sans-serif; font-size:12px; font-weight:600; letter-spacing:1.1px; text-transform:uppercase; text-decoration:none; cursor:pointer; background:none; transition:background .2s,color .2s; }
.btn-outline:hover { background:var(--navy); color:#fff; }

/* ── SECTIONS ── */
.section { max-width:1240px; margin:0 auto; padding:72px 32px; }
.sec-label { font-size:10px; font-weight:700; letter-spacing:2.2px; text-transform:uppercase; color:var(--teal); margin-bottom:8px; }
.sec-title { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,4vw,44px); font-weight:600; color:var(--navy); line-height:1.1; }
.sec-title em { font-style:italic; }
.sec-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:40px; gap:20px; }
.view-all { font-size:12px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; color:var(--navy); text-decoration:none; border-bottom:1px solid currentColor; padding-bottom:2px; transition:color .2s; white-space:nowrap; }
.view-all:hover { color:var(--teal); }

/* ── PRODUCT GRID ── */
.prod-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.pcard { cursor:pointer; }
.pcard-img-wrap { position:relative; overflow:hidden; background:var(--sand); margin-bottom:14px; aspect-ratio:3/4; }
.pcard-swatch { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:400; color:var(--muted); letter-spacing:.5px; text-transform:uppercase; transition:transform .45s ease; text-align:center; padding:12px; }
.pcard:hover .pcard-swatch { transform:scale(1.04); }
.color-1{background:linear-gradient(145deg,#d4e8e8,#b8d4d0);}
.color-2{background:linear-gradient(145deg,#e8dcc8,#d4c8b0);}
.color-3{background:linear-gradient(145deg,#c8d8e0,#b0c8d4);}
.color-4{background:linear-gradient(145deg,#e0ccc0,#cdb8aa);}
.color-5{background:linear-gradient(145deg,#d8e0cc,#c4ceb8);}
.color-6{background:linear-gradient(145deg,#e8d8cc,#d4c4b4);}
.color-7{background:linear-gradient(145deg,#ccd8e0,#b8c8d4);}
.color-8{background:linear-gradient(145deg,#e0d8cc,#ccc4b0);}
.pcard-badge { position:absolute; top:10px; left:10px; font-size:10px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; padding:4px 10px; }
.pcard-badge.sale { background:var(--coral); color:#fff; }
.pcard-badge.new  { background:var(--navy); color:#fff; }
.pcard-wish { position:absolute; top:10px; right:10px; background:rgba(255,255,255,.9); border:none; cursor:pointer; opacity:0; transition:opacity .2s; color:var(--muted); padding:6px; border-radius:50%; width:34px; height:34px; display:flex; align-items:center; justify-content:center; }
.pcard-wish svg { width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:1.5; }
.pcard-wish.liked svg { fill:var(--coral); stroke:var(--coral); }
.pcard:hover .pcard-wish { opacity:1; }
.quick-add { position:absolute; bottom:0; left:0; right:0; background:var(--navy); color:#fff; border:none; font-family:'Jost',sans-serif; font-size:12px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; padding:13px; cursor:pointer; transform:translateY(100%); transition:transform .25s ease,background .2s; }
.pcard:hover .quick-add { transform:translateY(0); }
.quick-add:hover { background:var(--teal); }
/* BIGGER TEXT for older eyes on mobile */
.pcard-name  { font-size:15px; font-weight:500; color:var(--text); margin-bottom:5px; line-height:1.38; }
.pcard-hint  { font-size:12px; color:var(--coral); font-weight:500; min-height:16px; margin-bottom:6px; }
.pcard-price { font-size:17px; font-weight:700; color:var(--navy); }
.pcard-old   { font-size:14px; color:var(--muted); text-decoration:line-through; margin-left:6px; }
.pcard-stars { color:#b8860e; font-size:13px; letter-spacing:1px; }
.pcard-rcount{ font-size:13px; color:var(--muted); }

/* ── CATEGORY GRID ── */
.cat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.cat-card { position:relative; overflow:hidden; cursor:pointer; text-decoration:none; display:block; aspect-ratio:3/4; background:var(--sand2); }
.cat-card:nth-child(1) { grid-row:span 2; aspect-ratio:auto; }
.cat-img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .55s ease; filter:brightness(.78); }
.cat-card:hover .cat-img { transform:scale(1.05); filter:brightness(.6); }
.cat-overlay { position:absolute; inset:0; background:linear-gradient(0deg,rgba(10,24,38,.75) 0%,transparent 60%); }
.cat-info { position:absolute; bottom:0; left:0; right:0; padding:22px 22px; }
/* BETTER CONTRAST on category cards */
.cat-name { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:600; color:#fff; margin-bottom:5px; text-shadow:0 1px 8px rgba(0,0,0,.5); }
.cat-cta  { font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.85); transition:color .2s; text-shadow:0 1px 4px rgba(0,0,0,.4); }
.cat-card:hover .cat-cta { color:#c8a84b; }

/* ── REVIEWS ── */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.rcard { background:var(--white); border:1px solid var(--border); padding:28px; }
.rcard-stars { font-size:14px; color:var(--gold); letter-spacing:2px; margin-bottom:14px; }
.rcard-text { font-family:'Cormorant Garamond',serif; font-size:19px; font-style:italic; color:var(--navy); line-height:1.6; margin-bottom:18px; }
.rcard-name    { font-size:13px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--text); }
.rcard-product { font-size:12px; color:var(--muted); margin-top:3px; }
.rcard-bottom  { border-top:1px solid var(--border); padding-top:12px; }

/* ── ABOUT STRIP ── */
.about-bg { background:var(--sand); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.about-inner { max-width:1240px; margin:0 auto; padding:72px 32px; display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.about-photo { width:100%; aspect-ratio:4/3; object-fit:cover; }
.about-text h2 { font-family:'Cormorant Garamond',serif; font-size:clamp(26px,3.5vw,40px); font-weight:600; color:var(--navy); line-height:1.18; margin-bottom:18px; }
.about-text p  { font-size:16px; font-weight:300; color:#484848; line-height:1.82; margin-bottom:16px; }

/* ── EMAIL ── */
.email-section { background:var(--navy); padding:88px 32px; text-align:center; }
.email-label { font-size:10px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:#c8a84b; margin-bottom:12px; }
.email-section h2 { font-family:'Cormorant Garamond',serif; font-size:clamp(30px,5vw,50px); font-weight:600; color:#fff; margin-bottom:10px; }
.email-section p  { color:rgba(255,255,255,.55); font-size:15px; font-weight:300; margin-bottom:32px; }
.email-row   { display:flex; justify-content:center; max-width:420px; margin:0 auto; }
.email-input { flex:1; border:1px solid rgba(255,255,255,.22); border-right:none; background:rgba(255,255,255,.08); color:#fff; font-family:'Jost',sans-serif; font-size:14px; padding:14px 18px; outline:none; }
.email-input::placeholder { color:rgba(255,255,255,.3); }
.email-btn   { background:var(--teal); color:#fff; border:none; padding:14px 26px; font-family:'Jost',sans-serif; font-size:12px; font-weight:600; letter-spacing:1px; text-transform:uppercase; cursor:pointer; transition:background .2s; white-space:nowrap; }
.email-btn:hover { background:#1aa8a8; }

/* ── FOOTER ── */
footer { background:var(--sand); border-top:1px solid var(--border); padding:60px 32px 28px; }
.footer-grid { max-width:1240px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
.footer-logo-txt { font-family:'Barlow Condensed',sans-serif; font-size:24px; font-weight:800; color:var(--blue); letter-spacing:1px; text-transform:uppercase; display:block; margin-bottom:14px; }
.footer-desc { font-size:14px; font-weight:300; color:var(--muted); line-height:1.78; }
.footer-col h4 { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--text); margin-bottom:16px; }
.footer-col a  { display:block; font-size:14px; font-weight:300; color:var(--muted); text-decoration:none; margin-bottom:10px; transition:color .2s; }
.footer-col a:hover { color:var(--text); }
.footer-bottom { max-width:1240px; margin:0 auto; border-top:1px solid var(--border); padding-top:22px; display:flex; justify-content:space-between; font-size:12px; color:var(--muted); flex-wrap:wrap; gap:10px; }

/* ── TOAST ── */
.toast { position:fixed; bottom:28px; left:28px; background:var(--navy); color:#fff; padding:15px 22px; font-size:14px; font-weight:400; line-height:1.45; box-shadow:0 4px 28px rgba(0,0,0,.2); z-index:9999; transform:translateY(10px); opacity:0; transition:all .3s; max-width:290px; border-left:3px solid var(--teal); }
.toast.show { transform:translateY(0); opacity:1; }

/* ── POPUP ── */
.pop-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:1000; display:flex; align-items:center; justify-content:center; padding:20px; opacity:0; pointer-events:none; transition:opacity .35s; }
.pop-overlay.show { opacity:1; pointer-events:all; }
.popup { background:#fff; max-width:460px; width:100%; display:grid; grid-template-columns:1fr 1fr; overflow:hidden; transform:translateY(14px); transition:transform .35s; box-shadow:0 20px 60px rgba(0,0,0,.22); }
.pop-overlay.show .popup { transform:translateY(0); }
.popup-photo { min-height:340px; background-size:cover; background-position:center 70%; }
.popup-body  { padding:36px 26px; display:flex; flex-direction:column; justify-content:center; position:relative; }
.pop-x    { position:absolute; top:14px; right:16px; background:none; border:none; font-size:20px; color:var(--muted); cursor:pointer; }
.pop-x:hover { color:var(--text); }
.pop-label { font-size:9px; font-weight:700; letter-spacing:2.2px; text-transform:uppercase; color:var(--teal); margin-bottom:8px; }
.popup-body h3 { font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:600; color:var(--navy); line-height:1.2; margin-bottom:10px; }
.popup-body p  { font-size:14px; color:var(--muted); line-height:1.65; margin-bottom:22px; font-weight:300; }
.pop-code { border:1.5px dashed var(--border); padding:12px; text-align:center; font-size:20px; font-weight:700; color:var(--coral); letter-spacing:3px; margin-bottom:16px; }
.pop-btn  { width:100%; background:var(--navy); color:#fff; border:none; padding:14px; font-family:'Jost',sans-serif; font-size:12px; font-weight:600; letter-spacing:1.1px; text-transform:uppercase; cursor:pointer; transition:background .2s; }
.pop-btn:hover { background:var(--teal); }
.pop-skip { display:block; text-align:center; margin-top:12px; font-size:12px; color:var(--muted); cursor:pointer; text-decoration:underline; }

/* ── PAGE HERO (interior pages) ── */
.page-hero { background:var(--navy); padding:56px 32px; text-align:center; }
.page-hero h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(32px,5vw,56px); font-weight:600; color:#fff; margin-bottom:10px; }
.page-hero p  { color:rgba(255,255,255,.6); font-size:15px; font-weight:300; }

/* ── FORMS ── */
.form-wrap { max-width:640px; margin:0 auto; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.form-group.full { grid-column:1/-1; }
.form-group label { font-size:12px; font-weight:600; letter-spacing:.5px; text-transform:uppercase; color:var(--text); }
.form-group input,
.form-group select,
.form-group textarea { border:1px solid var(--border); background:#fff; font-family:'Jost',sans-serif; font-size:15px; padding:12px 14px; outline:none; color:var(--text); border-radius:2px; width:100%; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--teal); }
.form-group textarea { resize:vertical; min-height:120px; }

/* ── BREADCRUMB ── */
.breadcrumb { max-width:1240px; margin:0 auto; padding:16px 32px; font-size:13px; color:var(--muted); display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.breadcrumb a { color:var(--muted); text-decoration:none; }
.breadcrumb a:hover { color:var(--text); }
.breadcrumb span { color:var(--border); }

/* ── RESPONSIVE ── */
@media(max-width:1024px){ .prod-grid{grid-template-columns:repeat(3,1fr);} .footer-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:768px){
  .cat-grid{grid-template-columns:1fr 1fr;} .cat-card:nth-child(1){grid-row:span 1;}
  .prod-grid{grid-template-columns:repeat(2,1fr);}
  .reviews-grid{grid-template-columns:1fr;}
  .about-inner{grid-template-columns:1fr; gap:36px;}
  .popup{grid-template-columns:1fr;} .popup-photo{min-height:160px;}
  .section{padding:48px 20px;}
  .header-inner{padding:14px 20px;}
  .cart-panel{width:100%;}
  .form-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .gift-row2{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .prod-grid{grid-template-columns:repeat(2,1fr); gap:12px;}
  .footer-grid{grid-template-columns:1fr;}
  .pay-buttons{grid-template-columns:1fr;}
  .pcard-name{font-size:14px;}
  .pcard-price{font-size:16px;}
}
