/* =============================================================
   CHIRAG SOLUTIONS – Meet AI v4
   Fonts: Poppins (headings) + DM Sans (body)
   Full responsive: Mobile / Tablet / Desktop
   ============================================================= */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800;900&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

/* ─── TOKENS ───────────────────────────────────────────────── */
:root {
  /* Brand */
  --blue:       #1a6bcc;
  --blue2:      #2899e8;
  --cyan:       #5bc4f5;
  --grad:       linear-gradient(135deg,#1a6bcc 0%,#2899e8 55%,#5bc4f5 100%);
  /* Backgrounds */
  --bg:         #060d1a;
  --bg2:        #0b1525;
  --bg3:        #101e35;
  /* Surfaces */
  --s1:         rgba(255,255,255,0.045);
  --s2:         rgba(255,255,255,0.08);
  --shov:       rgba(26,107,204,0.10);
  /* Status */
  --grn:        #0fda7a; --grn-bg:rgba(15,218,122,0.10);
  --amb:        #ffb830; --amb-bg:rgba(255,184,48,0.10);
  --red:        #ff4b5c; --red-bg:rgba(255,75,92,0.10);
  --pur:        #a78bfa; --pur-bg:rgba(167,139,250,0.12);
  /* Text */
  --t1:         #eef4ff;
  --t2:         #8caac8;
  --t3:         #4a6280;
  --t4:         #1e2e42;
  /* Shape */
  --r:          16px;  --rsm:10px;  --rxs:7px;
  /* Nav */
  --navh:       68px;
  --toph:       62px;
  --sidebar-w:  240px;
  /* Fonts */
  --fh: 'Poppins', sans-serif;   /* headings */
  --fb: 'DM Sans', sans-serif;   /* body */
  /* Shadows */
  --shblue: 0 4px 24px rgba(26,107,204,0.38);
  --shcard: 0 2px 20px rgba(0,0,0,0.4);
  --tr: .18s cubic-bezier(.4,0,.2,1);
}

/* ─── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--fb);
  background:var(--bg);
  color:var(--t1);
  min-height:100vh;
  overflow-x:hidden;
  line-height:1.5;
}

/* Ambient mesh */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 55% at 90% 0%,  rgba(26,107,204,.13) 0%,transparent 60%),
    radial-gradient(ellipse 55% 65% at 0%  90%,  rgba(40,153,232,.07) 0%,transparent 60%),
    radial-gradient(ellipse 40% 40% at 50% 50%,  rgba(91,196,245,.04) 0%,transparent 55%);
}

/* ─── LOGO PILL ────────────────────────────────────────────── */
/* White creative box with subtle blue glow – works on any bg */
.logo-pill{
  display:inline-flex;align-items:center;justify-content:center;
  background:#ffffff;
  border-radius:10px;
  padding:5px 10px;
  box-shadow:0 0 0 1px rgba(26,107,204,.25), 0 4px 16px rgba(26,107,204,.2);
  flex-shrink:0;
  transition:box-shadow var(--tr);
}
.logo-pill:hover{box-shadow:0 0 0 1px rgba(26,107,204,.5), 0 6px 24px rgba(26,107,204,.35)}
.logo-pill img{height:24px;width:auto;display:block}

/* Auth screen – larger pill */
.auth-logo-pill{
  display:inline-flex;align-items:center;justify-content:center;
  background:#ffffff;
  border-radius:16px;
  padding:14px 28px;
  box-shadow:
    0 0 0 1px rgba(26,107,204,.3),
    0 8px 32px rgba(26,107,204,.25),
    0 2px 8px rgba(0,0,0,.4);
  margin-bottom:22px;
}
.auth-logo-pill img{height:40px;width:auto;display:block}

/* ─── LAYOUT MODES ─────────────────────────────────────────── */

/* MOBILE (default) */
body.layout-app{
  padding-top:var(--toph);
  padding-bottom:calc(var(--navh) + 10px);
}
body.layout-auth{ padding:0 }
body.layout-app .page-wrap{
  max-width:520px;margin:0 auto;padding:16px 14px;
  position:relative;z-index:1;
}

