/* =========================================================
   ANNDAAN — design tokens
   ========================================================= */
:root{
  --paper:      #FBF1DE;
  --paper-dark: #F0E1BE;
  --ink:        #201A12;
  --ink-soft:   #55503f;
  --marigold:   #E8A93A;
  --marigold-dark:#C98A1E;
  --saag:       #2F5233;
  --saag-light: #E4EEE3;
  --brick:      #B84A3E;
  --brick-light:#F7E4E1;
  --line:       rgba(32,26,18,0.16);

  --font-display: 'Archivo Black', 'Work Sans', sans-serif;
  --font-body: 'Work Sans', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --radius: 14px;
  --radius-sm: 8px;
  --shadow: 0 6px 18px rgba(32,26,18,0.10);
  --shadow-lg: 0 16px 40px rgba(32,26,18,0.18);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
[hidden]{ display:none !important; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
button{font-family:inherit;cursor:pointer;}
input,select{font-family:inherit;font-size:1rem;}

.mono{font-family:var(--font-mono);}
.muted{color:var(--ink-soft);}
.small{font-size:0.85rem;}
.center{text-align:center;}

:focus-visible{outline:3px solid var(--brick);outline-offset:2px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}

/* =========================================================
   TYPE
   ========================================================= */
.eyebrow{
  font-family:var(--font-mono);
  font-size:0.78rem;
  letter-spacing:0.14em;
  color:var(--brick);
  font-weight:700;
  margin:0 0 10px;
}
.display{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5.6vw,4.4rem);
  line-height:1.02;
  margin:0 0 22px;
  letter-spacing:-0.01em;
}
.h2{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,3.4vw,2.4rem);
  line-height:1.1;
  margin:0 0 28px;
  max-width:20ch;
}

/* =========================================================
   LAYOUT SHELL
   ========================================================= */
.section{
  max-width:1180px;
  margin:0 auto;
  padding:80px 24px;
}
.section--alt{background:var(--paper-dark);}
.section--alt .section, .section--alt{padding-left:24px;padding-right:24px;}

/* =========================================================
   NAVBAR
   ========================================================= */
.navbar{
  position:sticky;top:0;z-index:50;
  background:rgba(251,241,222,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.navbar__inner{
  max-width:1180px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px;margin-right:auto;}
.brand__name{font-family:var(--font-display);font-size:1.25rem;}
.navlinks{display:flex;gap:22px;font-weight:600;font-size:0.95rem;}
.navlinks a{padding:6px 2px;border-bottom:2px solid transparent;}
.navlinks a.active{border-color:var(--brick);color:var(--brick);}
.navbar__actions{display:flex;align-items:center;gap:12px;position:relative;}
.hamburger{display:none;background:none;border:none;font-size:1.4rem;}

.bell{position:relative;background:none;border:none;font-size:1.2rem;padding:6px;}
.bell__dot{
  position:absolute;top:2px;right:2px;width:9px;height:9px;border-radius:50%;
  background:var(--brick);border:2px solid var(--paper);
}
.notif-panel{
  position:absolute;top:44px;right:120px;width:300px;max-height:360px;overflow:auto;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);
  z-index:60;
}
.notif-panel__head{font-weight:700;padding:12px 14px;border-bottom:1px solid var(--line);}
.notif-panel__list{padding:6px;}
.notif-item{padding:10px;border-radius:8px;font-size:0.88rem;}
.notif-item + .notif-item{margin-top:2px;}
.notif-item.unread{background:var(--brick-light);}
.notif-item time{display:block;color:var(--ink-soft);font-size:0.75rem;margin-top:3px;}

.user-chip{
  font-family:var(--font-mono);font-size:0.82rem;background:var(--saag-light);
  color:var(--saag);padding:6px 10px;border-radius:20px;font-weight:700;
}
.user-area{display:flex;align-items:center;gap:10px;}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 20px;border-radius:999px;font-weight:700;font-size:0.92rem;
  border:2px solid transparent;transition:transform .12s ease, background .15s ease;
  white-space:nowrap;
}
.btn:active{transform:scale(0.97);}
.btn--primary{background:var(--brick);color:#fff;}
.btn--primary:hover{background:#9c3e33;}
.btn--outline{background:transparent;border-color:var(--ink);color:var(--ink);}
.btn--outline:hover{background:var(--ink);color:var(--paper);}
.btn--ghost{background:var(--paper-dark);color:var(--ink);}
.btn--ghost:hover{background:var(--line);}
.btn--lg{padding:15px 28px;font-size:1rem;}
.btn--block{width:100%;}
.btn--sm{padding:7px 14px;font-size:0.8rem;}
.link{background:none;border:none;color:var(--brick);font-weight:700;text-decoration:underline;padding:0;}

/* =========================================================
   HERO
   ========================================================= */
.hero{padding:64px 24px 40px;}
.hero__grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1.15fr 0.85fr;gap:56px;align-items:center;
}
.hero__lede{font-size:1.08rem;color:var(--ink-soft);max-width:52ch;margin:0 0 28px;}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px;}
.hero__stats{display:flex;gap:36px;flex-wrap:wrap;}
.hero__stats strong{
  display:block;font-family:var(--font-mono);font-size:1.6rem;color:var(--saag);
}
.hero__stats span{font-size:0.82rem;color:var(--ink-soft);}

