/* ============================================================
   TSHIMO DATING APP — app.css
   ============================================================ */

/* ----- CSS Variables / Brand Tokens ----- */
:root {
  --soil: #2C1810;
  --bark: #4A2C20;
  --terracotta: #C4673C;
  --copper: #D4845A;
  --sand: #E8D5B7;
  --cream: #F5EDE0;
  --sage: #7A9E7E;
  --deep-green: #2D5A3D;
  --leaf: #4CAF6A;
  --gold: #D4A843;
  --warm-white: #FEFBF6;
  --charcoal: #1A1A1A;

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --shadow-sm: 0 1px 3px rgba(44,24,16,.08);
  --shadow-md: 0 4px 12px rgba(44,24,16,.1);
  --shadow-lg: 0 8px 30px rgba(44,24,16,.12);
  --transition: .25s cubic-bezier(.4,0,.2,1);
}

/* ----- Reset ----- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Outfit',system-ui,-apple-system,sans-serif;
  background:var(--cream);
  color:var(--soil);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:1rem}
img{max-width:100%;display:block}

/* ----- Utilities ----- */
.hidden{display:none!important}
.container{max-width:960px;margin:0 auto;padding:1.5rem}

/* ----- Typography ----- */
.page-title{font-family:'DM Serif Display',serif;font-size:2rem;margin-bottom:.25rem}
.page-subtitle{color:var(--bark);opacity:.7;font-weight:300;margin-bottom:1.5rem}
.section-title{font-family:'DM Serif Display',serif;font-size:1.25rem;margin-bottom:1rem}

/* ----- Logo Images ----- */
.nav-logo-img{
  height:36px;
  width:auto;
  display:block;
}
.auth-logo{
  text-align:center;
  margin-bottom:.25rem;
}
.auth-logo-img{
  height:56px;
  width:auto;
  display:inline-block;
  margin:0 auto;
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--soil);color:var(--cream);
  box-shadow:var(--shadow-md);
}
.nav-inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 1.5rem;
}
.nav-logo{
  display:flex;align-items:center;
}
.nav-links{display:flex;align-items:center;gap:1.25rem}
.nav-links a{
  font-size:.9rem;font-weight:500;color:var(--sand);
  padding:.35rem .5rem;border-radius:var(--radius-sm);
  transition:color var(--transition),background var(--transition);
}
.nav-links a:hover,.nav-links a.active{color:var(--cream);background:rgba(255,255,255,.1)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--cream);border-radius:2px;transition:var(--transition)}