/* DESKTOP sidebar layout */
@media(min-width:900px){
  body.layout-app{
    padding-top:0;
    padding-bottom:0;
    padding-left:var(--sidebar-w);
  }
  body.layout-app .page-wrap{
    max-width:900px;
    margin:0 auto;
    padding:28px 32px;
  }
  .topbar{ display:none }
  .bottom-nav{ display:none }
  .sidebar{ display:flex }
  .sidebar-overlay{ display:none }
}
@media(min-width:1280px){
  body.layout-app .page-wrap{ max-width:1100px }
}
@media(max-width:899px){
  .sidebar{ display:none }
}

/* ─── TOPBAR (mobile/tablet) ───────────────────────────────── */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--toph);
  background:rgba(6,13,26,.95);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border-bottom:1px solid rgba(26,107,204,.18);
  z-index:300;
}
.topbar-inner{
  max-width:520px;margin:0 auto;height:100%;
  padding:0 14px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.back-btn{
  display:flex;align-items:center;gap:5px;
  color:var(--t2);text-decoration:none;font-size:.82rem;font-weight:500;
  padding:6px 10px;border-radius:var(--rxs);white-space:nowrap;
  transition:color var(--tr);
}
.back-btn:hover{color:var(--cyan)}
.topbar-title{font-family:var(--fh);font-weight:700;font-size:.9rem;color:var(--t1)}
.topbar-right{display:flex;align-items:center;gap:8px}
.avatar-chip{
  display:flex;align-items:center;gap:7px;
  background:var(--s1);border:1px solid var(--s2);
  border-radius:50px;padding:3px 11px 3px 3px;
  text-decoration:none;transition:border-color var(--tr);
}
.avatar-chip:hover{border-color:rgba(26,107,204,.4)}
.av-circle{
  width:28px;height:28px;border-radius:50%;background:var(--grad);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-size:.7rem;font-weight:700;color:#fff;
}
.av-name{font-size:.76rem;font-weight:500;color:var(--t2)}

/* ─── SIDEBAR (desktop) ─────────────────────────────────────── */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);
  background:rgba(6,13,26,.98);
  border-right:1px solid rgba(26,107,204,.15);
  flex-direction:column;
  z-index:300;
  padding:24px 0 24px;
}
.sidebar-logo{
  padding:0 20px 24px;
  border-bottom:1px solid rgba(26,107,204,.12);
  margin-bottom:12px;
}
.sidebar-logo .logo-pill{ padding:8px 14px }
.sidebar-logo .logo-pill img{ height:26px }
.sidebar-nav{ flex:1;overflow-y:auto;padding:0 10px }
.sidebar-nav a{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--rsm);
  color:var(--t3);text-decoration:none;
  font-size:.85rem;font-weight:500;
  transition:all var(--tr);margin-bottom:2px;
}
.sidebar-nav a:hover{background:var(--shov);color:var(--t2)}
.sidebar-nav a.active{background:rgba(26,107,204,.18);color:var(--cyan)}
.sidebar-nav a.active svg{filter:drop-shadow(0 0 4px rgba(91,196,245,.5))}
.sidebar-nav a svg{flex-shrink:0;opacity:.7;transition:opacity var(--tr)}
.sidebar-nav a:hover svg,.sidebar-nav a.active svg{opacity:1}
.sidebar-section{
  font-size:.6rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--t4);
  padding:14px 14px 6px;
}
.sidebar-footer{
  padding:16px 20px 0;
  border-top:1px solid rgba(26,107,204,.12);
}
.sidebar-footer a{
  display:flex;align-items:center;gap:8px;
  font-size:.8rem;color:var(--t3);text-decoration:none;
  padding:8px;border-radius:var(--rxs);
  transition:color var(--tr);
}
.sidebar-footer a:hover{color:var(--red)}
/* Sidebar user card */
.sidebar-user{
  display:flex;align-items:center;gap:10px;
  padding:12px 20px;margin-bottom:8px;
}
.sidebar-user .av-circle{width:34px;height:34px;font-size:.8rem}
.sidebar-user-info{ min-width:0 }
.sidebar-user-name{font-size:.82rem;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:.68rem;color:var(--t3)}