/* ---- signature ticket component ---- */
.hero__ticket-wrap{display:flex;justify-content:center;}
.ticket{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:22px 22px 0;width:100%;max-width:340px;position:relative;
  border:1px solid var(--line);
  transform:rotate(-2deg);
}
.ticket--demo{animation:ticketIn .6s ease both;}
@keyframes ticketIn{from{opacity:0;transform:rotate(-2deg) translateY(14px);}to{opacity:1;transform:rotate(-2deg) translateY(0);}}
.ticket__row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.ticket__tag{
  font-family:var(--font-mono);font-size:0.7rem;font-weight:700;letter-spacing:.06em;
  background:var(--marigold);color:var(--ink);padding:4px 9px;border-radius:5px;
}
.ticket__timer{font-size:1.1rem;font-weight:700;color:var(--brick);}
.ticket__item{font-family:var(--font-body);font-weight:700;font-size:1.15rem;margin:0 0 4px;}
.ticket__meta{color:var(--ink-soft);font-size:0.85rem;margin:0 0 14px;}
.ticket__price{display:flex;align-items:baseline;gap:10px;margin-bottom:18px;}
.ticket__price .strike{color:var(--ink-soft);text-decoration:line-through;font-size:0.95rem;}
.ticket__price .now{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--saag);}
.ticket__perf{
  height:0;border-top:2px dashed var(--line);margin:0 -22px;position:relative;
}
.ticket__perf::before,.ticket__perf::after{
  content:"";position:absolute;top:-9px;width:18px;height:18px;border-radius:50%;background:var(--paper);
}
.ticket__perf::before{left:-9px;}
.ticket__perf::after{right:-9px;}
.ticket__stub{
  display:flex;justify-content:space-between;font-size:0.75rem;color:var(--ink-soft);
  padding:12px 0;font-family:var(--font-mono);
}

/* =========================================================
   STATS ROW
   ========================================================= */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:16px;}
.stat-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;text-align:left;
}
.stat-card__num{display:block;font-size:1.9rem;color:var(--brick);font-weight:700;margin-bottom:6px;}
.stat-card__label{font-size:0.88rem;color:var(--ink-soft);}

/* =========================================================
   COMPARE
   ========================================================= */
.compare{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.compare__card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;
}
.compare__card h3{font-family:var(--font-display);font-size:1.05rem;margin:0 0 10px;}
.compare__card p{font-size:0.9rem;color:var(--ink-soft);margin:0;}
.compare__card--highlight{
  background:var(--saag);color:#fff;border-color:var(--saag);
}
.compare__card--highlight p{color:#e9f1e9;}

/* =========================================================
   FLOW
   ========================================================= */
.flow{display:flex;align-items:stretch;gap:14px;}
.flow__step{
  flex:1;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;
}
.flow__badge{
  display:inline-block;font-family:var(--font-mono);font-size:0.72rem;font-weight:700;
  background:var(--marigold);padding:4px 10px;border-radius:5px;margin-bottom:14px;
}
.flow__step h3{margin:0 0 8px;font-size:1.1rem;}
.flow__step p{margin:0;color:var(--ink-soft);font-size:0.9rem;}
.flow__arrow{display:flex;align-items:center;font-size:1.6rem;color:var(--brick);}

/* =========================================================
   REVENUE
   ========================================================= */
.revenue-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.revenue-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;}
.revenue-card__pct{display:block;font-size:1.8rem;color:var(--saag);margin-bottom:10px;}
.revenue-card h3{margin:0 0 8px;font-size:1.05rem;}
.revenue-card p{margin:0;color:var(--ink-soft);font-size:0.9rem;}

.cta-band{text-align:center;padding-bottom:100px;}
.cta-band .hero__lede{margin-left:auto;margin-right:auto;}

/* =========================================================
   AUTH
   ========================================================= */