@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{
    display:none;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:var(--soil);padding:1rem 1.5rem;
    border-top:1px solid rgba(255,255,255,.08);
    gap:.5rem;
  }
  .nav-links.open{display:flex}
  .nav-links a{width:100%;padding:.6rem .5rem}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.7rem 1.5rem;border-radius:var(--radius-md);
  font-weight:600;font-size:.95rem;
  transition:all var(--transition);
}
.btn-sm{padding:.45rem 1rem;font-size:.85rem}
.btn-full{width:100%}
.btn-primary{
  background:linear-gradient(135deg,var(--terracotta),var(--copper));
  color:var(--warm-white);
  box-shadow:0 2px 8px rgba(196,103,60,.3);
}
.btn-primary:hover{box-shadow:0 4px 16px rgba(196,103,60,.4);transform:translateY(-1px)}
.btn-sage{background:var(--sage);color:#fff}
.btn-sage:hover{background:var(--deep-green)}
.btn-outline{
  border:1.5px solid var(--sand);color:var(--soil);background:transparent;
}
.btn-outline:hover{background:var(--sand)}
.btn-destructive{background:var(--soil);color:var(--cream)}
.btn-destructive:hover{background:var(--charcoal)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* Button spinner */
.btn-spinner{
  display:inline-block;width:18px;height:18px;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  border-radius:50%;animation:spin .6s linear infinite;
}

/* ============================================================
   FORMS
   ============================================================ */
.form-group{margin-bottom:1rem;text-align:left}
.form-group label{display:block;font-weight:500;font-size:.875rem;margin-bottom:.35rem;color:var(--bark)}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:.7rem .9rem;
  background:var(--cream);border:1.5px solid var(--sand);
  border-radius:var(--radius-sm);font-size:.95rem;color:var(--soil);
  transition:border var(--transition),box-shadow var(--transition);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--copper);
  box-shadow:0 0 0 3px rgba(232,213,183,.5);
}
.form-group textarea{resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field-error{display:block;color:var(--terracotta);font-size:.8rem;min-height:1.2em;margin-top:.2rem}
.form-error{
  background:rgba(196,103,60,.1);color:var(--terracotta);
  padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.875rem;
  margin-bottom:.75rem;display:none;
}
.form-error.show{display:block}

/* ============================================================
   AUTH PAGES (Login / Register)
   ============================================================ */
.auth-container{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:2rem 1rem;background:var(--cream);
}
.auth-card{
  width:100%;max-width:420px;
  background:var(--warm-white);
  border-radius:var(--radius-xl);
  padding:2.5rem 2rem;
  box-shadow:var(--shadow-lg);
}
.auth-logo{
  text-align:center;margin-bottom:.25rem;
}
.auth-tagline{
  text-align:center;font-family:'Cormorant Garamond',serif;
  font-size:1.1rem;font-style:italic;color:var(--bark);opacity:.7;
  margin-bottom:2rem;
}
.auth-form{margin-top:1rem}
.auth-switch{
  text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--bark);
}
.auth-switch a{color:var(--terracotta);font-weight:600}
.auth-switch a:hover{text-decoration:underline}

/* ============================================================
   PAGE TRANSITIONS
   ============================================================ */
.page{
  display:none;opacity:0;
  animation:fadeIn .35s ease forwards;
}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   DASHBOARD
   ============================================================ */
.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}

.stats-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1rem;margin-bottom:2rem;
}
.stat-card{
  background:var(--warm-white);border-radius:var(--radius-lg);
  padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;
  box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);
}
.stat-card:hover{box-shadow:var(--shadow-md)}
.stat-card.mini{flex-direction:column;text-align:center;padding:1rem}
.stat-icon{
  width:44px;height:44px;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:linear-gradient(135deg,var(--terracotta),var(--copper));color:#fff;
}
.stat-icon svg{width:22px;height:22px}
.stat-icon.vouch-icon{background:linear-gradient(135deg,var(--sage),var(--deep-green))}
.stat-icon.credits-icon{background:linear-gradient(135deg,var(--gold),#c49a38)}
.stat-icon.matches-icon{background:linear-gradient(135deg,var(--copper),var(--terracotta))}
.stat-info{flex:1;min-width:0}
.stat-label{display:block;font-size:.8rem;color:var(--bark);opacity:.7;margin-bottom:.15rem}
.stat-value{display:block;font-family:'DM Serif Display',serif;font-size:1.35rem}

/* Progress bar */
.progress-bar{
  height:6px;background:var(--sand);border-radius:3px;overflow:hidden;margin-top:.5rem;
}
.progress-fill{
  height:100%;border-radius:3px;
  background:linear-gradient(90deg,var(--terracotta),var(--copper));
  transition:width .6s ease;
}

/* Vouch dots */
.vouch-dots{display:flex;gap:.4rem;margin-top:.5rem}
.vouch-dot{
  width:12px;height:12px;border-radius:50%;
  background:var(--sand);transition:background var(--transition);
}
.vouch-dot.filled{background:var(--sage)}

/* Quick actions */
.quick-actions{margin-top:1rem}
.actions-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}
.action-card{
  background:var(--warm-white);border-radius:var(--radius-lg);
  padding:1.5rem 1rem;text-align:center;
  box-shadow:var(--shadow-sm);transition:all var(--transition);
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  font-weight:500;font-size:.9rem;
}
.action-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.action-icon{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--terracotta),var(--copper));color:#fff;
}
.action-icon svg{width:22px;height:22px}
.action-icon.sage-icon{background:linear-gradient(135deg,var(--sage),var(--deep-green))}
.action-icon.gold-icon{background:linear-gradient(135deg,var(--gold),#c49a38)}

/* ============================================================
   DISCOVER
   ============================================================ */
.discover-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;
}
.discover-card{
  background:var(--warm-white);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:all var(--transition);
}
.discover-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.discover-card-top{
  padding:1.5rem 1.25rem 1rem;display:flex;align-items:center;gap:1rem;
}
.discover-avatar{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--sand),var(--copper));
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:1.3rem;color:var(--soil);
  flex-shrink:0;
}
.discover-info{flex:1;min-width:0}
.discover-info h3{font-family:'DM Serif Display',serif;font-size:1.1rem;margin-bottom:.15rem}
.discover-info .gender-tag{font-size:.8rem;color:var(--bark);opacity:.6;text-transform:capitalize}
.discover-badges{display:flex;gap:.4rem;margin-top:.35rem;flex-wrap:wrap}
.discover-card-body{padding:0 1.25rem}
.discover-card-body p{font-size:.9rem;color:var(--bark);line-height:1.5}
.discover-card-actions{padding:1rem 1.25rem;display:flex;gap:.5rem}

