*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#D8D5C4;--fg:#1a1a1a;--card:#fff;--primary:#172C3D;--primary-fg:#fff;
  --sage-light:#B0AD96;--sage-muted:hsl(100,14%,96%);--muted-fg:hsl(100,8%,40%);
  --border:hsl(100,12%,88%);
  
  /* Font Variables */
  --serif: 'Cormorant', Georgia, serif;
  --sans: 'Manrope', system-ui, sans-serif;
  --danger:hsl(0,65%,55%);
  --success:hsl(100,40%,40%);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased; overflow-x: hidden;}
::selection{background:hsl(100 22% 65%/.3);color:var(--fg)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;font-family:inherit;background:none;}
input, textarea, select {font-family:inherit; outline:none;}

/* ===== SPA ROUTING BASE ===== */
.page-view { display: none; }
.home-page.active, .product-page.active, .account-page.active, .checkout-page.active { display: block; animation: fadeUp .4s ease; }
.auth-page.active { display: flex; animation: fadeUp .4s ease; }
@keyframes fadeUp{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem;background:transparent;transition:all .4s ease; border-bottom: 1px solid transparent;}
@media(min-width:768px){.header{padding:1.5rem 3rem}}
.header.is-scrolled {background:rgba(244, 245, 240, 0.85); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom: 1px solid rgba(26,26,26,0.05);}

.menu-btn{display:flex; flex-direction:column; gap:6px; width:32px; align-items:flex-start; z-index: 60;}
.menu-btn span{display:block; height:1.5px; background:var(--fg); transition:all .3s ease;}
.menu-btn span:nth-child(1){width:100%;}
.menu-btn span:nth-child(2){width:75%;}
.menu-btn:hover span:nth-child(2){width:100%;}

.header-actions{display:flex; gap:0.75rem; align-items:center;}
.cart-pill{display:flex; align-items:center; gap:0.75rem; border:1.5px solid var(--fg); border-radius:99px; padding:4px 4px 4px 16px; font-weight:600; font-size:.875rem; transition:transform .2s;}
.cart-pill:hover{transform:translateY(-2px);}
.cart-circle{width:32px; height:32px; background:var(--fg); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--bg); position:relative;}
.cart-circle svg{width:16px; height:16px; stroke-width:2;}
.cart-badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;font-size:.6rem;font-weight:700;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;display:none; border:2px solid var(--bg);}
.cart-badge.show{display:flex}

.user-circle{width:40px; height:40px; background:var(--fg); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--bg); transition:transform .2s;}
.user-circle:hover{transform:translateY(-2px);}
.user-circle svg{width:20px; height:20px; stroke-width:2; fill:currentColor;}

/* ===== HERO ===== */
.hero-new{position:relative; width:100%; height:100vh; min-height:600px; display:flex; flex-direction:column; justify-content:flex-end; align-items:center; padding-bottom:2rem; overflow:hidden;}
.hero-bg{position:absolute; inset:0; z-index:-1; background-image:url('herobgphone.webp'); background-size:cover; background-position:center; background-color:#dbe6d5;}
@media(min-width:768px){ .hero-bg{background-image:url('hero-bg.webp');} .hero-new{padding-bottom:1rem;} }

.hero-cta{background:rgba(255,255,255,0.2); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,0.4); color:var(--fg); padding:1rem 2.5rem; border-radius:9999px; font-size:.875rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; display:inline-flex; align-items:center; gap:0.5rem; margin-bottom:1rem; transition:all .3s ease; z-index:10; box-shadow:0 10px 30px rgba(0,0,0,0.05);}
.hero-cta:hover{background:var(--fg); color:var(--bg); border-color:var(--fg); transform:translateY(-2px);}
.hero-cta svg{width:16px; height:16px;}

.hero-massive{font-family:var(--sans); font-size:16vw; font-weight:800; line-height:0.75; letter-spacing:-0.04em; color:var(--fg); margin:0; z-index:10; text-align:center; width:100%; pointer-events:none; white-space:nowrap;}
@media(min-width:768px){ .hero-massive{font-size:18vw;} }

/* ===== HOME SECTIONS ===== */
.features{padding:6rem 1.5rem;display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;max-width:64rem;margin:0 auto}
.feature-pill{background:#B0AD96;border:1px solid var(--border);border-radius:80px;width:100%;max-width:13rem;padding:3.5rem 1.5rem;text-align:center;transition:box-shadow .3s}
.feature-pill:hover{box-shadow:0 8px 30px rgba(0,0,0,.08)}
.feature-pill h3{font-family:var(--serif);font-size:1.5rem;font-weight:700;margin-bottom:.5rem;color:var(--fg)}
.feature-pill p{font-family:var(--sans);color:var(--muted-fg);font-size:.875rem;line-height:1.6}

.proof{padding:0 1.5rem 5rem;max-width:64rem;margin:0 auto;text-align:center}
.proof h2{font-family:var(--serif);font-size:clamp(2.5rem,5vw,3.5rem);font-style:italic;font-weight:600;margin-bottom:.5rem;color:var(--fg);letter-spacing:-0.02em}
.proof p{font-family:var(--sans);color:var(--muted-fg);font-size:.875rem;margin-bottom:3rem}
.comparison-wrapper{position:relative;width:100%;max-width:100vw;margin:0 auto;height:clamp(300px,60vh,500px);border-radius:1rem;overflow:hidden;box-shadow:0 20px 40px rgba(26,26,26,.1);background:var(--sage-light)}
.comparison-slider{position:relative;width:100%;height:100%;overflow:hidden;cursor:col-resize}
.comparison-slider img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;pointer-events:none;user-select:none}
.resize-image{position:absolute;top:0;left:0;height:100%;width:50%;overflow:hidden;z-index:2;border-right:2px solid var(--card);box-shadow:5px 0 15px rgba(0,0,0,.1)}
.resize-image img{width:auto;height:100%;max-width:none}
.handle{position:absolute;top:0;bottom:0;left:50%;width:40px;transform:translateX(-50%);z-index:10;display:flex;align-items:center;justify-content:center}
.handle-circle{width:44px;height:44px;background:var(--card);border:2px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.1);transition:transform .2s,border-color .2s;color:var(--fg);gap:2px}
.handle:hover .handle-circle{transform:scale(1.1);border-color:var(--primary)}
.handle-circle svg{width:16px;height:16px;stroke-width:2.5}
.slider-label{position:absolute;top:1.5rem;background:rgba(255,255,255,.85);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:var(--fg);font-family:var(--serif);font-size:1rem;font-weight:700;padding:.4rem 1.25rem;border-radius:9999px;z-index:20;pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,.05);text-transform:uppercase;letter-spacing:1px}
.label-before{left:1.5rem}
.label-after{right:1.5rem}