/* Record FAB on desktop sidebar */
.sidebar-record{
  margin:8px 10px 12px;
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:var(--rsm);
  background:var(--grad);color:#fff;
  text-decoration:none;font-size:.85rem;font-weight:700;
  box-shadow:var(--shblue);
  transition:filter var(--tr),box-shadow var(--tr);
}
.sidebar-record:hover{filter:brightness(1.08);box-shadow:0 6px 32px rgba(26,107,204,.5)}

/* ─── BOTTOM NAV (mobile) ──────────────────────────────────── */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;height:var(--navh);
  background:rgba(6,13,26,.97);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border-top:1px solid rgba(26,107,204,.14);
  display:flex;align-items:center;
  padding:0 2px env(safe-area-inset-bottom,0);
  z-index:300;
}
.nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:6px 2px;
  text-decoration:none;color:var(--t3);
  font-size:.56rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  border-radius:8px;transition:color var(--tr);
}
.nav-item.active{color:var(--cyan)}
.nav-item.active svg{filter:drop-shadow(0 0 5px rgba(91,196,245,.5))}
/* Elevated record button */
.nav-item-record{
  flex:1;display:flex;flex-direction:column;align-items:center;
  text-decoration:none;color:var(--cyan);
  font-size:.56rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  margin-top:-18px;padding-bottom:2px;
}
.nav-item-record .rec-bubble{
  width:50px;height:50px;border-radius:50%;background:var(--grad);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shblue);
  transition:transform var(--tr),box-shadow var(--tr);
  margin-bottom:3px;
}
.nav-item-record:hover .rec-bubble,.nav-item-record.active .rec-bubble{
  transform:scale(1.08);box-shadow:0 6px 28px rgba(26,107,204,.6);
}

/* ─── PAGE HEADER ──────────────────────────────────────────── */
.page-header{margin-bottom:20px}
.page-eyebrow{
  display:flex;align-items:center;gap:5px;
  font-size:.65rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--blue2);margin-bottom:2px;
}
.page-title{
  font-family:var(--fh);
  font-size:1.6rem;font-weight:800;color:var(--t1);
  line-height:1.15;letter-spacing:-.02em;
}
.page-sub{font-size:.79rem;color:var(--t3);margin-top:3px}

@media(min-width:900px){
  .page-title{font-size:2rem}
  .page-sub{font-size:.85rem}
}

/* ─── CARDS ─────────────────────────────────────────────────── */
.card{
  background:var(--s1);
  border:1px solid var(--s2);
  border-radius:var(--r);
  padding:16px;
  margin-bottom:12px;
  position:relative;overflow:hidden;
  box-shadow:var(--shcard);
}
.card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(40,153,232,.3),transparent);
  opacity:0;transition:opacity var(--tr);
}
.card:hover::after{opacity:1}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.card-title{
  display:flex;align-items:center;gap:6px;
  font-size:.67rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.09em;color:var(--blue2);
}
.card-action{
  font-size:.72rem;font-weight:600;color:var(--blue);
  text-decoration:none;padding:4px 8px;border-radius:6px;
  transition:background var(--tr);
}
.card-action:hover{background:var(--shov)}

@media(min-width:900px){
  .card{padding:22px;margin-bottom:16px;border-radius:18px}
}

/* ─── STATS GRID ────────────────────────────────────────────── */
.stat-row{display:grid;gap:8px;margin-bottom:12px}
.sc4{grid-template-columns:repeat(4,1fr)}
.sc3{grid-template-columns:repeat(3,1fr)}
.sc2{grid-template-columns:repeat(2,1fr)}
.stat-box{
  background:var(--s1);border:1px solid var(--s2);
  border-radius:var(--rsm);padding:14px 10px;text-align:center;
  transition:border-color var(--tr),transform var(--tr);
  box-shadow:var(--shcard);
}
.stat-box:hover{border-color:rgba(26,107,204,.3);transform:translateY(-2px)}
.stat-val{
  display:block;font-family:var(--fh);
  font-size:1.55rem;font-weight:800;line-height:1;
  color:var(--cyan);margin-bottom:2px;
}
.stat-lbl{font-size:.62rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}