/* ============================================================
   BADGES
   ============================================================ */
.badge{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.2rem .6rem;border-radius:var(--radius-sm);
  font-size:.75rem;font-weight:600;
}
.trust-badge{background:rgba(122,158,126,.15);color:var(--deep-green)}
.trust-badge svg{vertical-align:middle;margin-right:.15rem;flex-shrink:0}
.trust-badge.trust-high{background:rgba(45,90,61,.2);color:var(--deep-green)}
.trust-badge.trust-medium{background:rgba(212,168,67,.15);color:#8a6d1b}
.trust-badge.trust-low{background:rgba(74,44,32,.1);color:var(--bark)}
.elite-badge{background:linear-gradient(135deg,var(--gold),#c49a38);color:#fff}
.vouch-badge{background:rgba(196,103,60,.1);color:var(--terracotta)}

/* ============================================================
   MATCHES
   ============================================================ */
.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}
.tab{
  padding:.6rem 1.25rem;border-radius:var(--radius-md);
  font-weight:600;font-size:.9rem;color:var(--bark);
  background:var(--warm-white);border:1.5px solid var(--sand);
  transition:all var(--transition);
}
.tab.active{background:var(--soil);color:var(--cream);border-color:var(--soil)}
.tab-panel{min-height:200px}

.matches-list{display:flex;flex-direction:column;gap:1rem}
.match-card{
  background:var(--warm-white);border-radius:var(--radius-lg);
  padding:1.25rem;display:flex;align-items:center;gap:1rem;
  box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);
}
.match-card:hover{box-shadow:var(--shadow-md)}
.match-avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--sand),var(--copper));
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--soil);
  flex-shrink:0;
}
.match-info{flex:1;min-width:0}
.match-info h3{font-size:1rem;margin-bottom:.15rem}
.match-info .match-score{font-size:.8rem;color:var(--sage);font-weight:500}
.match-info .match-status{font-size:.8rem;color:var(--bark);opacity:.6}
.match-info .match-bio{font-size:.8rem;color:var(--bark);opacity:.7;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}
.match-badges{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.25rem}
.match-actions{display:flex;gap:.5rem;flex-shrink:0}
@media(max-width:600px){
  .match-card{flex-direction:column;text-align:center}
  .match-actions{width:100%;justify-content:center}
}

/* ============================================================
   SAFETY
   ============================================================ */