.collection{padding:0 1.5rem 5rem;max-width:72rem;margin:0 auto}
.collection h2{font-family:var(--serif);font-size:2rem;font-weight:700;margin-bottom:2.5rem;letter-spacing:-.02em}
@media(min-width:768px){.collection h2{font-size:2.5rem}}
.collection-grid{display:grid;gap:1.5rem;width:100%;max-width:100%;overflow:hidden;}
@media(min-width:1024px){.collection-grid{grid-template-columns:3fr 2fr}}
.card-bundle{background:var(--sage-light);border-radius:1rem;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between;min-height:420px;cursor:pointer;transition:box-shadow .3s}
.card-bundle:hover{box-shadow:0 8px 30px rgba(0,0,0,.08)}
.card-bundle .img-wrap{background:var(--primary);border-radius:.75rem;flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;margin-bottom:1.25rem}
.card-bundle .img-wrap img{max-width:100%;height:auto;object-fit:contain;filter:drop-shadow(0 10px 25px rgba(0,0,0,.15))}
.card-bundle .info{display:flex;align-items:flex-end;justify-content:space-between;padding:0 .5rem}
.card-bundle .info .price{font-family:var(--serif);font-weight:700;font-size:1.5rem}
.card-bundle .info h3{font-family:var(--sans);font-size:1.25rem;font-weight:700;margin-bottom:.25rem}
.card-bundle .info .sub{font-family:var(--sans);color:var(--muted-fg);font-size:.75rem}

.btn-buy{background:#172C3D;color:var(--bg);padding:.75rem 1.5rem;border-radius:9999px;font-size:.875rem;font-weight:700;display:inline-flex;align-items:center;gap:.5rem;transition:opacity .2s, transform .2s}
.btn-buy:hover{opacity:.9; transform:translateY(-2px);}
.btn-buy-sm{padding:.625rem 1.25rem;font-size:.75rem}

.side-cards{display:flex;flex-direction:column;gap:1.5rem}
.card-side{background:var(--sage-light);border-radius:1rem;padding:1rem;display:flex;align-items:center;gap:1.25rem;flex:1;cursor:pointer;transition:box-shadow .3s}
.card-side:hover{box-shadow:0 8px 30px rgba(0,0,0,.08)}
.card-side .thumb{background:var(--primary);border-radius:.75rem;width:7rem;height:7rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:.75rem}
.card-side .thumb img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 5px 15px rgba(0,0,0,.12))}
.card-side h3{font-family:var(--sans);font-size:1.125rem;font-weight:700}
.card-side .price{font-family:var(--serif);font-weight:700;font-size:1.25rem;margin-top:.25rem}

@media (max-width: 1023px) {
  .card-side { width: 100%; padding: 1rem; gap: 1rem; }
  @media (max-width: 480px) {
    .card-side .thumb { width: 5.5rem; height: 5.5rem; padding: 0.5rem; }
    .card-side h3 { font-size: 1rem; }
    @media (max-width: 380px) {
      .card-bundle .info { flex-direction: column; align-items: flex-start; gap: 1rem; }
      .card-bundle .btn-buy { width: 100%; justify-content: center; }
    }
  }
}

