@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500&family=JetBrains+Mono:wght@300;400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#ffffff;
  --bg-surface:#f5f5f5;
  --bg-elevated:#fff;
  --bg-card:#fff;
  --bg-card-hover:#fafafa;

  --text:#2a2825;
  --text-mid:#6b6762;
  --text-faint:#a09c96;
  --text-on-card:#2a2825;
  --text-on-card-mid:#6b6762;
  --text-on-card-faint:#a09c96;

  --accent:#5b8a7d;
  --accent-hover:#4a7c6f;
  --accent-soft:rgba(91,138,125,.08);
  --accent-border:rgba(91,138,125,.25);
  --accent-text:#4a7c6f;
  --gold:#b8944a;
  --gold-soft:rgba(184,148,74,.08);

  /* Product-specific accent colors (saturated for contrast on #f7f5f2 bg) */
  --color-dhp:#8b5fbf;
  --color-dhp-soft:rgba(139,95,191,.08);
  --color-dhp-bg:#ece0f5;
  --color-preg:#2d7a9e;
  --color-preg-soft:rgba(45,122,158,.08);
  --color-preg-bg:#dceef5;
  --color-prog:#b8862e;
  --color-prog-soft:rgba(184,134,46,.08);
  --color-prog-bg:#f2e8d4;
  --color-allop:#5b8abf;
  --color-allop-soft:rgba(91,138,191,.08);
  --color-allop-bg:#dce8f5;
  --color-andro:#4a8a5e;
  --color-andro-soft:rgba(74,138,94,.08);
  --color-andro-bg:#daf0e0;
  --color-fen:#b06868;
  --color-fen-soft:rgba(176,104,104,.08);
  --color-fen-bg:#f2dede;

  --rule:rgba(0,0,0,.07);
  --rule-strong:rgba(0,0,0,.12);
  --rule-card:#eaeaea;

  --font-head:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono','DM Mono',monospace;

  --max-w:980px;
  --pad:48px;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:14px;font-weight:400;line-height:1.65;-webkit-font-smoothing:antialiased}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:center;height:56px}