.safety-panic-section{
  text-align:center;padding:2rem 1rem;
  background:var(--warm-white);border-radius:var(--radius-xl);
  margin-bottom:2rem;box-shadow:var(--shadow-sm);
}
.panic-button{
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(135deg,#c0392b,var(--terracotta));
  color:#fff;display:inline-flex;flex-direction:column;
  align-items:center;justify-content:center;gap:.3rem;
  font-weight:700;font-size:1rem;letter-spacing:1px;
  box-shadow:0 4px 20px rgba(192,57,43,.35);
  transition:all var(--transition);
  animation:panicPulse 3s ease-in-out infinite;
}
.panic-button svg{width:28px;height:28px}
.panic-button:hover{transform:scale(1.05);box-shadow:0 6px 28px rgba(192,57,43,.45)}
@keyframes panicPulse{0%,100%{box-shadow:0 4px 20px rgba(192,57,43,.35)}50%{box-shadow:0 4px 30px rgba(192,57,43,.5)}}
.panic-desc{margin-top:1rem;font-size:.875rem;color:var(--bark);opacity:.7;max-width:320px;margin-left:auto;margin-right:auto}

.safety-timer-section,.safety-section{
  background:var(--warm-white);border-radius:var(--radius-xl);
  padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);
}
.timer-controls{display:flex;gap:.75rem;align-items:center}
.timer-select{
  flex:1;padding:.6rem .8rem;border:1.5px solid var(--sand);
  border-radius:var(--radius-sm);background:var(--cream);color:var(--soil);
}
.timer-display{text-align:center;margin-top:1.5rem}
.timer-ring{position:relative;width:140px;height:140px;margin:0 auto 1rem}
.timer-ring svg{width:100%;height:100%}
.timer-text{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'DM Serif Display',serif;font-size:1.5rem;
}
.timer-display .btn{margin-top:.5rem}

.safe-spots-list{display:flex;flex-direction:column;gap:.75rem}
.safe-spot-card{
  padding:1rem;border:1.5px solid var(--sand);border-radius:var(--radius-md);
  display:flex;align-items:center;gap:.75rem;
}
.safe-spot-card .spot-icon{
  width:40px;height:40px;border-radius:50%;
  background:var(--sage);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.safe-spot-card .spot-icon svg{width:18px;height:18px}
.safe-spot-card .spot-info{flex:1}
.safe-spot-card .spot-info h4{font-size:.95rem;margin-bottom:.1rem}
.safe-spot-card .spot-info p{font-size:.8rem;color:var(--bark);opacity:.6}

.incidents-list{display:flex;flex-direction:column;gap:.75rem}
.incident-card{
  padding:1rem;border:1.5px solid var(--sand);border-radius:var(--radius-md);
}
.incident-card .incident-type{
  font-size:.75rem;font-weight:600;text-transform:uppercase;
  color:var(--terracotta);margin-bottom:.25rem;
}
.incident-card .incident-date{font-size:.8rem;color:var(--bark);opacity:.6}
.incident-card .incident-status{
  display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);
  font-size:.75rem;font-weight:600;margin-top:.35rem;
}
.incident-card .incident-status.open{background:rgba(196,103,60,.15);color:var(--terracotta)}
.incident-card .incident-status.resolved{background:rgba(122,158,126,.15);color:var(--deep-green)}

/* ============================================================
   PROFILE
   ============================================================ */
.profile-header{
  text-align:center;padding:2rem 1rem;
  background:var(--warm-white);border-radius:var(--radius-xl);
  margin-bottom:1.5rem;box-shadow:var(--shadow-sm);
}
.profile-avatar{
  width:80px;height:80px;border-radius:50%;margin:0 auto .75rem;
  background:linear-gradient(135deg,var(--terracotta),var(--copper));
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:2rem;color:#fff;
}
.profile-name{font-family:'DM Serif Display',serif;font-size:1.5rem;margin-bottom:.15rem}
.profile-email{font-size:.9rem;color:var(--bark);opacity:.6;margin-bottom:.75rem}
.profile-badges{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}

.profile-section{
  background:var(--warm-white);border-radius:var(--radius-xl);
  padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);
}
.profile-edit-form .btn{margin-top:.5rem}

