/* ═══════════════════════════════════════════════════════════
   DESIGN TOKENS — Warm Organic Editorial
═══════════════════════════════════════════════════════════ */
:root {
  --bg          : #FAF7F2;
  --bg-2        : #F3EDE3;
  --bg-3        : #E9E0D3;
  --bg-card     : #FFFFFF;
  --ink-1       : #1C1712;
  --ink-2       : #4A4035;
  --ink-3       : #8C7B6B;
  --ink-4       : #C0B0A0;
  --green       : #1A3C34;
  --green-2     : #2D6B5E;
  --green-3     : #4A9E8A;
  --green-dim   : rgba(26,60,52,.08);
  --green-glow  : rgba(26,60,52,.20);
  --terra       : #C5603A;
  --terra-2     : #D4754F;
  --terra-dim   : rgba(197,96,58,.10);
  --terra-glow  : rgba(197,96,58,.22);
  --warn        : #D97706;
  --warn-dim    : rgba(217,119,6,.10);
  --r-xs        : 6px;
  --r-sm        : 10px;
  --r-md        : 16px;
  --r-lg        : 22px;
  --r-xl        : 28px;
  --sh-sm       : 0 1px 4px rgba(28,23,18,.06), 0 2px 12px rgba(28,23,18,.04);
  --sh-md       : 0 4px 20px rgba(28,23,18,.10), 0 1px 4px rgba(28,23,18,.05);
  --sh-lg       : 0 12px 48px rgba(28,23,18,.14);
  --sh-sheet    : 0 -8px 48px rgba(28,23,18,.18);
  --nav-h       : 60px;
  --safe-bot    : env(safe-area-inset-bottom, 0px);
  --font-d      : 'Playfair Display', Georgia, serif;
  --font-b      : 'Outfit', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}
body{
  font-family:var(--font-b);
  background:var(--bg);
  color:var(--ink-1);
  min-height:100dvh;
  font-size:14px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.022'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img,svg{display:block}
input,textarea,select{font-family:inherit}

/* ═══ TOPBAR ═══════════════════════════════════════════════ */
.topbar{
  position:sticky;top:0;z-index:100;
  height:56px;
  background:rgba(250,247,242,.92);
  border-bottom:1px solid var(--bg-3);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  display:flex;align-items:center;
  padding:0 20px;gap:10px;
}
.topbar-brand{
  flex:1;
  font-family:var(--font-d);
  font-size:18px;font-weight:900;
  color:var(--green);letter-spacing:-.4px;
}
.topbar-brand em{font-style:normal;color:var(--terra)}
.topbar-links{display:flex;gap:4px}
@media(max-width:560px){.topbar-links .hide-xs{display:none}}

/* ═══ BUTTONS ═════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:9px 16px;border-radius:var(--r-sm);
  font-family:var(--font-b);font-size:13px;font-weight:600;
  border:1.5px solid transparent;cursor:pointer;white-space:nowrap;
  transition:all .18s ease;text-decoration:none;
  -webkit-user-select:none;user-select:none;
}
@media (max-width: 580px) {
  .btn {
    font-size: 12px;
    padding: 7px 10px;
  }

  .btn-xs {
    font-size: 11px;
  }
}
.btn:focus-visible{outline:2px solid var(--green);outline-offset:3px}
.btn:disabled{opacity:.45;pointer-events:none}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-xs{padding:5px 11px;font-size:11px;border-radius:var(--r-xs)}
.btn-full{width:100%;justify-content:center}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn-primary:hover{background:var(--green-2);border-color:var(--green-2);transform:translateY(-1px);box-shadow:0 4px 14px var(--green-glow)}
.btn-ghost{background:transparent;color:var(--ink-2);border-color:var(--bg-3)}
.btn-ghost:hover{border-color:var(--ink-3);color:var(--ink-1);background:var(--bg-2)}
.btn-terra{background:var(--terra);color:#fff;border-color:var(--terra)}
.btn-terra:hover{background:var(--terra-2);transform:translateY(-1px);box-shadow:0 4px 14px var(--terra-glow)}
.btn-success{background:rgba(45,107,94,.10);color:var(--green-2);border-color:rgba(45,107,94,.20)}
.btn-success:hover{background:var(--green-2);color:#fff;border-color:var(--green-2)}
.btn-danger{background:var(--terra-dim);color:var(--terra);border-color:rgba(197,96,58,.20)}
.btn-danger:hover{background:var(--terra);color:#fff;border-color:var(--terra)}

/* ═══ PAGE LAYOUT ══════════════════════════════════════════ */
.pg{
  max-width:1100px;margin:0 auto;
  padding:28px 18px calc(var(--nav-h) + var(--safe-bot) + 24px);
}
.page-eyebrow{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--terra);margin-bottom:6px;
}
.page-headline{
  font-family:var(--font-d);
  font-size:clamp(24px,4vw,36px);font-weight:900;
  color:var(--green);letter-spacing:-.5px;line-height:1.1;
  margin-bottom:28px;
}
.page-headline span{font-style:italic;font-weight:700;color:var(--ink-3)}

