/* =========================================================================
   pages.css — shared styles for all interior pages
   (loaded after heritage.css; reuses its design tokens / variables)
   ========================================================================= */

/* active nav state */
.main-nav a.active{color:#fff}
.main-nav a.active::after{width:100%}

/* ===================== PAGE HERO (interior banner) ===================== */
.page-hero{position:relative;margin-top:-188px;min-height:60vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.page-hero-media{position:absolute;inset:0;z-index:-2}
.page-hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(14,13,36,.72) 0%,rgba(14,13,36,.35) 45%,rgba(14,13,36,.85) 100%)}
.page-hero .container{padding-bottom:64px;padding-top:210px}
.page-hero .eyebrow{color:var(--gold)}
.page-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,5vw,4rem);line-height:1.05;margin:8px 0 14px;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.page-hero p{font-size:1.12rem;color:rgba(255,255,255,.88);max-width:60ch}

/* page-hero — solid blue variant with logo watermark (no photo) */
.page-hero.hero-solid{background:linear-gradient(160deg,#1a1854,#0e0d24);min-height:48vh}
.page-hero.hero-solid::after{display:none}
.page-hero.hero-solid .page-hero-watermark{position:absolute;top:50%;right:-120px;transform:translateY(-50%);
  width:520px;height:auto;opacity:.06;filter:brightness(0) invert(1);pointer-events:none;z-index:0}
.page-hero.hero-solid .container{position:relative;z-index:1}
@media(max-width:640px){.page-hero.hero-solid .page-hero-watermark{width:340px;right:-80px}}

/* breadcrumb */
.breadcrumb{background:var(--cream);border-bottom:1px solid #ece4d4}
.breadcrumb ul{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:16px 0;font-size:13px;color:var(--muted)}
.breadcrumb li::after{content:"/";margin-left:8px;color:#c9c2d6}
.breadcrumb li:last-child::after{content:""}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb li[aria-current]{color:var(--ink);font-weight:600}

/* generic prose / text page */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.3rem);color:var(--ink);margin:40px 0 16px;font-weight:600}
.prose h3{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin:28px 0 12px}
.prose p{margin-bottom:16px;color:var(--text)}
.prose p:first-child{font-size:1.15rem;color:var(--muted)}
.prose ul.bullets{margin:16px 0;padding-left:0}
.prose ul.bullets li{position:relative;padding-left:28px;margin-bottom:12px}
.prose ul.bullets li::before{content:"";position:absolute;left:0;top:9px;width:10px;height:10px;background:var(--gold);border-radius:50%}
.prose blockquote{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--red);border-left:3px solid var(--gold);padding-left:22px;margin:28px 0}
.prose blockquote cite{display:block;font-size:.95rem;font-style:normal;color:var(--muted);margin-top:8px}

/* ===================== HISTORY PAGE ===================== */
.history-block{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.history-block.flip .history-figure{order:2}
.history-figure img{border-radius:3px;box-shadow:0 26px 60px rgba(20,18,63,.18);width:100%;aspect-ratio:4/5;object-fit:cover}
.history-block h2{margin-bottom:18px}
.tl-vertical{position:relative;max-width:880px;margin:0 auto;padding-left:28px}
.tl-vertical::before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--gold),rgba(210,172,103,.15))}
.tl-row{position:relative;padding:0 0 44px 38px}
.tl-row::before{content:"";position:absolute;left:-2px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(210,172,103,.2)}
.tl-row .yr{font-family:var(--serif);font-size:2rem;color:var(--red);line-height:1;margin-bottom:8px}
.tl-row h3{font-family:var(--serif);font-size:1.35rem;color:var(--ink);margin-bottom:8px}
.tl-row p{color:var(--muted)}
.gen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.gen-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;overflow:hidden;text-align:center}
.gen-card img{width:100%;aspect-ratio:1/1;object-fit:cover}
.gen-card .gen-body{padding:22px}
.gen-card .gen-role{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
.gen-card h3{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin:8px 0}

/* ===================== TOOLBAR / FILTERS (wines listing) ===================== */
.shop-layout{display:grid;grid-template-columns:248px 1fr;gap:40px;align-items:start}
.filters{position:sticky;top:120px;background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:24px}
.filters h3{font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.filter-group{padding:18px 0;border-bottom:1px solid #f0e9da}
.filter-group:last-child{border-bottom:0;padding-bottom:0}
.filter-group h4{font-size:13px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-bottom:12px}
.filter-group label{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);padding:6px 0;cursor:pointer}
.filter-group input{accent-color:var(--red);width:16px;height:16px}
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.shop-toolbar .count{font-size:14px;color:var(--muted)}
.shop-toolbar select{border:1px solid #d8cfbd;border-radius:3px;padding:10px 14px;background:#fff;font-size:14px;color:var(--text)}
.filter-toggle{display:none}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:48px}
.pagination a{min-width:42px;height:42px;display:flex;align-items:center;justify-content:center;border:1px solid #d8cfbd;border-radius:3px;font-size:14px;color:var(--text);transition:.25s}
.pagination a:hover,.pagination a[aria-current]{background:var(--red);border-color:var(--red);color:#fff}

/* ===================== PRODUCT DETAIL ===================== */
.product{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start}
.product-gallery .main-img{background:linear-gradient(160deg,#f3ecdd,#e7dcc4);border-radius:4px;overflow:hidden;aspect-ratio:1/1}
.product-gallery .main-img img{width:100%;height:100%;object-fit:cover}
.product-thumbs{display:flex;gap:12px;margin-top:14px}
.product-thumbs button{flex:1;border:1px solid #e2d9c6;border-radius:3px;overflow:hidden;aspect-ratio:1/1;background:#faf6ee;padding:0}
.product-thumbs button.active{border-color:var(--red)}
.product-thumbs img{width:100%;height:100%;object-fit:cover}
.product-info .coll{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
.product-info h1{font-family:var(--serif);font-size:clamp(2rem,4vw,2.8rem);color:var(--ink);margin:6px 0 12px;line-height:1.08}
.product-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.product-price{font-family:var(--serif);font-size:2.4rem;color:var(--red);margin-bottom:6px}
.product-price small{font-size:.42em;color:var(--muted);font-family:var(--sans)}
.product-avail{font-size:13px;color:#3a8a4a;margin-bottom:22px}
.product-desc{color:var(--text);margin-bottom:24px}
.product-buy{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:28px}
.qty{display:flex;align-items:center;border:1px solid #d8cfbd;border-radius:3px;overflow:hidden}
.qty button{width:44px;height:48px;font-size:18px;color:var(--ink);background:#faf6ee}
.qty button:hover{background:var(--cream)}
.qty input{width:52px;height:48px;text-align:center;border:0;border-left:1px solid #e2d9c6;border-right:1px solid #e2d9c6;font-size:16px}
.product-buy .btn-gold{flex:1;min-width:180px;justify-content:center}
.product-fav{width:50px;height:50px;flex:0 0 auto;border:1px solid #d8cfbd;border-radius:3px;display:flex;align-items:center;justify-content:center;background:#fff}
.product-fav img{width:22px;height:22px}
.product-fav .heart-fill{display:none}
.product-fav.is-active{background:var(--red);border-color:var(--red)}
.product-fav.is-active .heart-line{display:none}
.product-fav.is-active .heart-fill{display:block}
.product-specs{border-top:1px solid #ece4d4;padding-top:22px}
.product-specs dl{display:grid;grid-template-columns:auto 1fr;gap:10px 24px;font-size:14px}
.product-specs dt{color:var(--muted)}
.product-specs dd{color:var(--ink);font-weight:600;margin:0}

/* ===================== SERVICES ===================== */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.service-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:34px 28px;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(20,18,63,.12)}
.service-icon{width:58px;height:58px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.service-icon img{width:28px;height:28px}
.service-card h3{font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin-bottom:12px}
.service-card p{color:var(--muted);font-size:.97rem;margin-bottom:18px}
.service-card .more{margin-top:auto;display:inline-flex;align-items:center;gap:8px;color:var(--red);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.service-card .more img{width:16px;height:16px}
.service-detail{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,64px);align-items:start}
.service-detail .figure img{border-radius:4px;width:100%;aspect-ratio:4/3;object-fit:cover}
.service-aside{background:var(--cream);border:1px solid #ece4d4;border-radius:4px;padding:28px;position:sticky;top:120px}
.service-aside h3{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:16px}

/* ===================== BLOG / NEWS LISTINGS ===================== */
.filter-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:44px}
.filter-chips a{border:1px solid #d8cfbd;border-radius:30px;padding:9px 20px;font-size:13px;color:var(--text);transition:.25s}
.filter-chips a:hover,.filter-chips a[aria-current]{background:var(--red);border-color:var(--red);color:#fff}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-feature{display:grid;grid-template-columns:1.1fr .9fr;gap:0;background:#fff;border:1px solid #ece4d4;border-radius:4px;overflow:hidden;margin-bottom:40px}
.blog-feature .post-media{aspect-ratio:auto}
.blog-feature .post-media img{height:100%;min-height:320px}
.blog-feature .post-body{padding:clamp(28px,4vw,52px);align-self:center}
.blog-feature h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink);margin:12px 0 14px;line-height:1.15}
.post-date{font-size:12px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}

/* news list (rows) */
.news-list{max-width:900px;margin:0 auto}
.news-row{display:grid;grid-template-columns:150px 1fr auto;gap:24px;align-items:center;padding:24px 0;border-bottom:1px solid #ece4d4}
.news-row .news-date{font-family:var(--serif);color:var(--red)}
.news-row .news-date b{display:block;font-size:2rem;line-height:1}
.news-row h3{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:6px}
.news-row p{color:var(--muted);font-size:.95rem}

/* ===================== ARTICLE (blog/news detail) ===================== */
.article{max-width:780px;margin:0 auto}
.article-head{text-align:center;margin-bottom:36px}
.article-head .post-cat{display:inline-block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:var(--red);padding:5px 12px;font-weight:600}
.article-head h1{font-family:var(--serif);font-size:clamp(2rem,4.4vw,3rem);color:var(--ink);margin:16px 0 14px;line-height:1.12}
.article-meta{font-size:13px;color:var(--muted);letter-spacing:.04em}
.article-cover{border-radius:4px;overflow:hidden;margin-bottom:36px;aspect-ratio:16/9}
.article-cover img{width:100%;height:100%;object-fit:cover}
.article-share{display:flex;align-items:center;gap:14px;margin-top:40px;padding-top:24px;border-top:1px solid #ece4d4;font-size:13px;color:var(--muted)}
.article-share a{width:38px;height:38px;border:1px solid #d8cfbd;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.25s}
.article-share a:hover{background:var(--red);border-color:var(--red)}
.article-share a:hover img{filter:brightness(0) invert(1)}
.article-share img{width:18px;height:18px}

/* ===================== CONTACT ===================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:start}
.contact-info{background:var(--ink);color:#fff;border-radius:4px;padding:clamp(28px,4vw,44px)}
.contact-info h2{color:#fff;margin-bottom:22px}
.contact-info .ci-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.contact-info .ci-row img{width:22px;height:22px;flex:0 0 auto;margin-top:3px}
.contact-info .ci-row b{display:block;color:var(--gold);font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.contact-info .ci-row a,.contact-info .ci-row span{color:rgba(255,255,255,.85)}
.contact-social{display:flex;gap:10px;margin-top:8px}
.contact-social a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.25s}
.contact-social a:hover{background:var(--gold);border-color:var(--gold)}
.contact-social img{width:18px;height:18px}

/* forms (shared) */
.form-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:clamp(26px,4vw,40px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;letter-spacing:.04em;color:var(--ink);font-weight:600;margin-bottom:8px}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{width:100%;border:1px solid #d8cfbd;border-radius:3px;padding:13px 15px;font-size:15px;background:#fdfbf6;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(210,172,103,.18)}
.field textarea{min-height:150px;resize:vertical}
.form-note{font-size:13px;color:var(--muted);margin-top:8px}
.form-success{display:none;background:#eef8f0;border:1px solid #bfe3c8;color:#2c6e3b;border-radius:3px;padding:14px 16px;margin-bottom:18px}
.form-success.is-visible{display:block}

/* map */
.map-embed{border-radius:4px;overflow:hidden;border:1px solid #ece4d4;line-height:0}
.map-embed iframe{width:100%;height:380px;border:0;display:block}

/* section helper */
.section.tight{padding:clamp(48px,6vw,84px) 0}
.bg-cream{background:var(--cream)}
.bg-paper{background:var(--paper)}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1024px){
  .product-grid,.blog-grid,.service-grid,.gen-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:920px){
  .page-hero{margin-top:-96px;min-height:auto}
  .page-hero .container{padding-top:128px;padding-bottom:48px}
  .page-hero.hero-solid{min-height:auto}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:fixed;inset:0 0 0 auto;width:min(86vw,340px);z-index:95;border-radius:0;overflow-y:auto;transform:translateX(100%);transition:transform .35s}
  body.filters-open .filters{transform:none}
  body.filters-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:94}
  .filter-toggle{display:inline-flex;align-items:center;gap:8px;border:1px solid #d8cfbd;border-radius:3px;padding:10px 16px;font-size:14px}
  .filter-toggle img{width:18px;height:18px}
  .product,.service-detail,.blog-feature,.history-block,.contact-grid{grid-template-columns:1fr}
  .history-block.flip .history-figure{order:0}
  .service-aside,.filters{position:static}
}
@media(max-width:640px){
  .product-grid,.blog-grid,.service-grid,.gen-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .news-row{grid-template-columns:64px 1fr;gap:16px}
  .news-row .btn{grid-column:2}
  .news-row .news-date b{font-size:1.5rem}
  .page-hero .container{padding-top:120px;padding-bottom:40px}
  .page-hero h1{font-size:clamp(2rem,8vw,2.6rem)}
  .page-hero p{font-size:1rem}
}

/* =========================================================================
   AUTH PAGES (login / register)
   ========================================================================= */
.auth-page{background:linear-gradient(160deg,#1a1854,#0e0d24);min-height:100vh}
.auth-page .site-header{background:rgba(14,13,36,.3)}
.auth-page .site-header.is-scrolled{background:rgba(14,13,36,.96)}
.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 16px 80px;min-height:calc(100vh - 40px)}
.auth-card{background:#fff;border-radius:6px;padding:clamp(28px,4vw,48px);width:100%;max-width:480px;box-shadow:0 28px 70px rgba(14,13,36,.32)}
.auth-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:26px;text-align:center}
.auth-logo img{width:72px;height:72px;border-radius:50%;padding:6px;margin-bottom:12px;background:rgba(210,172,103,.1);border:2px solid var(--gold)}
.auth-logo .auth-brand{font-family:var(--serif);font-size:1.5rem;color:var(--ink);line-height:1}
.auth-logo .auth-brand small{display:block;font-family:var(--sans);font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-top:4px}
.auth-title{font-family:var(--serif);font-size:1.75rem;color:var(--ink);margin-bottom:6px;text-align:center}
.auth-sub{font-size:13.5px;color:var(--muted);text-align:center;margin-bottom:24px}
.auth-divider{display:flex;align-items:center;gap:14px;margin:18px 0;color:var(--muted);font-size:13px}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:#e6dece}
.auth-links{text-align:center;font-size:13.5px;color:var(--muted);margin-top:20px}
.auth-links a{color:var(--red);font-weight:600}
.auth-links a:hover{text-decoration:underline}
.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;border:1.5px solid #d8cfbd;border-radius:3px;padding:13px 20px;font-size:14px;font-weight:500;color:var(--text);background:#fff;transition:.25s}
.btn-google:hover{background:var(--cream);border-color:var(--gold)}
.btn-google img{width:20px;height:20px}
.btn-full{width:100%;justify-content:center}
.field-icon{position:relative}
.field-icon input{padding-right:46px}
.field-icon .eye-toggle{position:absolute;right:13px;top:50%;transform:translateY(-50%);width:22px;height:22px;opacity:.45;cursor:pointer;transition:opacity .2s}
.field-icon .eye-toggle:hover{opacity:.8}
.age-check{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);line-height:1.5}
.age-check input{width:17px;height:17px;flex:0 0 auto;accent-color:var(--red);margin-top:2px}
.field-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.password-req{font-size:12px;color:var(--muted);margin-top:6px}
.password-strength-bar{height:3px;border-radius:2px;background:#e6dece;margin-top:6px;overflow:hidden}
.password-strength-bar span{display:block;height:100%;border-radius:2px;width:0;transition:width .35s,background .35s}
.auth-notice{background:#fdf8ee;border:1px solid #e8d9a0;border-radius:3px;padding:12px 14px;font-size:12.5px;color:#7a6020;margin-bottom:16px;display:flex;gap:8px;align-items:flex-start}
@media(max-width:480px){.field-row-2{grid-template-columns:1fr}}

/* =========================================================================
   CART PAGE
   ========================================================================= */
.cart-layout{display:grid;grid-template-columns:1fr 340px;gap:30px;align-items:start}
.cart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.cart-head h2{font-family:var(--serif);font-size:1.6rem;color:var(--ink)}
.cart-clear{font-size:12px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-weight:600;text-decoration:underline}
.cart-clear:hover{color:var(--red)}
.cart-table-wrap{background:#fff;border:1px solid #ece4d4;border-radius:4px;overflow:hidden}
.cart-table{width:100%;border-collapse:collapse}
.cart-table thead tr{background:var(--cream)}
.cart-table th{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:12px 18px;text-align:left;border-bottom:1px solid #e6dece;font-weight:600}
.cart-table td{padding:18px;border-bottom:1px solid #f5f0e8;vertical-align:middle}
.cart-table tbody tr:last-child td{border-bottom:0}
.cart-table th:nth-child(3),.cart-table th:nth-child(4),.cart-table td:nth-child(3),.cart-table td:nth-child(4){text-align:center}
.cart-table th:last-child,.cart-table td:last-child{text-align:right}
.cart-item-cell{display:flex;align-items:center;gap:16px}
.cart-item-img{width:68px;height:68px;object-fit:cover;border-radius:3px;background:linear-gradient(160deg,#f3ecdd,#e7dcc4);flex:0 0 auto}
.cart-item-name{font-family:var(--serif);font-size:1.1rem;color:var(--ink);display:block;line-height:1.2;margin-bottom:4px}
.cart-item-meta{font-size:12px;color:var(--muted)}
.cart-remove{display:inline-block;margin-top:6px;font-size:11.5px;color:var(--red);letter-spacing:.06em;text-transform:uppercase;font-weight:600}
.cart-remove:hover{text-decoration:underline}
.cart-unit{color:var(--muted);font-size:14px}
.cart-subtotal{font-family:var(--serif);font-size:1.1rem;color:var(--ink);font-weight:600;white-space:nowrap}
.qty-stepper{display:inline-flex;align-items:center;border:1px solid #d8cfbd;border-radius:3px;overflow:hidden}
.qty-stepper button{width:36px;height:36px;font-size:16px;color:var(--ink);background:#faf6ee;transition:.2s}
.qty-stepper button:hover{background:var(--cream)}
.qty-stepper input{width:44px;height:36px;text-align:center;border:0;border-left:1px solid #e2d9c6;border-right:1px solid #e2d9c6;font-size:14px;background:#fff;color:var(--ink)}
.cart-empty{text-align:center;padding:72px 24px;color:var(--muted)}
.cart-empty img{width:60px;height:60px;opacity:.35;margin-bottom:18px;display:block;margin-left:auto;margin-right:auto}
.cart-empty h3{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:10px}
.cart-empty p{margin-bottom:22px}
.order-summary{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:26px;position:sticky;top:120px}
.order-summary h3{font-family:var(--serif);font-size:1.3rem;color:var(--ink);margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid #f0e9da}
.sum-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:7px 0;color:var(--muted)}
.sum-row .sum-val{color:var(--ink);font-weight:500}
.sum-row.total-row{border-top:1px solid #e6dece;margin-top:10px;padding-top:16px;font-size:16px;color:var(--ink);font-weight:700}
.sum-row.total-row .sum-val{font-family:var(--serif);font-size:1.45rem;color:var(--red)}
.promo-field{display:flex;gap:8px;margin:14px 0}
.promo-field input{flex:1;border:1px solid #d8cfbd;border-radius:3px;padding:11px 13px;font-size:13.5px;background:#fdfbf6;transition:.2s}
.promo-field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(210,172,103,.15)}
.promo-field button{border:1.5px solid var(--red);color:var(--red);border-radius:3px;padding:11px 14px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;transition:.25s}
.promo-field button:hover{background:var(--red);color:#fff}
.delivery-note{font-size:12px;color:var(--muted);margin-bottom:14px;padding:10px 12px;background:var(--cream);border-radius:3px}
.checkout-btn{width:100%;justify-content:center;margin-top:12px}

/* =========================================================================
   CHECKOUT PAGE
   ========================================================================= */
.checkout-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:40px;overflow-x:auto;padding:4px}
.ck-step{display:flex;align-items:center;gap:10px;white-space:nowrap;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:500}
.ck-step-num{width:30px;height:30px;border-radius:50%;border:2px solid #c9c2d6;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex:0 0 auto;transition:.3s}
.ck-step.done .ck-step-num{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.ck-step.active .ck-step-num{background:var(--red);border-color:var(--red);color:#fff}
.ck-step.active{color:var(--ink)}
.ck-sep{width:52px;height:2px;background:#e6dece;flex:0 0 auto;margin:0 6px}
.ck-step.done+.ck-sep{background:var(--gold)}
.checkout-layout{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start}
.checkout-form-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:clamp(22px,3vw,36px);margin-bottom:20px}
.checkout-form-card h3{font-family:var(--serif);font-size:1.3rem;color:var(--ink);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.checkout-form-card h3 span.step-tag{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;font-family:var(--sans);font-size:12px;font-weight:700;flex:0 0 auto}
.section-lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;display:block;margin-bottom:14px;margin-top:22px}
.section-lbl:first-child{margin-top:0}
.delivery-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.delivery-opt{border:2px solid #e6dece;border-radius:4px;padding:16px;cursor:pointer;transition:.25s;position:relative}
.delivery-opt:has(input:checked){border-color:var(--red);background:#fdf8f8}
.delivery-opt input[type=radio]{position:absolute;top:14px;right:14px;accent-color:var(--red);width:16px;height:16px}
.delivery-opt .opt-name{font-weight:700;font-size:14px;color:var(--ink);margin-bottom:4px}
.delivery-opt .opt-desc{font-size:12px;color:var(--muted)}
.delivery-opt .opt-price{font-size:13px;font-weight:700;color:var(--red);margin-top:8px}
.pay-methods{display:flex;flex-direction:column;gap:10px}
.pay-opt{border:2px solid #e6dece;border-radius:4px;padding:15px 18px;cursor:pointer;transition:.25s;display:flex;align-items:center;gap:14px}
.pay-opt:has(input:checked){border-color:var(--red);background:#fdf8f8}
.pay-opt input[type=radio]{accent-color:var(--red);width:16px;height:16px;flex:0 0 auto}
.pay-opt .pay-label{font-weight:700;font-size:14px;color:var(--ink)}
.pay-opt .pay-sub{font-size:12px;color:var(--muted)}
.pay-opt .pay-logos{margin-left:auto;display:flex;gap:6px;align-items:center}
.pay-logo-chip{background:#f5f2ed;border:1px solid #e6dece;border-radius:3px;padding:3px 8px;font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.04em}
.card-details-block{margin-top:14px;padding:18px;background:var(--cream);border-radius:4px;display:none}
.card-details-block.is-active{display:block}
.checkout-sum-items{margin-bottom:14px}
.sum-item{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid #f5f0e8}
.sum-item:last-child{border-bottom:0}
.sum-item img{width:50px;height:50px;object-fit:cover;border-radius:3px;background:#f3ecdd;flex:0 0 auto}
.sum-item .si-name{font-size:13px;color:var(--ink);font-weight:600;line-height:1.3}
.sum-item .si-meta{font-size:11.5px;color:var(--muted)}
.sum-item .si-price{margin-left:auto;font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap}

/* =========================================================================
   ORDER SUCCESS
   ========================================================================= */
.order-success{display:none;text-align:center;max-width:600px;margin:0 auto;padding:20px 16px 60px}
.order-success.is-active{display:block}
.success-icon-wrap{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,#2e7d40,#4eaa60);display:flex;align-items:center;justify-content:center;margin:0 auto 28px;box-shadow:0 16px 40px rgba(46,125,64,.25)}
.success-icon-wrap img{width:38px;height:38px;filter:brightness(0) invert(1)}
.order-success h2{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.4rem);color:var(--ink);margin-bottom:12px}
.order-success .order-ref{font-family:var(--serif);font-size:1.35rem;color:var(--red);margin:14px 0 6px}
.order-success>p{color:var(--muted);font-size:15px;margin-bottom:6px}
.order-track-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:24px;margin:30px auto;max-width:440px;text-align:left}
.order-track-card h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:16px}
.track-steps{display:flex;flex-direction:column;gap:0}
.track-step{display:flex;gap:14px;align-items:flex-start;padding-bottom:0;position:relative;padding:12px 0}
.track-step:not(:last-child){border-bottom:1px dashed #ece4d4}
.track-dot{width:28px;height:28px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;margin-top:1px}
.track-dot.done{background:var(--gold)}
.track-dot.active{background:var(--red)}
.track-dot.pending{background:#f0e9da;border:2px solid #d8cfbd}
.track-dot img{width:13px;height:13px}
.track-dot.done img,.track-dot.active img{filter:brightness(0) invert(1)}
.track-dot.pending img{display:none}
.track-info .tr-label{font-size:14px;font-weight:600;color:var(--ink)}
.track-info .tr-sub{font-size:12px;color:var(--muted);margin-top:2px}
.track-step.active .track-dot.active{box-shadow:0 0 0 4px rgba(163,25,25,.15)}
.success-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px}

/* =========================================================================
   USER ACCOUNT CABINET
   ========================================================================= */
.cabinet-layout{display:grid;grid-template-columns:258px 1fr;gap:30px;align-items:start}
.cabinet-sidebar{background:#fff;border:1px solid #ece4d4;border-radius:4px;overflow:hidden;position:sticky;top:120px}
.cabinet-user{background:var(--ink);padding:24px 20px;text-align:center}
.user-avatar{width:66px;height:66px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-family:var(--serif);font-size:1.9rem;color:var(--ink);font-weight:600;text-transform:uppercase}
.user-avatar-img{width:66px;height:66px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);margin:0 auto 12px;display:block}
.cabinet-user .u-name{font-family:var(--serif);font-size:1.15rem;color:#fff;line-height:1.2}
.cabinet-user .u-email{font-size:11.5px;color:rgba(255,255,255,.55);margin-top:4px;word-break:break-all}
.cabinet-user .member-since{display:inline-block;margin-top:10px;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);opacity:.85}
.cabinet-nav{list-style:none;padding:0;margin:0}
.cabinet-nav li a{display:flex;align-items:center;gap:12px;padding:13px 20px;font-size:14px;color:var(--text);border-bottom:1px solid #f5f0e8;transition:.2s;position:relative}
.cabinet-nav li a:hover{background:var(--cream);color:var(--ink)}
.cabinet-nav li a.is-active{background:var(--cream);color:var(--red);font-weight:600;border-left:3px solid var(--red);padding-left:17px}
.cabinet-nav li a img{width:17px;height:17px;opacity:.5;flex:0 0 auto}
.cabinet-nav li a.is-active img{opacity:1}
.cabinet-nav li.nav-danger a{color:var(--red)}
.cabinet-nav li.nav-danger a img{opacity:.7}
.cabinet-nav li.nav-danger a:hover{background:#fdf5f5}
.cabinet-panel{display:none}
.cabinet-panel.is-active{display:block}
.panel-head{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid #ece4d4}
.panel-head h2{font-family:var(--serif);font-size:1.75rem;color:var(--ink);margin-bottom:5px}
.panel-head p{font-size:13.5px;color:var(--muted)}
/* overview stats */
.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.stat-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:20px;text-align:center}
.stat-card .stat-val{font-family:var(--serif);font-size:2rem;color:var(--red);line-height:1}
.stat-card .stat-lbl{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.recent-order-card{background:#fff;border:1px solid #ece4d4;border-radius:4px;padding:22px}
.recent-order-card h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.rec-order-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.rec-order-id{font-family:var(--serif);font-size:1.1rem;color:var(--ink)}
.rec-order-meta{font-size:13px;color:var(--muted)}
/* orders table */
.orders-wrap{background:#fff;border:1px solid #ece4d4;border-radius:4px;overflow:hidden}
.orders-table{width:100%;border-collapse:collapse}
.orders-table th{background:var(--cream);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:12px 16px;text-align:left;border-bottom:1px solid #e6dece;font-weight:600}
.orders-table td{padding:14px 16px;border-bottom:1px solid #f5f0e8;font-size:13.5px;color:var(--text);vertical-align:middle}
.orders-table tbody tr:last-child td{border-bottom:0}
.orders-table tbody tr.expandable:hover{background:var(--cream);cursor:pointer}
.ord-id{font-weight:700;color:var(--ink);font-size:12.5px}
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.status-badge::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.status-badge.processing{background:#fff8e8;color:#b07800}
.status-badge.shipped{background:#e8f0ff;color:#1a44c2}
.status-badge.delivered{background:#eef8f0;color:#2c6e3b}
.status-badge.cancelled{background:#fdf5f5;color:var(--red)}
.expand-btn{font-size:11px;color:var(--red);letter-spacing:.06em;text-transform:uppercase;font-weight:600;white-space:nowrap}
.order-detail-row{display:none;background:var(--cream)}
.order-detail-row.is-open{display:table-row}
.order-detail-row td{padding:20px 16px}
.order-detail-inner{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:start}
.order-detail-items{display:flex;flex-direction:column;gap:10px}
.od-item{display:flex;gap:12px;align-items:center;font-size:13px}
.od-item img{width:48px;height:48px;object-fit:cover;border-radius:3px;background:#e7dcc4;flex:0 0 auto}
.od-item .od-name{font-weight:600;color:var(--ink)}
.od-item .od-meta{font-size:11.5px;color:var(--muted)}
.delivery-tracker{min-width:200px}
.delivery-tracker .tracker-lbl{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:12px}
.tracker-steps{display:flex;flex-direction:column;gap:0}
.ts-step{display:flex;gap:10px;align-items:flex-start;padding:8px 0;position:relative}
.ts-step:not(:last-child)::before{content:"";position:absolute;left:7px;top:20px;bottom:0;width:2px;background:#e6dece;z-index:0}
.ts-step.done::before{background:var(--gold)}
.ts-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;border:2px solid #d8cfbd;margin-top:2px;background:#fff;position:relative;z-index:1}
.ts-step.done .ts-dot{background:var(--gold);border-color:var(--gold)}
.ts-step.active .ts-dot{background:var(--red);border-color:var(--red)}
.ts-text{font-size:12px;color:var(--muted);line-height:1.4}
.ts-step.done .ts-text,.ts-step.active .ts-text{color:var(--ink);font-weight:500}
.no-orders{text-align:center;padding:48px 24px;color:var(--muted)}
.no-orders img{width:52px;height:52px;opacity:.3;margin-bottom:14px;display:block;margin-left:auto;margin-right:auto}
/* security panel */
.security-note{background:var(--cream);border-left:3px solid var(--gold);padding:13px 16px;border-radius:0 3px 3px 0;margin-bottom:22px;font-size:13.5px;color:var(--muted);line-height:1.55}
.security-note strong{color:var(--ink)}
.pw-strength-bar{height:4px;background:#e6dece;border-radius:2px;margin-top:8px;overflow:hidden}
.pw-strength-bar span{display:block;height:100%;border-radius:2px;width:0;transition:width .35s,background .35s}
.pw-strength-bar span.weak{background:#a31919}
.pw-strength-bar span.fair{background:#b07800}
.pw-strength-bar span.strong{background:#2c6e3b}
.pw-req-list{display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:8px;font-size:12px;color:var(--muted)}
.pw-req-list span.met{color:#2c6e3b;font-weight:600}
.pw-req-list span.met::before{content:"✓ "}
/* danger zone */
.danger-zone{background:#fff;border:2px solid #f5d5d5;border-radius:4px;padding:26px 28px}
.danger-zone h3{font-family:var(--serif);font-size:1.25rem;color:var(--red);margin-bottom:10px}
.danger-zone p{font-size:13.5px;color:var(--muted);margin-bottom:18px;line-height:1.6}
.btn-danger{display:inline-flex;align-items:center;gap:9px;border:2px solid var(--red);color:var(--red);border-radius:3px;padding:12px 22px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:.25s;background:transparent}
.btn-danger:hover{background:var(--red);color:#fff}
/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(14,13,36,.72);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.modal-overlay.is-open{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:6px;padding:clamp(24px,4vw,40px);max-width:440px;width:100%;box-shadow:0 30px 80px rgba(14,13,36,.3);transform:translateY(16px) scale(.97);transition:transform .3s}
.modal-overlay.is-open .modal{transform:none}
.modal-icon{width:52px;height:52px;border-radius:50%;background:#fdf5f5;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.modal-icon img{width:24px;height:24px}
.modal h3{font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin-bottom:10px}
.modal p{font-size:14px;color:var(--muted);margin-bottom:18px;line-height:1.6}
.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:6px}
.btn-modal-cancel{border:1.5px solid #d8cfbd;border-radius:3px;padding:11px 20px;font-size:13px;color:var(--muted);font-weight:600;transition:.2s}
.btn-modal-cancel:hover{border-color:var(--ink);color:var(--ink)}
/* mobile cabinet */
.cabinet-mobile-select{display:none;margin-bottom:22px}
.cabinet-mobile-select select{width:100%;border:1.5px solid #d8cfbd;border-radius:3px;padding:13px 16px;font-size:15px;background:#fff;color:var(--text)}
.form-save-bar{display:flex;align-items:center;gap:16px;margin-top:24px}
.form-save-success{font-size:13px;color:#2c6e3b;font-weight:600;display:none}
.form-save-success.is-visible{display:block}

/* =========================================================================
   RESPONSIVE — commerce / account
   ========================================================================= */
@media(max-width:980px){
  .cabinet-layout{grid-template-columns:1fr}
  .cabinet-sidebar{position:static;display:none}
  .cabinet-mobile-select{display:block}
  .stat-cards{grid-template-columns:repeat(2,1fr)}
  .order-detail-inner{grid-template-columns:1fr}
  .delivery-tracker{min-width:auto}
}
@media(max-width:860px){
  .cart-layout,.checkout-layout{grid-template-columns:1fr}
  .order-summary{position:static}
  .delivery-options{grid-template-columns:1fr}
  .checkout-steps{justify-content:flex-start}
  .ck-sep{width:28px}
}
@media(max-width:640px){
  .cart-table thead{display:none}
  .cart-table,.cart-table tbody,.cart-table tr,.cart-table td{display:block}
  .cart-table td{border:0;padding:6px 16px}
  .cart-table tr{padding:14px 0;border-bottom:1px solid #f5f0e8}
  .cart-table tr:last-child{border-bottom:0}
  .stat-cards{grid-template-columns:1fr 1fr}
  .orders-table th:nth-child(4),.orders-table td:nth-child(4){display:none}
  .order-detail-inner{grid-template-columns:1fr}
  .ck-step .ck-step-label{display:none}
}