.auth-wrap{display:flex;justify-content:center;padding:60px 24px 100px;}
.auth-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px;width:100%;max-width:420px;box-shadow:var(--shadow);
}
.tabs{display:flex;gap:6px;background:var(--paper-dark);border-radius:999px;padding:4px;margin-bottom:24px;}
.tab{flex:1;border:none;background:none;padding:9px;border-radius:999px;font-weight:700;}
.tab.active{background:var(--brick);color:#fff;}
.form{display:flex;flex-direction:column;gap:14px;}
.form label{display:flex;flex-direction:column;gap:6px;font-size:0.85rem;font-weight:700;color:var(--ink-soft);}
.form input,.form select{
  padding:10px 12px;border-radius:8px;border:1px solid var(--line);background:var(--paper);color:var(--ink);
  font-weight:500;
}
.form input:focus,.form select:focus{border-color:var(--brick);}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form__error{color:var(--brick);font-size:0.85rem;margin:0;min-height:1em;}
.form__hint{font-size:0.8rem;color:var(--ink-soft);text-align:center;margin-top:6px;}
.toggle-row{flex-direction:row !important;align-items:center;gap:8px !important;font-weight:600;}
.toggle-row input{width:auto;}
.safety-warn{
  background:var(--brick-light);color:#7a2c22;font-size:0.82rem;padding:10px 12px;border-radius:8px;margin:0;
}

/* =========================================================
   DASHBOARD
   ========================================================= */
.dash-locked{max-width:520px;margin:100px auto;text-align:center;}
.dash-head{
  max-width:1180px;margin:0 auto;padding:48px 24px 12px;
  display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;
}
.impact-chips{display:flex;gap:10px;flex-wrap:wrap;}
.impact-chip{
  background:var(--saag-light);color:var(--saag);font-family:var(--font-mono);font-weight:700;
  font-size:0.82rem;padding:8px 14px;border-radius:999px;
}
.dash-grid{
  max-width:1180px;margin:0 auto;padding:24px 24px 100px;
  display:grid;grid-template-columns:400px 1fr;gap:24px;align-items:start;
}
.panel{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;
}
.panel h3{margin:0 0 16px;font-family:var(--font-display);font-size:1.05rem;}
.ngo-badge-row{
  max-width:1180px;margin:0 auto;padding:0 24px 12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.badge{padding:6px 12px;border-radius:999px;font-weight:700;font-size:0.82rem;}
.badge--verified{background:var(--saag-light);color:var(--saag);}

.listing-stack{display:flex;flex-direction:column;gap:14px;max-height:640px;overflow:auto;padding-right:4px;}
.listing-stack:empty::after{content:"Nothing here yet.";color:var(--ink-soft);font-size:0.9rem;}

/* =========================================================
   BROWSE
   ========================================================= */
.browse-head{
  max-width:1180px;margin:0 auto;padding:48px 24px 24px;
  display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;
}
.browse-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.browse-controls select{padding:9px 10px;border-radius:8px;border:1px solid var(--line);background:#fff;}
.listing-grid{
  max-width:1180px;margin:0 auto;padding:0 24px 100px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}

/* listing card (ticket, list-mode) */
.lcard{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 20px 0;box-shadow:var(--shadow);display:flex;flex-direction:column;
  animation:cardIn .35s ease both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.lcard__top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;}
.lcard__tags{display:flex;gap:6px;flex-wrap:wrap;}
.tag{font-family:var(--font-mono);font-size:0.68rem;font-weight:700;padding:4px 8px;border-radius:5px;letter-spacing:.03em;}
.tag--discount{background:var(--marigold);color:var(--ink);}
.tag--donation{background:var(--saag-light);color:var(--saag);}
.tag--escalated{background:var(--brick);color:#fff;}
.tag--ngo{background:var(--ink);color:#fff;}
.tag--status{background:var(--paper-dark);color:var(--ink-soft);}
.lcard__timer{font-family:var(--font-mono);font-weight:700;color:var(--brick);font-size:0.95rem;white-space:nowrap;}
.lcard__timer.expired{color:var(--ink-soft);}
.lcard h4{margin:0 0 4px;font-size:1.1rem;}
.lcard__meta{color:var(--ink-soft);font-size:0.85rem;margin:0 0 12px;}
.lcard__price{display:flex;align-items:baseline;gap:8px;margin-bottom:14px;}
.lcard__price .strike{color:var(--ink-soft);text-decoration:line-through;font-size:0.9rem;}
.lcard__price .now{font-family:var(--font-mono);font-weight:700;font-size:1.3rem;color:var(--saag);}
.lcard__perf{height:0;border-top:2px dashed var(--line);margin:0 -20px;}
.lcard__foot{display:flex;justify-content:space-between;align-items:center;padding:14px 0;}
.lcard__foot .btn{width:100%;}

/* =========================================================
   SAFETY / ABOUT
   ========================================================= */
.safety-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:32px;}
.safety-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;}
.safety-card h3{margin:0 0 10px;font-size:1.05rem;}
.safety-card p{margin:0;color:var(--ink-soft);font-size:0.9rem;}
.disclaimer-box{
  background:var(--paper-dark);border-left:4px solid var(--brick);border-radius:8px;padding:22px 24px;
}
.disclaimer-box h3{margin:0 0 10px;font-size:1rem;}
.disclaimer-box p{margin:0;font-style:italic;color:var(--ink-soft);}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:24px;}
.about-grid h3{font-family:var(--font-display);font-size:1.1rem;margin:0 0 14px;}
.check-list li{padding-left:26px;position:relative;margin-bottom:12px;color:var(--ink-soft);font-size:0.94rem;}
.check-list li::before{content:"✓";position:absolute;left:0;color:var(--saag);font-weight:700;}

/* =========================================================
   MODALS
   ========================================================= */
.modal-overlay{
  position:fixed;inset:0;background:rgba(32,26,18,0.55);display:flex;align-items:center;justify-content:center;
  z-index:100;padding:20px;
}
.modal{
  background:#fff;border-radius:var(--radius);padding:28px;max-width:420px;width:100%;position:relative;
  box-shadow:var(--shadow-lg);animation:modalIn .2s ease both;
}
@keyframes modalIn{from{opacity:0;transform:scale(.96);}to{opacity:1;transform:scale(1);}}
.modal__close{
  position:absolute;top:14px;right:14px;background:none;border:none;font-size:1.1rem;color:var(--ink-soft);
}
.modal h3{margin:0 0 10px;font-family:var(--font-display);font-size:1.15rem;}
.modal--ticket .ticket{box-shadow:none;border:1px solid var(--line);margin-top:14px;transform:none;max-width:none;}
.otp-display{
  display:flex;justify-content:space-between;align-items:center;background:var(--paper-dark);
  border-radius:8px;padding:12px 16px;margin:14px 0;
}
.otp-display span{font-size:0.75rem;color:var(--ink-soft);font-weight:700;letter-spacing:.08em;}
.otp-display strong{font-size:1.6rem;letter-spacing:.2em;color:var(--brick);}
.ticket-qr{display:flex;justify-content:center;padding:10px 0 4px;}

/* =========================================================
   TOAST
   ========================================================= */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:var(--paper);padding:13px 22px;border-radius:999px;
  font-weight:600;font-size:0.9rem;box-shadow:var(--shadow-lg);z-index:200;
  animation:toastIn .25s ease both;
}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,10px);}to{opacity:1;transform:translate(-50%,0);}}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{border-top:1px solid var(--line);background:var(--paper-dark);}
.footer__inner{
  max-width:1180px;margin:0 auto;padding:40px 24px;
  display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;
}
.footer__brand{display:flex;align-items:center;gap:8px;font-family:var(--font-display);}
.footer__links{display:flex;gap:20px;font-weight:600;font-size:0.9rem;}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:960px){
  .hero__grid{grid-template-columns:1fr;}
  .hero__ticket-wrap{order:-1;}
  .stat-row,.compare,.revenue-grid,.safety-grid{grid-template-columns:repeat(2,1fr);}
  .flow{flex-direction:column;}
  .flow__arrow{transform:rotate(90deg);justify-content:center;padding:2px 0;}
  .dash-grid{grid-template-columns:1fr;}
  .listing-grid{grid-template-columns:repeat(2,1fr);}
  .about-grid{grid-template-columns:1fr;}
}
@media (max-width:680px){
  .navlinks{
    position:absolute;top:100%;left:0;right:0;background:var(--paper);
    flex-direction:column;padding:16px 24px;border-bottom:1px solid var(--line);display:none;gap:14px;
  }
  .navlinks.open{display:flex;}
  .hamburger{display:block;}
  .navbar__actions .auth-area,.navbar__actions .user-area{display:none;}
  .navbar__actions.show-mobile .auth-area,.navbar__actions.show-mobile .user-area{display:flex;}
  .stat-row,.compare,.revenue-grid,.safety-grid,.listing-grid{grid-template-columns:1fr;}
  .form__row{grid-template-columns:1fr;}
  .notif-panel{right:12px;width:calc(100vw - 24px);}
  .display{font-size:2.2rem;}
}