/* banner */
.banner{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:var(--r-md);
  margin-bottom:24px;border:1.5px solid;
  animation:fade-up .4s ease;
}
.banner-success{background:rgba(45,107,94,.08);border-color:rgba(45,107,94,.22)}
.banner-icon{font-size:22px;flex-shrink:0}
.banner-body{flex:1}
.banner-body strong{display:block;font-weight:700;color:var(--green-2);font-size:14px}
.banner-body span{font-size:12px;color:var(--ink-3)}

/* grid */
.layout{
  display:grid;
  grid-template-columns:284px 1fr;
  gap:24px;align-items:start;
}
@media(max-width:820px){.layout{grid-template-columns:1fr}}

/* ═══ SIDEBAR / PROFILE ════════════════════════════════════ */
.sidebar{position:sticky;top:68px}
.profile-card{
  background:var(--bg-card);
  border-radius:var(--r-lg);
  border:1.5px solid var(--bg-3);
  box-shadow:var(--sh-sm);
  overflow:hidden;
}
/* decorative stripe — the unforgettable detail */
.profile-strip{
  height:5px;
  background:repeating-linear-gradient(
    90deg,
    var(--green) 0,var(--green) 28px,
    var(--terra) 28px,var(--terra) 32px,
    var(--bg-3) 32px,var(--bg-3) 38px
  );
}
.profile-inner{padding:22px 22px 0}
.avatar-row{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.avatar{
  width:56px;height:56px;border-radius:50%;
  background:var(--green);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-d);font-size:18px;font-weight:900;
  flex-shrink:0;letter-spacing:-.5px;
  box-shadow:0 0 0 4px var(--green-dim);
}
.profile-name{
  font-family:var(--font-d);font-size:17px;font-weight:700;
  color:var(--ink-1);margin-bottom:4px;word-break:break-word;
}
.meta-line{font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:5px}
.meta-ico{font-size:11px;opacity:.7}

/* stat chips */
.stat-row{display:flex;gap:8px;margin-bottom:20px}
.stat-chip{
  flex:1;background:var(--bg-2);border-radius:var(--r-sm);
  padding:10px 12px;text-align:center;
}
.stat-n{
  font-family:var(--font-d);font-size:22px;font-weight:900;
  color:var(--green);line-height:1;
}
.stat-l{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-3);margin-top:3px}
.order-card {
  border-radius: 12px;
}

/* New structure */
.oc-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.oc-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.oc-time {
  font-size: 12px;
  color: var(--ink-3);
}

.oc-right {
  text-align: right;
}

.oc-amount {
  font-size: 15px;
  font-weight: 800;
}

.oc-status {
  margin-top: 4px;
}

/* Strong CTA */
.pay-cta {
  width: 100%;
  margin-top: 10px;
  padding: 10px;
  border-radius: 10px;
  background: var(--terra);
  color: #fff;
  border: none;
  font-weight: 700;
  font-size: 13px;
}