.vouch-status-card{
  padding:1rem;border:1.5px solid var(--sand);border-radius:var(--radius-md);
  margin-bottom:1rem;
}
.vouches-list{display:flex;flex-direction:column;gap:.5rem}
.vouch-item{
  padding:.75rem;border:1px solid var(--sand);border-radius:var(--radius-sm);
}
.vouch-item .vouch-from{font-weight:600;font-size:.9rem}
.vouch-item .vouch-rel{font-size:.8rem;color:var(--bark);opacity:.7}
.vouch-item .vouch-msg{font-size:.85rem;font-style:italic;margin-top:.25rem;color:var(--bark)}

.account-actions{display:flex;flex-direction:column;gap:.75rem}

/* ============================================================
   ADMIN
   ============================================================ */
.admin-stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:1rem;margin-bottom:2rem;
}
.admin-section{
  background:var(--warm-white);border-radius:var(--radius-xl);
  padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);
}
.table-wrap{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}
.admin-table th{
  text-align:left;padding:.6rem .75rem;
  border-bottom:2px solid var(--sand);font-weight:600;font-size:.8rem;
  text-transform:uppercase;color:var(--bark);opacity:.7;
}
.admin-table td{padding:.6rem .75rem;border-bottom:1px solid var(--sand)}
.admin-table tr:hover td{background:rgba(232,213,183,.2)}
.admin-incidents-list{display:flex;flex-direction:column;gap:.75rem}

/* ============================================================
   MODALS
   ============================================================ */
.modal{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:1rem;
}
.modal-overlay{position:absolute;inset:0;background:rgba(26,26,26,.5);backdrop-filter:blur(4px)}
.modal-content{
  position:relative;z-index:1;
  background:var(--warm-white);border-radius:var(--radius-xl);
  padding:2rem;max-width:420px;width:100%;
  box-shadow:var(--shadow-lg);
  animation:modalIn .3s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.modal-content h2{font-family:'DM Serif Display',serif;font-size:1.3rem;margin-bottom:.5rem}
.modal-content p{font-size:.9rem;color:var(--bark);margin-bottom:1rem}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.modal-header h2{margin-bottom:0}
.modal-close{font-size:1.5rem;color:var(--bark);padding:.25rem}
.modal-body{max-height:60vh;overflow-y:auto}
.modal-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}
.modal-panic h2{color:#c0392b}

/* Chat modal */
.modal-chat{
  max-width:520px;padding:0;display:flex;flex-direction:column;
  height:min(80vh,600px);border-radius:var(--radius-xl);overflow:hidden;
}
.chat-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem 1.25rem;border-bottom:1px solid var(--sand);
  background:var(--warm-white);
}
.chat-header-info{display:flex;align-items:center;gap:.75rem}
.chat-header h2{font-family:'DM Serif Display',serif;font-size:1.1rem;margin-bottom:0}
.chat-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--sand),var(--copper));
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:1rem;color:var(--soil);
}
.chat-trust{font-size:.75rem;color:var(--sage);font-weight:500}
.chat-messages{
  flex:1;overflow-y:auto;padding:1rem 1.25rem;
  display:flex;flex-direction:column;gap:.5rem;
  background:var(--cream);
}
.chat-placeholder{text-align:center;padding:2rem 1rem;color:var(--bark);opacity:.6}
.chat-placeholder p{margin-bottom:0}
.chat-bubble{
  max-width:80%;padding:.6rem .9rem;border-radius:var(--radius-md);
  font-size:.9rem;line-height:1.4;word-wrap:break-word;
}
.chat-bubble.sent{
  align-self:flex-end;
  background:linear-gradient(135deg,var(--terracotta),var(--copper));
  color:#fff;border-bottom-right-radius:4px;
}
.chat-bubble.received{
  align-self:flex-start;
  background:var(--warm-white);color:var(--soil);
  border-bottom-left-radius:4px;box-shadow:var(--shadow-sm);
}
.chat-bubble .chat-time{
  display:block;font-size:.65rem;opacity:.6;margin-top:.2rem;
  text-align:right;
}
.chat-input-wrap{
  display:flex;gap:.5rem;padding:.75rem 1rem;
  border-top:1px solid var(--sand);background:var(--warm-white);
}
.chat-input-wrap input{
  flex:1;padding:.6rem .8rem;border:1.5px solid var(--sand);
  border-radius:var(--radius-sm);font-size:.9rem;
  background:var(--cream);color:var(--soil);
}
.chat-input-wrap input:focus{outline:none;border-color:var(--copper)}
.chat-input-wrap .btn{padding:.5rem .7rem;flex-shrink:0}