@media(min-width:600px){
  .stat-row{gap:12px}
  .stat-val{font-size:1.8rem}
  .stat-box{padding:18px 14px}
}
@media(max-width:399px){
  .sc4{grid-template-columns:repeat(2,1fr)}
  .sc3{grid-template-columns:repeat(3,1fr)}
}

/* ─── BUTTONS ───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  width:100%;padding:13px 18px;
  border:none;border-radius:var(--rsm);
  font-family:var(--fb);font-size:.87rem;font-weight:600;
  cursor:pointer;text-decoration:none;-webkit-appearance:none;outline:none;
  transition:all var(--tr);line-height:1;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shblue)}
.btn-primary:hover{filter:brightness(1.08);box-shadow:0 6px 32px rgba(26,107,204,.55)}
.btn-secondary{background:var(--s1);border:1px solid var(--s2);color:var(--t2)}
.btn-secondary:hover{border-color:rgba(26,107,204,.35);color:var(--t1)}
.btn-ghost{background:transparent;border:1px solid var(--s2);color:var(--t2)}
.btn-ghost:hover{border-color:var(--blue);color:var(--cyan)}
.btn-danger{background:var(--red-bg);border:1px solid rgba(255,75,92,.35);color:var(--red)}
.btn-danger:hover{background:rgba(255,75,92,.18)}
.btn-xs{padding:5px 11px;font-size:.73rem;width:auto;border-radius:var(--rxs)}
.btn-sm{padding:9px 14px;font-size:.8rem;width:auto;border-radius:var(--rxs)}
.btn-auto{width:auto}

/* ─── FORMS ─────────────────────────────────────────────────── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.form-group{margin-bottom:12px}
.form-group.mb-0{margin-bottom:0}
.lbl{
  display:block;font-size:.67rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--t3);margin-bottom:5px;
}
.inp{
  width:100%;padding:11px 13px;
  background:rgba(255,255,255,.04);
  border:1.5px solid rgba(255,255,255,.07);
  border-radius:var(--rxs);
  color:var(--t1);font-family:var(--fb);font-size:.87rem;
  transition:border-color var(--tr),box-shadow var(--tr);
  -webkit-appearance:none;outline:none;
}
.inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,107,204,.14)}
.inp::placeholder{color:var(--t4)}
select.inp{cursor:pointer}
textarea.inp{resize:vertical;min-height:80px}
@media(max-width:479px){.form-row{grid-template-columns:1fr}}

/* ─── PILLS ─────────────────────────────────────────────────── */
.pills{display:flex;gap:7px;flex-wrap:wrap;margin-top:4px}
.pill-btn{
  padding:8px 14px;
  background:var(--s1);border:1.5px solid var(--s2);
  border-radius:50px;color:var(--t2);font-family:var(--fb);
  font-size:.78rem;font-weight:600;
  cursor:pointer;transition:all var(--tr);white-space:nowrap;
  text-decoration:none;display:inline-block;
}
.pill-btn.active,.pill-btn:hover{
  background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 2px 12px rgba(26,107,204,.35);
}