.pay-cta:active {
  opacity: 0.85;
}
/* address preview */
.addr-preview{
  background:var(--bg-2);
  border-top:1.5px solid var(--bg-3);
  padding:14px 22px;
}
.addr-preview-lbl{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;color:var(--terra);margin-bottom:6px;
}
.addr-preview-text{font-size:12px;color:var(--ink-2);line-height:1.5}

/* actions */
.profile-acts{display:flex;gap:8px;padding:14px 22px 20px}

/* ═══ ORDERS ═══════════════════════════════════════════════ */
.sec-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.sec-title{font-family:var(--font-d);font-size:20px;font-weight:700;color:var(--ink-1);letter-spacing:-.3px}
.sec-chip{
  background:var(--bg-3);border-radius:99px;padding:2px 10px;
  font-size:11px;font-weight:700;color:var(--ink-3);
}
.empty-state{
  background:var(--bg-card);border:1.5px dashed var(--bg-3);
  border-radius:var(--r-lg);padding:52px 24px;text-align:center;
}
.empty-state .emo{font-size:44px;margin-bottom:14px}
.empty-state p{font-size:15px;color:var(--ink-3);margin-bottom:20px}

.orders-list{display:flex;flex-direction:column;gap:10px}

.order-card{
  background:var(--bg-card);
  border:1.5px solid var(--bg-3);
  border-left:4px solid var(--bg-3);
  border-radius:var(--r-md);
  padding:18px 20px;cursor:pointer;
  position:relative;overflow:hidden;
  transition:border-color .2s,box-shadow .2s,transform .2s;
  animation:fade-up .3s ease both;
}
.order-card:hover{
  border-color:var(--bg-3);
  border-left-color:var(--green);
  box-shadow:var(--sh-md);
  transform:translateX(2px);
}
.order-card:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.order-card.pmt-pending{border-left-color:var(--terra)}
.order-card.is-live{border-left-color:var(--green-3)}
/* stagger */
.order-card:nth-child(1){animation-delay:.03s}
.order-card:nth-child(2){animation-delay:.07s}
.order-card:nth-child(3){animation-delay:.11s}
.order-card:nth-child(4){animation-delay:.15s}
.order-card:nth-child(5){animation-delay:.19s}
.order-card:nth-child(n+6){animation-delay:.22s}

.oc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.oc-sno{font-family:var(--font-d);font-size:15px;font-weight:700;color:var(--ink-1);margin-bottom:3px}
.oc-meta{font-size:12px;color:var(--ink-3)}
.oc-amount{font-family:var(--font-d);font-size:17px;font-weight:900;color:var(--green);text-align:right;white-space:nowrap}
.oc-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}