/* Credits modal */
.credits-options{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin:1rem 0}
.credit-option{
  padding:.75rem .5rem;border:2px solid var(--sand);border-radius:var(--radius-md);
  text-align:center;transition:all var(--transition);
}
.credit-option:hover,.credit-option.selected{border-color:var(--terracotta);background:rgba(196,103,60,.05)}
.credit-amount{display:block;font-family:'DM Serif Display',serif;font-size:1.3rem}
.credit-label{font-size:.7rem;color:var(--bark);opacity:.6}

/* ============================================================
   LOADING / EMPTY STATES
   ============================================================ */
.loading-state{text-align:center;padding:3rem 1rem;color:var(--bark);opacity:.6}
.spinner{
  width:32px;height:32px;border:3px solid var(--sand);
  border-top-color:var(--terracotta);border-radius:50%;
  animation:spin .7s linear infinite;margin:0 auto .75rem;
}
@keyframes spin{to{transform:rotate(360deg)}}
.page-loader{
  position:fixed;inset:0;z-index:300;
  background:rgba(245,237,224,.8);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
}
.page-loader .spinner{width:48px;height:48px;border-width:4px}

.empty-state{text-align:center;padding:3rem 1rem}
.empty-icon{
  width:64px;height:64px;margin:0 auto 1rem;
  color:var(--sand);
}
.empty-icon svg{width:100%;height:100%}
.empty-state h3{font-family:'DM Serif Display',serif;font-size:1.15rem;margin-bottom:.35rem}
.empty-state p{color:var(--bark);opacity:.6;font-size:.9rem;margin-bottom:1rem}

/* ============================================================
   TOAST NOTIFICATIONS
   ============================================================ */