.faq{background:var(--primary);color:#ffffff;clip-path:polygon(0 6vw,100% 0,100% 100%,0 100%);position:relative}
.faq-inner{max-width:42rem;margin:0 auto;text-align:center;padding:8rem 1.5rem 5rem}
@media(min-width:768px){.faq-inner{padding:10rem 1.5rem 7rem}}
.faq h2{font-family:var(--serif);font-size:clamp(2.5rem,5vw,3.5rem);font-style:italic;font-weight:600;margin-bottom:1rem;letter-spacing:-0.02em}
.faq>p,.faq-inner>p{font-family:var(--sans);color:#ffffff;font-size:.9rem;max-width:28rem;margin:0 auto 3.5rem}
.faq-list{text-align:left}
.faq-item{border-top:1px solid #3C5265}
.faq-item:last-child{border-bottom:1px solid #ffffff}
.faq-btn{font-family:var(--sans);width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;background:none;font-weight:700;font-size:.875rem;color:#F4F5F0;text-align:left;transition:opacity .2s}
@media(min-width:768px){.faq-btn{font-size:1rem}}
.faq-btn:hover{opacity:.8}
.faq-btn svg{width:20px;height:20px;flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-btn svg{transform:rotate(45deg)}
.faq-answer{font-family:var(--sans);padding-bottom:1.5rem;margin-top:-.5rem;color:#ffffff;font-size:.875rem;line-height:1.7;display:none}
.faq-item.open .faq-answer{display:block}

.footer{background:#D8D5C4;padding:4rem 1.5rem 2rem}
@media(min-width:768px){.footer{padding:4rem 3rem 2rem}}
.footer-inner{max-width:72rem;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem;margin-bottom:4rem}
@media(min-width:768px){.footer-grid{grid-template-columns:1fr 1fr 1fr 1fr 1fr}}
.footer .brand{grid-column:span 2}
@media(min-width:768px){.footer .brand{grid-column:span 1}}
.footer .brand-name{display:flex;align-items:center;gap:.625rem;margin-bottom:1rem}
.footer .brand-icon{width:1rem;height:1rem;background:var(--primary);border-radius:50% 50% 0 50%;transform:rotate(45deg)}
.footer .brand-name span{font-family:var(--serif);font-size:1.5rem;font-weight:700;text-transform:uppercase}
.footer .brand p{font-family:var(--sans);color:var(--muted-fg);font-size:.8rem;line-height:1.6}
.footer h4{font-family:var(--sans);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:1.25rem}
.footer ul{list-style:none}
.footer li{margin-bottom:.75rem}
.footer li a{font-family:var(--sans);color:var(--muted-fg);font-size:.875rem;transition:color .2s}
.footer li a:hover{color:var(--fg)}
.footer .contact{text-align:left;font-family:var(--sans)}
@media(min-width:768px){.footer .contact{text-align:right}}
.footer .contact .phone{font-weight:700;font-size:.875rem;margin-bottom:.25rem}
.footer .contact .email{color:var(--primary);font-weight:600;font-size:.875rem;margin-bottom:1.25rem}
.footer .contact .social-label{color:var(--muted-fg);font-size:.75rem;margin-bottom:.75rem}
.footer .socials{display:flex;gap:.5rem}
@media(min-width:768px){.footer .socials{justify-content:flex-end}}
.footer .socials a{width:2.25rem;height:2.25rem;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--muted-fg);transition:border-color .2s,color .2s;font-family:var(--sans);font-weight:600}
.footer .socials a:hover{border-color:var(--fg);color:var(--fg)}
.footer-bar{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-size:.75rem;color:var(--muted-fg);font-family:var(--sans)}
@media(min-width:640px){.footer-bar{flex-direction:row;justify-content:space-between}}

/* ===== PRODUCT PAGE ===== */
.product-page{min-height:100vh;padding-top:90px;padding-bottom:5rem;font-family:var(--sans)}
.pp-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--muted-fg);padding:1.5rem;cursor:pointer;transition:color .2s}
.pp-back:hover{color:var(--fg)}
.pp-container{max-width:64rem;margin:0 auto;padding:0 1.5rem}
.pp-grid{display:grid;gap:2.5rem}
@media(min-width:768px){.pp-grid{grid-template-columns:1fr 1fr}}
.pp-image{background:var(--primary);border-radius:1rem;display:flex;align-items:center;justify-content:center;padding:3rem;min-height:400px}
.pp-image img{max-width:320px;width:100%;object-fit:contain;filter:drop-shadow(0 15px 35px rgba(0,0,0,.15))}
.pp-details{display:flex;flex-direction:column;justify-content:center}
@media(min-width:768px){.pp-details{position:sticky;top:120px;align-self:flex-start;}}
.pp-details h1{font-family:var(--serif);font-size:2.5rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-0.02em}
.pp-details .pp-price{font-family:var(--serif);font-size:1.75rem;font-weight:700;margin-bottom:1rem;color:var(--fg)}
.pp-details .pp-desc{color:var(--muted-fg);font-size:.9rem;line-height:1.7;margin-bottom:2rem}
.pp-qty{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem}
.pp-qty label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted-fg)}
.pp-qty .qty-wrap{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:9999px;padding:0;overflow:hidden;background:var(--sage-muted);}
.pp-qty button{font-family:var(--sans);width:42px;height:42px;border-radius:0;background:transparent;border:none;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:600;transition:background .2s;color:var(--fg);}
.pp-qty button:hover{background:var(--border);}
.pp-qty .qty-val{font-size:.9rem;font-weight:700;min-width:36px;text-align:center;border-left:1px solid var(--border);border-right:1px solid var(--border);height:42px;line-height:42px;}
.pp-accordion{margin-bottom:2rem}
.pp-acc-item{border-top:0.5px solid var(--border); padding-top:0.25rem;}
.pp-acc-item:last-child{border-bottom:0.5px solid var(--border)}
.pp-acc-item + .pp-acc-item{margin-top:0.5rem;}
.pp-acc-btn{font-family:var(--sans);width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 0;background:none;font-weight:600;font-size:.875rem;color:var(--fg);text-align:left;transition:opacity .2s;letter-spacing:0.01em;}
.pp-acc-btn:hover{opacity:.7}
.pp-acc-btn svg{width:18px;height:18px;flex-shrink:0;transition:transform .3s}
.pp-acc-item.open .pp-acc-btn svg{transform:rotate(45deg)}
.pp-acc-answer{padding-bottom:1.25rem;color:var(--muted-fg);font-size:.825rem;line-height:1.8;display:none;font-weight:300;}
.pp-acc-answer.ingredients-text{font-family:'SF Mono','Fira Code','Cascadia Code','Consolas',monospace;font-size:.78rem;letter-spacing:0.02em;line-height:1.9;color:var(--muted-fg);}
.pp-acc-item.open .pp-acc-answer{display:block}
.pp-bottom-bar{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--border);padding:1rem 1.5rem;display:flex;gap:.75rem;z-index:60;font-family:var(--sans)}
@media(min-width:768px){.pp-bottom-bar{display:none;}}
.pp-desktop-cta{display:none; gap:.75rem; margin-top:1.5rem;}
@media(min-width:768px){.pp-desktop-cta{display:flex;}}
.btn-primary{flex:1;padding:.875rem;background:var(--fg);color:var(--bg);border-radius:9999px;font-size:.875rem;font-weight:700;transition:all .2s;font-family:inherit;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;justify-content:center;}
.btn-primary:hover{opacity:.9; transform:translateY(-2px);}
.btn-secondary{flex:1;padding:.875rem;border:2px solid var(--fg);color:var(--fg);background:transparent;border-radius:9999px;font-size:.875rem;font-weight:700;transition:all .2s;font-family:inherit;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;justify-content:center;}
.btn-secondary:hover{background:var(--sage-muted)}
.btn-outline{padding:.5rem 1rem; border:1px solid var(--border); border-radius:99px; background:var(--card); font-size:.75rem; font-weight:700; color:var(--fg); text-transform:uppercase; letter-spacing:1px; transition:all .2s; cursor:pointer;}
.btn-outline:hover{border-color:var(--fg);}

/* ===== UI COMPONENTS & VALIDATION ===== */
.form-group{margin-bottom:1.25rem; position:relative;}
.form-group label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;color:var(--muted-fg);}
.form-control{width:100%;padding:1rem;border:1px solid var(--border);border-radius:.5rem;font-size:.875rem;background:var(--sage-muted);transition:border-color .2s;}
.form-control:focus{border-color:var(--fg); background:var(--card);}
/* Validation States */
.form-control.valid { border-color: var(--success); }
.form-control.invalid { border-color: var(--danger); }
.validation-msg { font-size: 0.75rem; color: var(--danger); display: none; margin-top: 0.4rem; font-weight:600;}
.form-control.invalid + .validation-msg { display: block; }
.form-control.invalid ~ .password-toggle { top:-10px; } 

.password-wrapper { position: relative; }
.password-toggle { position: absolute; right: 1rem; color: var(--muted-fg); cursor: pointer; display: flex; align-items: center; justify-content: center; height: 100%; top: 0; }
.password-toggle:hover { color: var(--fg); }

/* ===== AUTH PAGE (ENTRY FLOW) ===== */
.auth-page{min-height:100vh; padding:120px 1.5rem 5rem; align-items:center; justify-content:center;}
.auth-container{background:var(--card); border-radius:1rem; width:100%; max-width:440px; padding:3rem 2.5rem; box-shadow:0 20px 40px rgba(0,0,0,0.05);}
.auth-container h2{font-family:var(--serif);font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:.5rem;letter-spacing:-0.02em}
.auth-sub{text-align:center;color:var(--muted-fg);font-size:.9rem;margin-bottom:2.5rem}
.auth-switch{text-align:center;margin-top:2rem;font-size:.875rem;color:var(--muted-fg)}
.auth-switch a{color:var(--fg);font-weight:700;cursor:pointer;text-decoration:underline}
.auth-msg{text-align:center;font-size:.85rem;margin-top:1rem;min-height:1.2em;font-weight:600;}
.auth-msg.error{color:var(--danger)}
.auth-msg.success{color:var(--success)}
.forgot-link{display:block; text-align:right; font-size:.75rem; font-weight:700; color:var(--muted-fg); margin-top:.5rem; cursor:pointer;}
.forgot-link:hover{color:var(--fg); text-decoration:underline;}

#authEntry .auth-btn-group { display: flex; flex-direction: column; gap: 1rem; }

/* ===== ACCOUNT PAGE (LUXURY DASHBOARD) ===== */
.account-page{min-height:100vh; padding:0; background:var(--bg);}
.acc-header{padding:2rem 2rem 1.5rem; display:flex; justify-content:space-between; align-items:flex-end; border-bottom:1px solid var(--border);}
.acc-header h1{font-family:var(--serif); font-size:2rem; font-weight:700; letter-spacing:-0.02em; line-height:1;}
.acc-header p{color:var(--muted-fg); font-weight:500; margin-top:.35rem; font-size:.85rem;}
.btn-logout{display:none;}

/* === Sidebar Rail & Drawer === */
.acc-layout { display: flex; flex-direction: row; min-height: 100vh; position: relative;}

.acc-sidebar {
  position: fixed; top: 0; left: 0; height: 100vh; z-index: 200;
  background: var(--card); border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  width: 56px; padding: 0;
  transition: width 0.28s cubic-bezier(.4,0,.2,1), box-shadow 0.28s ease;
  overflow: hidden;
}
.acc-sidebar.expanded {
  width: 240px;
  box-shadow: 4px 0 24px rgba(0,0,0,0.08);
}

.drawer-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.18); z-index:190; backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); transition: opacity .28s; }
.drawer-overlay.active { display:block; }