.pay-strip{
  margin:12px -20px -18px;padding:10px 20px;
  background:var(--terra-dim);border-top:1px solid rgba(197,96,58,.15);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.pay-strip-msg{font-size:12px;color:var(--terra);font-weight:500}

/* badges */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:99px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
}
.badge::before{content:'';display:block;width:5px;height:5px;border-radius:50%;flex-shrink:0}
.badge-pending{background:var(--warn-dim);color:var(--warn)}
.badge-pending::before{background:var(--warn)}
.badge-live{background:rgba(45,107,94,.10);color:var(--green-2)}
.badge-live::before{background:var(--green-3);animation:blink 1.4s ease-in-out infinite}
.badge-done{background:rgba(140,123,107,.10);color:var(--ink-3)}
.badge-done::before{background:var(--ink-4)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

/* ═══ ORDER DETAIL ══════════════════════════════════════════ */
.detail-card{
  background:var(--bg-card);border:1.5px solid var(--bg-3);
  border-radius:var(--r-lg);overflow:hidden;
  margin-top:20px;box-shadow:var(--sh-sm);
  animation:fade-up .35s ease;
}
.dc-header{
  padding:22px 24px;border-bottom:1.5px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;align-items:flex-start;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-2) 100%);
  color:#fff;
}
.dc-id{font-family:var(--font-d);font-size:18px;font-weight:900;letter-spacing:-.3px;margin-bottom:4px}
.dc-meta{font-size:12px;opacity:.7}
.dc-amount{font-family:var(--font-d);font-size:24px;font-weight:900;text-align:right;line-height:1}
.dc-status-lbl{font-size:12px;opacity:.75;text-align:right;margin-top:4px;font-style:italic}
.dc-progress{padding:20px 24px;border-bottom:1.5px solid var(--bg-3)}
.dc-stage-lbl{font-family:var(--font-d);font-style:italic;font-size:13px;font-weight:700;color:var(--green);margin-bottom:12px}
.progress-track{
  height:4px;background:var(--bg-3);border-radius:99px;
  overflow:visible;position:relative;margin-bottom:12px;
}
.progress-fill{
  height:100%;
  background:linear-gradient(90deg,var(--green) 0%,var(--green-3) 100%);
  border-radius:99px;position:relative;
  transition:width .7s cubic-bezier(.4,0,.2,1);
}
.progress-fill::after{
  content:'';position:absolute;right:-4px;top:-4px;
  width:12px;height:12px;background:var(--green);border-radius:50%;
  border:2px solid var(--bg-card);box-shadow:0 0 0 2px var(--green-dim);
}
.progress-steps{
  display:flex;justify-content:space-between;
  font-size:10px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.5px;font-weight:600;
}
.dc-items{padding:16px 24px}
.item-row{
  align-items:center;gap:12px;
  padding:9px 0;border-bottom:1px solid var(--bg-2);
}
@media (max-width: 580px) {

  .item-row {
    flex-wrap: wrap;
    gap: 6px;
  }

  .item-name {
    width: 100%;
  }

  .item-price {
    margin-left: auto;
  }
}
.item-row:last-child{border-bottom:none}
.item-dot{width:6px;height:6px;border-radius:50%;background:var(--terra);flex-shrink:0}
.item-name{flex:1;font-size:14px;color:var(--ink-1)}
.item-qty{font-size:12px;color:var(--ink-3);font-weight:600;white-space:nowrap}
.item-price{font-weight:700;font-size:14px;color:var(--ink-1);white-space:nowrap}
.dc-summary{padding:16px 24px;background:var(--bg-2);border-top:1.5px solid var(--bg-3)}
.sum-row{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-3);padding:3px 0}
.sum-row.grand{
  font-family:var(--font-d);font-size:16px;font-weight:900;color:var(--green);
  padding-top:10px;margin-top:8px;border-top:1.5px solid var(--bg-3);
}

/* ═══ BOTTOM NAV ═══════════════════════════════════════════ */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;
  padding-bottom:var(--safe-bot);
  background:rgba(250,247,242,.95);border-top:1.5px solid var(--bg-3);
  display:flex;align-items:stretch;z-index:90;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.bnav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;padding:6px 0;font-size:9px;font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;color:var(--ink-4);transition:color .18s;text-decoration:none;position:relative;
}
.bnav-item:hover,.bnav-item.active{color:var(--green)}
.bnav-item.active::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:24px;height:2.5px;background:var(--green);border-radius:0 0 3px 3px;
}
.bnav-ico{font-size:19px;line-height:1}