#toast-container{
  position:fixed;top:1rem;right:1rem;z-index:999;
  display:flex;flex-direction:column;gap:.5rem;
  pointer-events:none;max-width:380px;width:calc(100% - 2rem);
}
.toast{
  pointer-events:auto;
  padding:.85rem 1.1rem;border-radius:var(--radius-md);
  font-size:.9rem;font-weight:500;
  box-shadow:var(--shadow-md);
  animation:toastIn .35s ease;
  display:flex;align-items:center;gap:.5rem;
}
.toast.success{background:var(--deep-green);color:#fff}
.toast.error{background:#c0392b;color:#fff}
.toast.info{background:var(--soil);color:var(--cream)}
.toast.out{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}

/* ============================================================
   TRANSACTIONS
   ============================================================ */
.transactions-list{display:flex;flex-direction:column;gap:.5rem}
.transaction-item{
  display:flex;justify-content:space-between;align-items:center;
  padding:.75rem;border-bottom:1px solid var(--sand);
}
.transaction-item:last-child{border-bottom:none}
.transaction-item .tx-type{font-weight:600;font-size:.9rem}
.transaction-item .tx-date{font-size:.75rem;color:var(--bark);opacity:.6}
.transaction-item .tx-amount{font-family:'DM Serif Display',serif;font-size:1rem}
.transaction-item .tx-amount.positive{color:var(--deep-green)}
.transaction-item .tx-amount.negative{color:var(--terracotta)}

/* ============================================================
   NOTIFICATIONS
   ============================================================ */
.nav-notif-link{
  position:relative;display:flex;align-items:center;
}
.notif-badge{
  position:absolute;top:-4px;right:-8px;
  background:var(--terracotta);color:#fff;
  font-size:.65rem;font-weight:700;
  min-width:16px;height:16px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  padding:0 4px;
}
.notif-list{display:flex;flex-direction:column;gap:.5rem}
.notif-item{
  padding:1rem;border-radius:var(--radius-md);
  background:var(--warm-white);box-shadow:var(--shadow-sm);
  display:flex;align-items:flex-start;gap:.75rem;
  transition:all var(--transition);cursor:pointer;
}
.notif-item:hover{box-shadow:var(--shadow-md)}
.notif-item.unread{border-left:3px solid var(--terracotta)}
.notif-icon{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--sand);color:var(--bark);
}
.notif-icon svg{width:16px;height:16px}
.notif-icon.match{background:rgba(196,103,60,.15);color:var(--terracotta)}
.notif-icon.safety{background:rgba(192,57,43,.15);color:#c0392b}
.notif-icon.credit{background:rgba(212,168,67,.15);color:var(--gold)}
.notif-icon.vouch{background:rgba(122,158,126,.15);color:var(--sage)}
.notif-icon.system{background:rgba(74,44,32,.1);color:var(--bark)}
.notif-body{flex:1;min-width:0}
.notif-title{font-weight:600;font-size:.9rem;margin-bottom:.1rem}
.notif-msg{font-size:.8rem;color:var(--bark);opacity:.7}
.notif-time{font-size:.7rem;color:var(--bark);opacity:.5;margin-top:.25rem}

/* ============================================================
   EMERGENCY CONTACTS
   ============================================================ */
.section-desc{font-size:.85rem;color:var(--bark);opacity:.7;margin-bottom:1rem}
.emergency-contacts-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.ec-card{
  padding:.75rem 1rem;border:1.5px solid var(--sand);border-radius:var(--radius-md);
  display:flex;justify-content:space-between;align-items:center;
}
.ec-info{flex:1}
.ec-info h4{font-size:.95rem;margin-bottom:.1rem}
.ec-info p{font-size:.8rem;color:var(--bark);opacity:.6}
.ec-actions{display:flex;gap:.35rem;flex-shrink:0}
.add-contact-form{
  padding:1rem;border:1.5px dashed var(--sand);border-radius:var(--radius-md);
  background:rgba(232,213,183,.1);
}

/* ============================================================
   ADMIN SAFE SPOTS
   ============================================================ */
.admin-spot-form{
  padding:1rem;border:1.5px solid var(--sand);border-radius:var(--radius-md);
  margin-bottom:1.25rem;background:rgba(232,213,183,.08);
}
.admin-spots-list{display:flex;flex-direction:column;gap:.75rem}
.admin-spot-card{
  padding:1rem;border:1.5px solid var(--sand);border-radius:var(--radius-md);
  display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;
}
.admin-spot-card .spot-details{flex:1}
.admin-spot-card .spot-details h4{font-size:.95rem;margin-bottom:.25rem}
.admin-spot-card .spot-details p{font-size:.8rem;color:var(--bark);opacity:.6;margin-bottom:.15rem}
.admin-spot-card .spot-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.35rem}
.admin-spot-card .spot-meta span{
  font-size:.7rem;padding:.15rem .4rem;border-radius:var(--radius-sm);
  background:var(--sand);color:var(--bark);
}

/* ============================================================
   VIBE CREDITS USAGE
   ============================================================ */
.credits-display{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.85rem;color:var(--gold);font-weight:600;
}
.credits-display svg{width:14px;height:14px}
.discover-credit-hint{
  font-size:.8rem;color:var(--bark);opacity:.5;text-align:center;
  margin-top:.5rem;padding:.5rem;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:480px){
  .auth-card{padding:2rem 1.25rem;border-radius:var(--radius-lg)}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .credits-options{grid-template-columns:repeat(2,1fr)}
  .page-title{font-size:1.5rem}
  .container{padding:1rem}
}