/* ─── BADGES ─────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:50px;
  font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
}
.badge-blue  {background:rgba(26,107,204,.18);color:var(--cyan)}
.badge-green {background:var(--grn-bg);color:var(--grn)}
.badge-red   {background:var(--red-bg);color:var(--red)}
.badge-amber {background:var(--amb-bg);color:var(--amb)}
.badge-muted {background:var(--s1);color:var(--t3)}
.badge-purple{background:var(--pur-bg);color:var(--pur)}

/* ─── MEET ROWS ─────────────────────────────────────────────── */
.meet-row{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:13px 16px;margin:0 -16px;
  border-bottom:1px solid rgba(255,255,255,.04);
  text-decoration:none;color:inherit;
  transition:background var(--tr);
}
.meet-row:last-child{border-bottom:none}
.meet-row:hover{background:var(--shov)}
.meet-row-left{flex:1;min-width:0}
.meet-client{
  font-family:var(--fh);font-size:.9rem;font-weight:700;color:var(--t1);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.meet-company{font-size:.73rem;color:var(--t3);margin:2px 0 6px}
.meet-meta{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.meet-duration{font-size:.62rem;color:var(--t3)}
.meet-row-right{text-align:right;flex-shrink:0;padding-left:10px}
.meet-date-s{font-size:.71rem;font-weight:700;color:var(--t2)}
.meet-time-s{font-size:.62rem;color:var(--t3);margin-bottom:5px}

@media(min-width:900px){
  .meet-row{margin:0;padding:14px 0;border-radius:0}
  .meet-client{font-size:.95rem}
}

/* ─── FOLLOW-UP ROWS ─────────────────────────────────────────── */
.fu-row{
  display:flex;align-items:center;gap:10px;
  padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04);
}
.fu-row:last-child{border-bottom:none}
.fu-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--blue);cursor:pointer;flex-shrink:0}
.fu-info{flex:1;min-width:0}
.fu-client{font-size:.87rem;font-weight:600;color:var(--t1)}
.fu-note{font-size:.72rem;color:var(--t3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fu-due{font-size:.68rem;font-weight:700;padding:4px 10px;border-radius:50px;flex-shrink:0;white-space:nowrap}
.fu-today  {background:var(--amb-bg);color:var(--amb)}
.fu-overdue{background:var(--red-bg);color:var(--red)}
.fu-future {background:var(--grn-bg);color:var(--grn)}
.fu-done   {opacity:.5}

/* ─── RECORDER ──────────────────────────────────────────────── */
.rec-card{
  text-align:center;
  background:linear-gradient(160deg,rgba(26,107,204,.10),rgba(40,153,232,.04));
  border-color:rgba(26,107,204,.28);
  padding:22px 16px;
}
.rec-status{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px}
.rec-dot{width:8px;height:8px;border-radius:50%;transition:background var(--tr)}
.rec-dot.idle   {background:var(--t3)}
.rec-dot.stopped{background:var(--grn)}
.rec-dot.recording{background:var(--red);animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.rec-label{font-size:.72rem;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.08em}
.rec-timer{margin-bottom:18px}
.rec-time{font-family:var(--fh);font-size:3.2rem;font-weight:800;line-height:1;color:var(--t1);letter-spacing:-.03em}
.rec-tlabel{font-size:.6rem;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}
.waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:44px;margin-bottom:22px}
.wave-bar{
  width:4px;height:4px;border-radius:2px;
  background:linear-gradient(180deg,var(--cyan),var(--blue));
  transition:height .08s ease;
  animation:idlew 1.8s ease-in-out infinite;
  animation-delay:var(--delay,0s);
}
@keyframes idlew{0%,100%{height:4px}50%{height:11px}}
body.recording .wave-bar{animation:none}
.rec-btn{
  width:82px;height:82px;border-radius:50%;
  background:var(--grad);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shblue);transition:all var(--tr);margin:0 auto 10px;
}
.rec-btn:hover{transform:scale(1.05);box-shadow:0 6px 32px rgba(26,107,204,.55)}
.rec-btn:active{transform:scale(.96)}
body.recording .rec-btn{background:linear-gradient(135deg,#ff4b5c,#ff7a86);animation:rpulse 1.8s ease-in-out infinite}
@keyframes rpulse{0%,100%{box-shadow:0 4px 24px rgba(255,75,92,.4),0 0 0 0 rgba(255,75,92,.25)}50%{box-shadow:0 4px 24px rgba(255,75,92,.4),0 0 0 16px rgba(255,75,92,0)}}
.rec-btn-inner{display:flex;align-items:center;justify-content:center;color:#fff}
.rec-hint{font-size:.74rem;color:var(--t3)}

/* ─── PROCESSING ─────────────────────────────────────────────── */
.proc-wrap{text-align:center;padding:30px 20px}
.proc-anim{position:relative;width:68px;height:68px;margin:0 auto 18px}
.proc-ring-a,.proc-ring-b{position:absolute;inset:0;border-radius:50%;border:2px solid transparent}
.proc-ring-a{border-top-color:var(--blue);animation:spin 1s linear infinite}
.proc-ring-b{border-bottom-color:var(--cyan);animation:spin 1.5s linear infinite reverse;inset:8px}
@keyframes spin{to{transform:rotate(360deg)}}
.proc-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--cyan)}
.proc-title{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--t1);margin-bottom:4px}
.proc-sub{font-size:.77rem;color:var(--t3);margin-bottom:16px}
.proc-steps{text-align:left}
.proc-step{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.79rem;color:var(--t3);transition:color var(--tr)}
.proc-step:last-child{border-bottom:none}
.step-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:var(--t4);transition:background var(--tr)}
.proc-step.active{color:var(--t2)}
.proc-step.active .step-dot{background:var(--cyan);box-shadow:0 0 8px rgba(91,196,245,.6)}
.proc-step.done{color:var(--grn)}
.proc-step.done .step-dot{background:var(--grn)}