/* Sidebar zones */
.sidebar-zone-top { padding:1rem 0; display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--border); flex-shrink:0; min-height:56px; gap:0.75rem; overflow:hidden; }
.sidebar-logo { display:flex; align-items:center; gap:0.5rem; cursor:pointer; padding:0 0.5rem; white-space:nowrap; text-decoration:none; color:var(--fg); }
.sidebar-logo-icon { width:28px; height:28px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.sidebar-logo-icon .logo-dot { width:14px; height:14px; background:var(--primary); border-radius:50% 50% 0 50%; transform:rotate(45deg); }
.sidebar-logo-text { font-family:var(--serif); font-size:1.1rem; font-weight:700; text-transform:uppercase; letter-spacing:0.02em; opacity:0; transition: opacity .2s ease .05s; pointer-events:none; }
.acc-sidebar.expanded .sidebar-logo-text { opacity:1; pointer-events:auto; }

.sidebar-toggle-icon { display:none; }

.sidebar-expand-btn { display:flex; align-items:center; justify-content:center; width:100%; padding:0.5rem 0; border-bottom:1px solid var(--border); color:var(--muted-fg); transition:color .18s, background .18s; cursor:pointer; background:none; }
.sidebar-expand-btn:hover { color:var(--fg); background:var(--sage-light); }
.sidebar-expand-btn svg { width:16px; height:16px; }
@media(max-width:480px) { .sidebar-expand-btn { display:none; } }

.sidebar-zone-mid { flex:1; padding:0.75rem 0; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.sidebar-zone-bot { padding:0.75rem 0; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:2px; flex-shrink:0; }

.acc-tab-btn {
  display:flex; align-items:center; gap:0.75rem;
  padding: 0.65rem 0.75rem; margin: 0 0.4rem; width: calc(100% - 0.8rem);
  border-radius: 4px; transition: background .18s, color .18s;
  font-weight: 600; color: var(--muted-fg); font-size: .75rem;
  text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap;
  min-height: 38px;
}
.acc-tab-btn .tab-icon { width:20px; height:20px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.acc-tab-btn .tab-icon svg { width:18px; height:18px; stroke-width:1.5; }
.acc-tab-btn .tab-label { opacity:0; transition: opacity .18s ease .05s; pointer-events:none; }
.acc-sidebar.expanded .acc-tab-btn .tab-label { opacity:1; pointer-events:auto; }
.acc-tab-btn:hover { background: var(--sage-light); color:var(--fg); }
.acc-tab-btn.active { background: var(--sage-muted); color: var(--fg); }

.btn-logout-sidebar { display:flex; align-items:center; gap:0.75rem; padding:0.65rem 0.75rem; margin:0 0.4rem; width:calc(100% - 0.8rem); border-radius:4px; font-weight:600; color:var(--danger); font-size:.75rem; text-transform:uppercase; letter-spacing:0.5px; white-space:nowrap; transition:background .18s; }
.btn-logout-sidebar .tab-icon { width:20px; height:20px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.btn-logout-sidebar .tab-icon svg { width:18px; height:18px; stroke-width:1.5; }
.btn-logout-sidebar .tab-label { opacity:0; transition:opacity .18s ease .05s; }
.acc-sidebar.expanded .btn-logout-sidebar .tab-label { opacity:1; }
.btn-logout-sidebar:hover { background:hsl(0,65%,96%); }

/* Content area pushed by rail */
.acc-content-area { flex: 1; width: 100%; margin-left: 56px; transition: margin-left .28s cubic-bezier(.4,0,.2,1); padding: 0 2rem 3rem; }

/* Mobile FAB for sidebar */
.acc-mobile-fab {
  display:none; position:fixed; bottom:1.25rem; left:1.25rem; z-index:180;
  width:44px; height:44px; border-radius:4px;
  background:var(--fg); color:var(--bg); border:none;
  box-shadow:0 2px 12px rgba(0,0,0,0.15);
  align-items:center; justify-content:center; transition: transform .2s, opacity .2s;
}
.acc-mobile-fab svg { width:20px; height:20px; stroke-width:1.5; }
.acc-mobile-fab:active { transform:scale(0.92); }

/* Desktop: sidebar pushes content */
@media(min-width:481px) {
  .acc-sidebar.expanded ~ .acc-content-area { margin-left:240px; }
  .acc-sidebar.expanded ~ .acc-header-wrap { margin-left:240px; }
  .drawer-overlay { display:none !important; }
}

/* Mobile: sidebar hidden, FAB visible */
@media(max-width:480px) {
  .acc-sidebar { width:0; border-right:none; }
  .acc-sidebar.expanded { width:240px; border-right:1px solid var(--border); }
  .acc-content-area { margin-left:0 !important; padding: 0 1rem 3rem; }
  .acc-header { padding: 1.5rem 1rem 1rem; }
  .acc-mobile-fab { display:flex; }
}

.acc-tab-content{display:none; animation: fadeUp .3s ease;}
.acc-tab-content.active{display:block;}

/* Overview & Completeness Bar */
.overview-card { background:var(--sage-light); border-radius:6px; padding:2rem; margin-bottom:2rem; border:1px solid var(--border); }
.overview-card h2 { font-family:var(--serif); font-size:1.75rem; font-weight:700; margin-bottom:1rem; }
.comp-wrap { background:var(--border); border-radius:4px; height:6px; width:100%; overflow:hidden; margin:1rem 0; }
.comp-bar { background:var(--fg); height:100%; transition:width 0.5s ease; border-radius:4px; }
.comp-text { font-size:.75rem; font-weight:700; color:var(--muted-fg); text-transform:uppercase; letter-spacing:1px; }

/* Enhanced Order Cards & Stepper */
.order-card{background:var(--card); border:1px solid var(--border); border-radius:6px; padding:1.5rem; margin-bottom:1.5rem;}
.order-header{display:flex; justify-content:space-between; margin-bottom:1.5rem; font-size:.875rem; color:var(--muted-fg); border-bottom:1px solid var(--border); padding-bottom:1rem;}
.order-header strong{color:var(--fg); font-size:1.1rem;}

.order-stepper { display: flex; justify-content: space-between; margin: 0 1rem 2rem; position: relative; }
.order-stepper::before { content: ''; position: absolute; top: 17px; left: 0; right: 0; height: 1px; background: var(--border); z-index: 1; }
.step { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 0.5rem; }
.step-dot { width: 36px; height: 36px; border-radius: 50%; background: var(--card); border: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center; transition:all .3s;}
.step-dot svg { width:16px; height:16px; stroke-width:1.5; }
.step.active .step-dot svg { stroke: white; }
.step.active .step-dot { border-color: var(--success); background: var(--success); color: white; }
.step-label { font-size: 0.65rem; font-weight: 600; color: var(--muted-fg); text-transform: uppercase; letter-spacing:0.5px; background:var(--card); padding:0 4px; margin-top:0.25rem;}
.step.active .step-label { color: var(--fg); }

.order-items-list{margin-bottom:1.5rem;}
.order-item{display:flex; gap:1rem; align-items:center; margin-bottom:.75rem;}
.order-item img{width:60px; height:60px; background:var(--primary); border-radius:.5rem; object-fit:contain;}
.order-item-details h4{font-size:.875rem; font-weight:700;}
.order-item-details p{font-size:.75rem; color:var(--muted-fg);}

.order-actions { display:flex; gap:1rem; border-top:1px solid var(--border); padding-top:1.5rem; flex-wrap:wrap;}
.empty-state { text-align: center; padding: 4rem 1rem; background: var(--sage-light); border-radius: 1rem; border: 1px dashed var(--border); }
.empty-state svg { width: 48px; height: 48px; stroke: var(--muted-fg); margin-bottom: 1rem; stroke-width: 1.5; }
.empty-state h3 { font-family: var(--serif); font-size: 1.5rem; font-weight: 700; margin-bottom: 0.5rem; }
.empty-state p { font-size: 0.875rem; color: var(--muted-fg); margin-bottom: 1.5rem; max-width: 300px; margin-inline: auto; }

/* Skin Profile & Addresses */
.skin-grid { display:grid; grid-template-columns:1fr; gap:1rem; margin-bottom:2rem;}
@media(min-width:768px){.skin-grid{grid-template-columns:1fr 1fr;}}
.skin-card { border:1.5px solid var(--border); padding:1.5rem; border-radius:.75rem; cursor:pointer; text-align:center; transition:all .2s; position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.skin-card h4 { font-weight:700; font-size:.875rem; margin-bottom:.5rem;}
.skin-card p { font-size:.75rem; color:var(--muted-fg);}
.skin-card:hover { border-color:var(--fg); }
.skin-card.selected { border-color:var(--primary); border-width:2px; background:var(--sage-muted); color:var(--fg); position:relative; }
.skin-card.selected p { color:var(--muted-fg); }
.skin-card .skin-check { display:none; position:absolute; top:0.5rem; right:0.5rem; width:20px; height:20px; background:var(--primary); border-radius:50%; align-items:center; justify-content:center; }
.skin-card .skin-check svg { width:12px; height:12px; stroke:#fff; stroke-width:3; }
.skin-card.selected .skin-check { display:flex; }

.address-grid{display:grid; gap:1rem;}
@media(min-width:768px){.address-grid{grid-template-columns:1fr 1fr;}}
.address-card{background:var(--card); border:1px solid var(--border); border-radius:.75rem; padding:1.5rem; position:relative;}
.address-card.selectable{cursor:pointer; transition:all .2s;}
.address-card.selectable:hover{border-color:var(--fg);}
.address-card.selected{border-color:var(--fg); background:var(--sage-muted); box-shadow:inset 0 0 0 1px var(--fg);}
.address-card h4{font-size:1rem; font-weight:700; margin-bottom:.25rem; display:flex; align-items:center; gap:.5rem;}
.address-card p{font-size:.875rem; color:var(--muted-fg); line-height:1.5; margin-bottom:1rem;}
.address-badge{background:var(--fg); color:var(--bg); font-size:.65rem; padding:2px 8px; border-radius:4px; text-transform:uppercase; letter-spacing:1px;}
.address-actions{display:flex; gap:.75rem;}
.address-actions button{font-size:.75rem; font-weight:700; text-transform:uppercase; color:var(--muted-fg); transition:color .2s;}
.address-actions button:hover{color:var(--fg);}
.address-actions button.del:hover{color:var(--danger);}
.address-add-card{background:transparent; border:1px dashed var(--muted-fg); border-radius:.75rem; padding:1.5rem; text-align:center; cursor:pointer; color:var(--muted-fg); font-weight:600; font-size:.875rem; transition:all .2s; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem;}
.address-add-card:hover{border-color:var(--fg); color:var(--fg); background:var(--card);}
.new-address-form{background:var(--sage-light); padding:1.5rem; border-radius:.75rem; display:none; margin-top:1rem;}
.new-address-form.active{display:block;}
.settings-card{background:var(--card); border:1px solid var(--border); border-radius:.75rem; padding:2rem; max-width:440px;}

/* ===== CHECKOUT PAGE ===== */
.checkout-page{min-height:100vh; padding:120px 1.5rem 8rem;}
.chk-container{max-width:48rem; margin:0 auto;}
.chk-title{font-family:var(--serif); font-size:2.5rem; font-weight:700; margin-bottom:2rem; text-align:center;}

.chk-section{background:var(--card); border-radius:1rem; padding:2rem; margin-bottom:2rem; box-shadow:0 10px 30px rgba(0,0,0,0.03);}
.chk-section h2{font-size:1.25rem; font-weight:700; margin-bottom:1.5rem; display:flex; align-items:center; gap:.75rem;}
.chk-section h2 span{background:var(--fg); color:var(--bg); width:24px; height:24px; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; font-size:.875rem;}

.chk-summary-item{display:flex; justify-content:space-between; align-items:center; padding:1rem 0; border-bottom:1px solid var(--border);}
.chk-summary-info{display:flex; gap:1rem; align-items:center;}
.chk-summary-info img{width:60px; height:60px; background:var(--primary); border-radius:.5rem; object-fit:contain;}

.promo-box{display:flex; gap:.5rem; margin-top:1.5rem;}
.promo-box input{flex:1;}
.promo-box button{background:var(--fg); color:var(--bg); padding:0 1.5rem; border-radius:.5rem; font-weight:700; font-size:.75rem; text-transform:uppercase; letter-spacing:1px;}
.promo-msg{font-size:.75rem; font-weight:700; margin-top:.5rem;}
.promo-msg.success{color:var(--success);}
.promo-msg.error{color:var(--danger);}

.chk-calc-row{display:flex; justify-content:space-between; align-items:center; padding:.5rem 0; font-size:.875rem; color:var(--muted-fg);}
.chk-total-row{display:flex; justify-content:space-between; align-items:center; padding-top:1rem; margin-top:1rem; border-top:2px solid var(--border); font-family:var(--serif); font-size:1.5rem; font-weight:700; color:var(--fg);}

.shipping-options{margin-top:1.5rem;}
.ship-opt{display:flex; justify-content:space-between; align-items:center; padding:1rem; border:1px solid var(--border); border-radius:.5rem; margin-bottom:.5rem; cursor:pointer;}
.ship-opt.selected{border-color:var(--fg); background:var(--sage-muted);}
.ship-opt strong{font-size:.875rem; color:var(--fg);}
.ship-opt span{font-size:.875rem; font-weight:700; color:var(--muted-fg);}

.card-element{background:var(--sage-muted); padding:1.5rem; border-radius:.5rem; border:1px solid var(--border);}
.card-element-header{display:flex; justify-content:space-between; margin-bottom:1rem; font-weight:700; font-size:.875rem;}

.chk-bottom-bar{position:fixed; bottom:0; left:0; right:0; background:var(--card); border-top:1px solid var(--border); padding:1.5rem; display:flex; justify-content:center; z-index:60; box-shadow:0 -10px 20px rgba(0,0,0,0.05);}

/* ===== CART DRAWER ===== */
.cart-drawer{display:none;position:fixed;inset:0;z-index:100;font-family:var(--sans)}
.cart-drawer.open{display:block;}
.cart-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
.cart-panel{position:absolute;top:0;right:0;bottom:0;width:100%;max-width:420px;background:var(--card);padding:2rem 1.5rem;display:flex;flex-direction:column;animation:slideIn .3s ease}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.cart-panel h2{font-family:var(--serif);font-weight:700;font-size:2rem;margin-bottom:1.5rem;}
.close-cart{position:absolute;top:1.5rem;right:1.5rem;font-size:1.25rem;color:var(--muted-fg);width:32px;height:32px;border-radius:50%; display:flex; align-items:center; justify-content:center;}
.close-cart:hover{background:var(--sage-muted)}
.cart-items{flex:1;overflow-y:auto}
.cart-item{display:flex;gap:1rem;padding:1.25rem 0;border-bottom:1px solid var(--border);align-items:center}
.cart-item .ci-img{width:70px;height:70px;background:var(--primary);border-radius:.5rem;}
.cart-item .ci-info{flex:1}
.cart-item .ci-name{font-weight:700;font-size:.875rem;}
.cart-item .ci-price{font-family:var(--serif);font-size:1rem;font-weight:700;}
.cart-item .ci-controls{display:flex;align-items:center;gap:.5rem}
.cart-item .ci-controls button{width:28px;height:28px;border-radius:50%;background:var(--sage-muted);font-weight:600;display:flex; align-items:center; justify-content:center;}
.cart-item .ci-qty{font-size:.875rem;font-weight:700;min-width:20px;text-align:center}
.cart-item .ci-remove{background:none;color:var(--danger);font-size:.75rem;font-weight:700;margin-top:.25rem;padding:0;display:block;}
.cart-summary{border-top:2px solid var(--fg);padding-top:1.5rem;margin-top:1rem}
.cs-row{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.9rem}
.cs-total{font-family:var(--serif);font-weight:700;font-size:1.5rem;margin-top:.5rem}

/* ===== MISC UI ===== */
.mobile-menu{display:none;position:fixed;inset:0;top:0;background:var(--bg);z-index:40;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--serif);font-size:3rem;font-style:italic;font-weight:600;transition:color .2s}
.mobile-menu a:hover{color:var(--primary)}
.mobile-menu .close-btn {position:absolute; top:2rem; right:2rem; background:none; padding:1rem;}
.mobile-menu .close-btn svg {width:32px; height:32px; stroke:var(--fg);}

.toast{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%);background:var(--fg);color:var(--bg);padding:.75rem 1.5rem;border-radius:9999px;font-size:.85rem;font-weight:600;z-index:200;opacity:0;pointer-events:none;transition:all .3s;}
.toast.show{opacity:1;pointer-events:auto; transform:translateX(-50%) translateY(-10px);}

/* ===== MOCK PAYSTACK OVERLAY ===== */
.paystack-mock{display:none; position:fixed; inset:0; background:rgba(0,0,0,0.6); backdrop-filter:blur(5px); z-index:9999; align-items:center; justify-content:center;}
.paystack-mock.active{display:flex; animation:fadeUp .3s ease;}
.ps-modal{background:#fff; width:100%; max-width:380px; border-radius:1rem; padding:2.5rem 2rem; text-align:center; box-shadow:0 20px 50px rgba(0,0,0,0.2);}
.ps-logo{font-family:var(--sans); font-weight:800; font-size:1.5rem; color:#0ba4db; margin-bottom:1.5rem;}
.ps-spinner{width:40px; height:40px; border:4px solid #f3f3f3; border-top:4px solid #0ba4db; border-radius:50%; animation:spin 1s linear infinite; margin:0 auto 1.5rem;}
@keyframes spin{0%{transform:rotate(0deg)} 100%{transform:rotate(360deg)}}

/* ===== MANFICIENT ABOUT SECTION REFRESH ===== */
.about-brand-alt {
  padding: 12rem 1.5rem;
  background-color: var(--bg); /* Using your existing off-white */
  background-image: radial-gradient(circle at top right, rgba(165, 202, 141, 0.05), transparent); /* Subtle hint of your sage green */
  text-align: center;
  border-top: 1px solid var(--border);
  overflow: hidden;
}

.about-inner {
  max-width: 800px;
  margin: 0 auto;
}

.display-title {
  font-family: var(--sans);
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--fg);
  margin-bottom: 2.5rem;
}

.text-gradient {
  /* Metallic effect using your Charcoal color */
  background: linear-gradient(180deg, var(--fg) 30%, #666 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.lead-text {
  font-family: var(--sans);
  font-size: 1.25rem;
  line-height: 1.6;
  color: var(--fg);
  max-width: 600px;
  margin: 0 auto 1.5rem;
}

.highlight-serif {
  font-family: var(--serif); /* Uses your Cormorant font */
  font-size: clamp(2.2rem, 4vw, 2.75rem);
  font-style: italic;
  font-weight: 500;
  color: var(--fg);
  margin: 2.5rem 0;
  position: relative;
  display: inline-block;
}

.highlight-serif::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--primary); /* Accent line in sage green */
  opacity: 0.4;
}

.about-manifesto {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  margin-bottom: 4rem;
}

.manifesto-item {
  font-family: var(--sans);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.15em;
  color: var(--muted-fg);
}

.about-manifesto .dot {
  width: 5px;
  height: 5px;
  background: var(--primary);
  border-radius: 50%;
  opacity: 0.6;
}

.about-manifesto .win {
  color: var(--fg);
}

/* Customizing the Button for this section */
.about-btn {
  padding: 1.25rem 3.5rem !important;
  background-color: #172C3D; !important;
  border-radius: 50px !important; /* The "Masculine" square look you requested */
  gap: 12px;
}

.about-btn svg {
  transition: transform 0.3s ease;
}

.about-btn:hover svg {
  transform: translateX(5px);
}

@media (max-width: 768px) {
  /* 1. Spacing the wrapper */
  .about-cta-wrap {
    margin-top: 4rem; /* Significant gap from the Manifesto card */
    padding: 0 1rem; /* Prevents button from touching screen edges */
    display: flex;
    justify-content: center;
  }

  /* 2. The Button Styling */
  .about-btn {
    width: 100%;
    max-width: 320px; /* Matches the visual width of your manifesto card */
    display: flex !important;
    justify-content: space-between !important; /* Pushes text left and arrow right */
    align-items: center;
    padding: 1.25rem 1.5rem !important;
    font-size: 0.8rem !important;
    letter-spacing: 0.1em;
    border-radius: 50px !important; /* Slightly rounded for better mobile ergonomics */
    background-color: #172C3D; !important;
    box-shadow: 0 12px 24px rgba(0,0,0,0.12); /* Subtle lift */
  }

  /* 3. The Arrow Icon */
  .about-btn svg {
    margin-left: 0; /* Removed hardcoded margin */
    width: 18px;
    height: 18px;
    opacity: 0.8;
  }
}

/* Mobile Responsive Adjustments */
@media (max-width: 768px) {
  .about-brand-alt { padding: 8rem 1.25rem; }
  
  .about-manifesto {
    flex-direction: column;
    gap: 2.25rem;
    background: #B0AD96; 
    padding: 1.5rem;
    border-radius: 12px;
    border: 1px solid var(--border);
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 2rem;
  }
  
  .about-manifesto .dot {
    display: none;
  }
}

/* ===== PREMIUM DYNAMIC CARDS (Orders, Addresses, Skin) ===== */
.order-card, .addr-card, .skin-option { 
    background: var(--card); 
    border: 1px solid var(--border); 
    border-radius: 16px; 
    padding: 16px; 
    display: flex; 
    align-items: center; 
    gap: 16px; 
    margin-bottom: 12px; 
    transition: border-color 0.2s, box-shadow 0.2s; 
}

/* Order Specifics */
.product-thumb { 
    width: 56px; 
    height: 56px; 
    background: #172C3D; 
    border-radius: 12px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    font-size: 24px; 
    flex-shrink: 0; 
    overflow: hidden; 
}
.product-thumb img { width: 100%; height: 100%; object-fit: contain; }

.order-info, .addr-details, .skin-meta { flex: 1; min-width: 0; }
.order-info .p-title, .addr-details .a-title, .skin-meta h4 { 
    font-family: var(--sans); 
    font-weight: 700; 
    font-size: 14px; 
    margin-bottom: 2px; 
    color: var(--fg); 
}
.order-info .p-qty, .addr-details .a-text, .skin-meta p { 
    font-family: var(--sans); 
    font-size: 12px; 
    color: var(--muted-fg); 
    line-height: 1.5; 
}
.order-info .p-price { 
    font-family: var(--serif); 
    font-weight: 800; 
    color: var(--fg); 
    font-size: 15px; 
    margin-top: 2px; 
}
.order-info .p-id { 
    font-family: var(--sans); 
    font-size: 10px; 
    color: var(--muted-fg); 
    margin-top: 4px; 
    overflow: hidden; 
    text-overflow: ellipsis; 
    white-space: nowrap; 
}

.btn-buy-again { 
    font-family: var(--sans); 
    padding: 8px 14px; 
    background: var(--sage-muted); 
    border: 1px solid var(--border); 
    border-radius: 8px; 
    font-weight: 700; 
    font-size: 12px; 
    color: var(--fg); 
    cursor: pointer; 
    flex-shrink: 0; 
    transition: all 0.2s; 
    text-transform: uppercase; 
    letter-spacing: 0.5px; 
}
.btn-buy-again:hover { 
    border-color: var(--fg); 
    background: var(--bg); 
}

/* Address Specifics */
.addr-card.selected { 
    border-color: var(--fg); 
    background: var(--card); 
    box-shadow: 0 4px 12px rgba(0,0,0,0.05); 
}
.addr-icon-box { 
    width: 44px; 
    height: 44px; 
    background: var(--fg); 
    color: var(--bg); 
    border-radius: 12px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    flex-shrink: 0; 
}
.addr-icon-box svg { width: 20px; height: 20px; }

/* Skin Specifics */
.skin-option { cursor: pointer; }
.skin-option:hover { border-color: var(--border); background: var(--sage-muted); }
.skin-option.active, .skin-option.selected { 
    border-color: var(--primary); 
    background: var(--card); 
    box-shadow: 0 4px 12px rgba(0,0,0,0.05); 
}
.check-mark { 
    width: 24px; 
    height: 24px; 
    border: 2px solid var(--border); 
    border-radius: 50%; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: transparent; 
    flex-shrink: 0; 
    transition: all 0.2s; 
}
.active .check-mark, .selected .check-mark { 
    background: var(--primary); 
    border-color: var(--primary); 
    color: var(--bg); 
}
.check-mark svg { width: 14px; height: 14px; }