.nav-inner{width:100%;max-width:var(--max-w);padding:0 var(--pad);display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--font-head);font-size:16px;font-weight:500;letter-spacing:.02em;color:var(--text);text-decoration:none;display:flex;align-items:center;gap:6px}
.nav-logo .dot{color:var(--accent);font-size:20px;line-height:1}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{color:var(--text-mid);text-decoration:none;font-size:12px;font-weight:500;transition:color .15s}
.nav-links a:hover{color:var(--text)}
.nav-links .nav-tech{color:var(--accent-text)}
.nav-links .nav-tech:hover{color:var(--accent-hover)}
.cart-btn{display:flex;align-items:center;gap:8px;background:var(--accent);color:#fff;border:none;padding:8px 18px;border-radius:6px;cursor:pointer;font-family:var(--font-body);font-size:12px;font-weight:600;transition:background .15s}
.cart-btn:hover{background:var(--accent-hover)}
.cart-count{background:rgba(255,255,255,.25);color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.cart-count.hidden{display:none}

/* ── FOOTER ── */
footer{border-top:1px solid var(--rule);display:flex;justify-content:center}
.footer-inner{width:100%;max-width:var(--max-w);padding:40px var(--pad);display:flex;justify-content:space-between;align-items:center}
.footer-logo{font-family:var(--font-head);font-size:14px;font-weight:400;color:var(--text-mid)}
.footer-links{display:flex;gap:24px;list-style:none}
.footer-links a{color:var(--text-faint);text-decoration:none;font-size:12px;transition:color .15s}
.footer-links a:hover{color:var(--text-mid)}
.footer-copy{font-size:11px;color:var(--text-faint)}

/* ── BADGE (light bg) ── */
.badge{font-size:11px;font-weight:500;padding:5px 12px;border:1px solid var(--rule-strong);color:var(--text-mid);border-radius:4px;background:var(--bg-elevated)}
.badge-green{border-color:var(--accent-border);color:var(--accent-text);background:var(--accent-soft)}
/* Badge on cards */
.badge-card{font-size:11px;font-weight:500;padding:4px 10px;border:1px solid var(--rule-card);color:var(--text-on-card-mid);border-radius:4px}
.badge-card-green{border-color:rgba(91,138,125,.3);color:#4a7c6f;background:rgba(91,138,125,.06)}

/* ── ACCENT DIVIDER ── */
.accent-line{height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.15;border:none;margin:0}

/* ── CART DRAWER ── */
.drawer-backdrop{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.25)}
.drawer-backdrop.open{display:block}
.drawer{position:fixed;top:0;right:0;bottom:0;z-index:301;width:420px;background:var(--bg-elevated);border-left:1px solid var(--rule);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.08)}
.drawer.open{transform:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:22px 28px;border-bottom:1px solid var(--rule)}
.drawer-title{font-family:var(--font-head);font-size:20px;font-weight:500}
.drawer-close{background:none;border:none;cursor:pointer;font-size:20px;color:var(--text-faint);padding:4px 8px;line-height:1}
.drawer-items{flex:1;overflow-y:auto;padding:20px 28px}
.cart-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--rule)}
.ci-name{font-family:var(--font-head);font-size:15px;font-weight:500}
.ci-sub{font-size:11px;color:var(--text-faint);margin-top:2px}
.ci-right{display:flex;align-items:center;gap:14px}
.ci-price{font-family:var(--font-head);font-size:16px;font-weight:500}
.ci-remove{background:none;border:none;cursor:pointer;color:var(--text-faint);font-size:14px;padding:2px 4px;transition:color .15s}
.ci-remove:hover{color:#e05252}
.cart-empty{text-align:center;padding:60px 20px;color:var(--text-faint);font-size:13px}
.drawer-foot{padding:20px 28px;border-top:1px solid var(--rule)}
.cart-subtotal{display:flex;justify-content:space-between;padding:10px 0 18px;font-size:12px}
.cart-subtotal strong{font-family:var(--font-head);font-size:18px;font-weight:600}
.checkout-btn{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}
.checkout-btn:hover{background:var(--accent-hover)}
.checkout-btn:disabled{opacity:.4;cursor:default}

/* ── CHECKOUT MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.3);align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.checkout-modal{background:var(--bg-elevated);border:1px solid var(--rule-strong);border-radius:10px;width:100%;max-width:860px;max-height:90vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;animation:fadeUp .22s ease;box-shadow:0 20px 60px rgba(0,0,0,.1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.co-left{padding:40px 36px;border-right:1px solid var(--rule)}
.co-right{padding:40px 36px}
.co-title{font-family:var(--font-head);font-size:22px;font-weight:500;margin-bottom:4px}
.co-sub{font-size:12px;color:var(--text-faint);margin-bottom:28px}
.co-summary-item{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--rule);font-size:12px}
.co-summary-item:last-child{border-bottom:none}
.co-si-name{font-family:var(--font-head);font-size:14px;font-weight:500}
.co-si-sub{font-size:11px;color:var(--text-faint)}
.co-totals{margin-top:20px;padding-top:16px;border-top:2px solid var(--rule-strong)}
.co-total-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-mid);margin-bottom:6px}
.co-total-row.grand{font-size:14px;color:var(--text);margin-top:10px;padding-top:10px;border-top:1px solid var(--rule)}
.co-total-row.grand span:last-child{font-family:var(--font-head);font-size:20px;font-weight:600}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.field-row.full{grid-template-columns:1fr}
.field-row.thirds{grid-template-columns:2fr 1fr 1fr}
.field-group{display:flex;flex-direction:column;gap:5px}
.field-label{font-size:11px;font-weight:500;color:var(--text-mid)}
.field-input{background:var(--bg);border:1px solid var(--rule-strong);border-radius:6px;padding:10px 12px;font-family:var(--font-body);font-size:13px;color:var(--text);outline:none;width:100%;transition:border-color .18s}
.field-input:focus{border-color:var(--accent)}
.field-input.invalid{border-color:#e05252}
.section-sep{font-size:11px;font-weight:500;color:var(--accent-text);margin:22px 0 14px}
.pay-btn{width:100%;margin-top:20px;padding:15px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;display:flex;align-items:center;justify-content:center;gap:10px}
.pay-btn:hover{background:var(--accent-hover)}
.pay-btn:disabled{opacity:.5;cursor:default}
.co-note{margin-top:14px;padding:12px 14px;background:#f5f5f5;border-radius:6px;font-size:11px;color:var(--text-mid);line-height:1.6;display:flex;align-items:flex-start;gap:8px}
.co-note svg{flex-shrink:0;margin-top:1px;color:var(--accent)}
.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
@keyframes spin{to{transform:rotate(360deg)}}
.modal-close-btn{position:absolute;top:14px;right:18px;background:none;border:none;font-size:22px;color:var(--text-faint);cursor:pointer;z-index:10}
.checkout-modal-wrap{position:relative;width:100%;max-width:860px}
.success-screen{display:none;flex-direction:column;align-items:center;justify-content:center;padding:48px 40px;text-align:center;grid-column:1/-1}
.success-icon{width:56px;height:56px;border:2px solid var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px;color:var(--accent)}
.success-title{font-family:var(--font-head);font-size:26px;font-weight:500;margin-bottom:6px}
.success-ref{font-size:14px;color:var(--text-mid);margin-bottom:24px}
.success-ref strong{color:var(--text);font-family:var(--font-mono);font-size:16px;letter-spacing:.05em}
.bank-details{width:100%;max-width:420px;text-align:left;background:#fafafa;border:1px solid var(--rule);border-radius:8px;padding:24px}
.bd-title{font-family:var(--font-head);font-size:14px;font-weight:600;margin-bottom:10px}
.bd-body{font-size:12px;color:var(--text-mid);line-height:1.7;margin-bottom:12px}
.bd-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:12px;margin-bottom:16px;padding:12px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.bd-k{color:var(--text-faint);font-size:11px}
.bd-v{color:var(--text);font-family:var(--font-mono);font-size:12px}
.bd-email{display:inline-block;font-size:13px;font-weight:500;color:var(--accent-text);margin-bottom:12px}
.bd-small{font-size:11px;color:var(--text-faint);line-height:1.6}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.reveal.visible{opacity:1;transform:none}

/* ── RESPONSIVE ── */
@media(max-width:900px){.checkout-modal{grid-template-columns:1fr}.co-left{border-right:none;border-bottom:1px solid var(--rule)}}
@media(max-width:768px){
  :root{--pad:20px}
  .nav-inner{padding:0 20px}.nav-links{display:none}
  .drawer{width:100%}
}

/* ── COOKIE BANNER ── */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;max-width:440px;background:var(--bg-elevated);border:1px solid var(--rule-strong);border-radius:8px;padding:24px;box-shadow:0 12px 32px rgba(0,0,0,.08);z-index:9000;display:none;flex-direction:column;gap:16px;animation:fadeUp .3s cubic-bezier(.16,1,.3,1)}
.cb-text{font-size:12px;color:var(--text-mid);line-height:1.6}
.cb-text strong{color:var(--text);display:block;margin-bottom:4px;font-size:14px;font-family:var(--font-head)}
.cb-btns{display:flex;gap:10px}
.cb-btn{flex:1;padding:10px;border-radius:6px;font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;border:none;transition:background .15s}
.cb-accept{background:var(--accent);color:#fff}
.cb-accept:hover{background:var(--accent-hover)}
.cb-reject{background:var(--bg-surface);color:var(--text);border:1px solid var(--rule)}
.cb-reject:hover{background:#ebebeb}

/* FOOTER UPDATE */
.footer-inner{flex-direction:column;align-items:flex-start;gap:20px}
.footer-row-top{width:100%;display:flex;justify-content:space-between;align-items:center}
.footer-row-bottom{width:100%;border-top:1px solid var(--rule);padding-top:16px}
@media(max-width:768px){
  .footer-row-top{flex-direction:column;gap:16px;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
  .footer-row-bottom{text-align:center}
}