/* ─── SUCCESS ────────────────────────────────────────────────── */
.success-wrap{text-align:center;padding:28px 20px}
.success-ring{
  width:64px;height:64px;border-radius:50%;
  background:var(--grn-bg);border:2px solid rgba(15,218,122,.5);
  display:flex;align-items:center;justify-content:center;
  color:var(--grn);margin:0 auto 14px;
  animation:popin .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popin{from{transform:scale(.4);opacity:0}}
.success-title{font-family:var(--fh);font-size:1.3rem;font-weight:800;color:var(--t1);margin-bottom:4px}
.success-sub{font-size:.79rem;color:var(--t3);margin-bottom:14px}
.meet-ref-badge{
  display:inline-block;padding:5px 14px;
  background:rgba(26,107,204,.15);border:1px solid rgba(26,107,204,.3);
  border-radius:50px;font-size:.77rem;font-weight:700;color:var(--cyan);margin-bottom:14px;
}

/* ─── AUTH ───────────────────────────────────────────────────── */
.auth-outer{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:24px 16px;position:relative;z-index:1;
}
.auth-box{width:100%;max-width:400px}
.auth-title{font-family:var(--fh);font-size:1.5rem;font-weight:800;color:var(--t1);letter-spacing:-.02em;margin-bottom:2px;text-align:center}
.auth-sub{font-size:.74rem;color:var(--t3);margin-bottom:24px;text-align:center}
.auth-card{
  background:var(--s1);border:1px solid var(--s2);
  border-radius:var(--r);padding:22px;
  box-shadow:0 4px 40px rgba(0,0,0,.55);
  position:relative;overflow:hidden;
}
.auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad)}

/* ─── ALERTS ─────────────────────────────────────────────────── */
.alert{padding:10px 13px;border-radius:var(--rxs);font-size:.79rem;font-weight:500;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.alert-error  {background:var(--red-bg);border:1px solid rgba(255,75,92,.3);color:var(--red)}
.alert-warn   {background:var(--amb-bg);border:1px solid rgba(255,184,48,.3);color:var(--amb)}
.alert-success{background:var(--grn-bg);border:1px solid rgba(15,218,122,.3);color:var(--grn)}

/* ─── SEARCH BAR ─────────────────────────────────────────────── */
.search-bar{
  display:flex;align-items:center;gap:10px;
  background:var(--s1);border:1.5px solid var(--s2);
  border-radius:var(--rxs);padding:10px 13px;margin-bottom:10px;
}
.search-bar svg{color:var(--t3);flex-shrink:0}
.search-bar .inp{border:none;background:transparent;padding:0;font-size:.86rem;outline:none}
.search-bar .inp:focus{box-shadow:none}
.search-bar:focus-within{border-color:rgba(26,107,204,.5)}

/* ─── FILTER STRIP ───────────────────────────────────────────── */
.filter-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:10px;scrollbar-width:none}
.filter-strip::-webkit-scrollbar{display:none}
.filter-strip .pill-btn{flex-shrink:0;padding:6px 12px;font-size:.72rem}