/* Mobile = bottom sheet, Desktop = modal */
/* =========================
   RESPONSIVE SHEET BEHAVIOR
========================= */
@media (min-width: 768px) {

  .sheet-overlay.responsive {
    align-items: center !important;
    justify-content: center !important;
  }

  .sheet-overlay.responsive .sheet {
    border-radius: 16px !important;
    max-width: 480px;
    width: 92%;
    max-height: 85vh;
    border-bottom: 1.5px solid var(--bg-3) !important;
    animation: fade-up .25s ease !important;
  }
}
/* ═══ SHEETS ═══════════════════════════════════════════════ */
.sheet-overlay{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(28,23,18,.52);
  align-items:flex-end;justify-content:center;
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
}
.sheet-overlay.open{display:flex;animation:fade-bg .22s ease}
.sheet{
  background:var(--bg-card);border:1.5px solid var(--bg-3);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  width:100%;max-width:560px;max-height:90dvh;overflow-y:auto;
  padding-bottom:calc(20px + var(--safe-bot));
  box-shadow:var(--sh-sheet);
  animation:sheet-up .28s cubic-bezier(.25,.9,.25,1);
}
.sheet-knob{width:36px;height:4px;background:var(--bg-3);border-radius:2px;margin:14px auto 0}
.sheet-title{
  font-family:var(--font-d);font-size:19px;font-weight:700;
  color:var(--ink-1);padding:18px 22px 16px;letter-spacing:-.3px;
}
.field{padding:0 22px;margin-bottom:16px}
.field-lbl{
  display:block;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;color:var(--ink-3);margin-bottom:7px;
}
.field-inp{
  width:100%;padding:11px 14px;
  background:var(--bg-2);border:1.5px solid var(--bg-3);
  border-radius:var(--r-sm);color:var(--ink-1);outline:none;
  transition:border-color .18s,box-shadow .18s;resize:vertical;font-size:14px;
}
.field-inp:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-dim);background:var(--bg-card)}
.field-inp::placeholder{color:var(--ink-4)}
.sheet-hr{border:none;border-top:1.5px solid var(--bg-3);margin:4px 0}
.sheet-foot{
  display:flex;gap:8px;justify-content:flex-end;
  padding:16px 22px 0;border-top:1.5px solid var(--bg-2);margin-top:8px;
}
.check-row{
  display:flex;align-items:center;gap:10px;
  padding:0 22px;margin-bottom:16px;
  font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;
}
.check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--green);cursor:pointer}

/* address items in sheet */
.addr-item{
  background:var(--bg-2);border:1.5px solid var(--bg-3);
  border-left:4px solid var(--bg-3);border-radius:var(--r-md);
  padding:14px 16px;margin:0 22px 10px;
  transition:border-color .2s;
}
.addr-item.is-def{border-left-color:var(--green)}
.addr-head{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px;color:var(--ink-1);margin-bottom:5px}
.def-tag{
  background:var(--green-dim);color:var(--green);
  border-radius:4px;padding:1px 7px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;
}
.addr-body{font-size:12px;color:var(--ink-3);line-height:1.4}
.addr-acts{display:flex;gap:7px;margin-top:10px}

/* ═══ TOAST ════════════════════════════════════════════════ */
#ou-toast{
  position:fixed;bottom:calc(var(--nav-h) + var(--safe-bot) + 14px);
  left:50%;transform:translateX(-50%) translateY(16px);
  background:var(--ink-1);color:#fff;border-radius:var(--r-md);
  padding:12px 22px;font-size:13px;font-weight:500;
  box-shadow:var(--sh-lg);z-index:300;
  opacity:0;pointer-events:none;
  transition:opacity .22s,transform .28s cubic-bezier(.25,.9,.25,1);
  white-space:nowrap;max-width:calc(100vw - 32px);
}
#ou-toast.show{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
#ou-toast.t-success{background:var(--green)}
#ou-toast.t-error{background:var(--terra)}
#ou-toast.t-info{background:var(--ink-2)}

/* ═══ ANIMATIONS ═══════════════════════════════════════════ */
@keyframes fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fade-bg{from{opacity:0}to{opacity:1}}
@keyframes sheet-up{from{transform:translateY(100%)}to{transform:none}}

/* ═══ RESPONSIVE ═══════════════════════════════════════════ */
@media(max-width:580px){
  .pg{padding-left:14px;padding-right:14px}
  .dc-header,.dc-items,.dc-progress,.dc-summary{padding:14px 18px}
  .oc-amount{font-size:15px}
}