/* ─── MODAL ──────────────────────────────────────────────────── */
.modal-bg{
  position:fixed;inset:0;background:rgba(6,13,26,.85);
  backdrop-filter:blur(14px);z-index:500;
  display:flex;align-items:flex-end;justify-content:center;
}
.modal-bg.hidden{display:none}
.modal-sheet{
  background:var(--bg2);border:1px solid var(--s2);
  border-radius:var(--r) var(--r) 0 0;
  padding:20px 18px calc(20px + env(safe-area-inset-bottom,0));
  width:100%;max-width:520px;
  animation:slideup .25s cubic-bezier(.4,0,.2,1);
}
@keyframes slideup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.modal-title{font-family:var(--fh);font-size:1rem;font-weight:700;color:var(--t1)}
.modal-close{background:var(--s1);border:none;color:var(--t2);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:var(--s2)}
@media(min-width:900px){
  .modal-bg{align-items:center}
  .modal-sheet{border-radius:var(--r);max-width:460px;animation:fadein .2s ease}
  @keyframes fadein{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
}

/* ─── EMPTY ──────────────────────────────────────────────────── */
.empty{text-align:center;padding:36px 16px}
.empty-icon{font-size:2.2rem;margin-bottom:10px}
.empty p{font-size:.82rem;color:var(--t3)}

/* ─── MEET DETAIL ────────────────────────────────────────────── */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.detail-chip{background:rgba(255,255,255,.03);border-radius:var(--rxs);padding:10px}
.detail-chip-lbl{font-size:.63rem;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-bottom:2px}
.detail-chip-val{font-size:.83rem;font-weight:600;color:var(--t1)}
.notes-section-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--blue2);margin-bottom:7px;display:flex;align-items:center;gap:5px}
.notes-section-body{font-size:.84rem;line-height:1.72;color:var(--t2);white-space:pre-line}
.notes-block{font-size:.82rem;line-height:1.72;color:var(--t2);white-space:pre-line;padding:13px;background:rgba(255,255,255,.025);border-radius:var(--rxs);border:1px solid var(--s2)}
@media(min-width:600px){.detail-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.detail-grid{grid-template-columns:repeat(4,1fr)}}

/* ─── TABLES (admin) ─────────────────────────────────────────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--rsm);margin-bottom:12px}
.data-table{width:100%;border-collapse:collapse;font-size:.79rem;min-width:500px}
.data-table th,.data-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--s2);white-space:nowrap}
.data-table th{color:var(--blue2);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:rgba(26,107,204,.06)}
.data-table td{color:var(--t2)}
.data-table tr:hover td{background:var(--shov)}
.td-name{font-family:var(--fh);font-weight:600;color:var(--t1);font-size:.82rem}
.td-sub{font-size:.7rem;color:var(--t3);margin-top:2px}

/* ─── PROFILE ────────────────────────────────────────────────── */
.profile-avatar{
  width:72px;height:72px;border-radius:50%;background:var(--grad);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-size:1.7rem;font-weight:800;color:#fff;
  margin:0 auto 10px;box-shadow:var(--shblue);
}
.kv-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--s2)}
.kv-row:last-child{border-bottom:none}
.kv-key{font-size:.8rem;color:var(--t3)}
.kv-val{font-size:.8rem;font-weight:600;color:var(--t1)}

/* ─── DIVIDER / UTILITY ──────────────────────────────────────── */
.hidden{display:none!important}
.txt-center{text-align:center}
.mb-0{margin-bottom:0!important}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.gap-row{display:flex;gap:9px}
.divider{height:1px;background:var(--s2);margin:8px 0}

/* ─── ANIMATIONS ─────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.page-wrap>*{animation:fadeUp .3s ease both}
.page-wrap>*:nth-child(2){animation-delay:.05s}
.page-wrap>*:nth-child(3){animation-delay:.09s}
.page-wrap>*:nth-child(4){animation-delay:.13s}
.page-wrap>*:nth-child(5){animation-delay:.17s}
.page-wrap>*:nth-child(6){animation-delay:.21s}

/* ─── DESKTOP GRID LAYOUTS ───────────────────────────────────── */
@media(min-width:900px){
  .desktop-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
  .desktop-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
  .desktop-sidebar-layout{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
}