@media (max-width: 820px) {

  .layout {
    display: block;
  }

  .sidebar {
    position: relative;
    top: 0;
    margin-bottom: 16px;
  }

  .profile-card {
    border-radius: 14px;
  }

  .pg {
    padding: 16px 12px calc(var(--nav-h) + 20px);
  }
}
@media (max-width: 580px) {

.order-card {
  padding: 12px 14px !important;
  border-radius: 12px;
}

.oc-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.oc-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.oc-time {
  font-size: 12px;
  color: var(--ink-3);
}

.oc-right {
  text-align: right;
}

.oc-amount {
  font-size: 15px;
  font-weight: 800;
}

.oc-status {
  margin-top: 4px;
}

.pay-cta {
  width: 100%;
  margin-top: 10px;
  padding: 10px;
  border-radius: 10px;
  background: var(--terra);
  color: #fff;
  border: none;
  font-weight: 700;
  font-size: 13px;
}
@media (max-width: 580px) {

  .dc-header {
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
  }

  .dc-amount {
    font-size: 20px;
    text-align: left;
  }

  .dc-status-lbl {
    text-align: left;
  }
}
@media (max-width: 580px) {

  .dc-header {
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
  }

  .dc-amount {
    font-size: 20px;
    text-align: left;
  }

  .dc-status-lbl {
    text-align: left;
  }
}
.back-link {
  text-decoration: none;
  color: var(--terra);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.back-link:active {
  opacity: 0.7;
}
@media (max-width: 580px) {
  .page-eyebrow {
    position: sticky;
    top: 56px;
  background: var(--bg);
  z-index: 10;
    padding: 8px 0; 
  }
}
:root {
    --nav-height: 64px;
}


/* NAV */



/* BADGE */
.badge {
    position: absolute;
    top: 2px;
    right: 18%;
    background: red;
    color: #fff;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 20px;
}

/* iPhone safe area */
@supports (padding: max(0px)) {
    .bottom-nav {
        padding-bottom: max(env(safe-area-inset-bottom), 6px);
        height: calc(var(--nav-height) + env(safe-area-inset-bottom));
    }
}

/* Desktop centered */
@media (min-width: 768px) {
    .bottom-nav {
        max-width: 480px;
        margin: 0 auto;
        border-radius: 16px 16px 0 0;
    }

    body {
        padding-bottom: 80px;
    }
}

.app-footer {
  background: #111;
  color: #ccc;
  padding: 20px 16px 80px; /* bottom space for nav */
  font-size: 13px;
}

/* =========================
   CONTAINER
========================= */
.footer-container {
  max-width: 1100px;
  margin: 0 auto;
}

/* =========================
   BRAND
========================= */
.footer-brand {
  text-align: center;
  margin-bottom: 20px;
}

.footer-brand img {
  max-width: 120px;
  margin-bottom: 10px;
}

.footer-desc {
  font-size: 12px;
  color: #aaa;
}

/* =========================
   LINKS
========================= */
.footer-links {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.footer-col {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.footer-title {
  font-weight: 600;
  color: #fff;
  margin-bottom: 4px;
}

.footer-col a {
  color: #bbb;
  text-decoration: none;
  font-size: 13px;
}

.footer-col a:active {
  opacity: 0.6;
}

/* =========================
   BOTTOM
========================= */
.footer-bottom {
  margin-top: 20px;
  text-align: center;
  font-size: 12px;
  color: #777;
}
/* =========================
   FULL PAGE FIX
========================= */
html, body {
  height: 100%;
  margin: 0;
}

.page-wrapper {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* MAIN CONTENT EXPANDS */
.page-content {
  flex: 1;
}

/* FOOTER ALWAYS AT BOTTOM */
.app-footer {
  margin-top: auto;
}

.page-content {
  padding-bottom: calc(var(--nav-h) + 10px);
}
/* =========================
   DESKTOP UPGRADE
========================= */
@media (min-width: 768px) {

  .footer-container {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 40px;
  }

  .footer-brand {
    text-align: left;
  }

  .footer-links {
    flex-direction: row;
    justify-content: space-between;
  }

}

