/*
  The Social Athlete — dark + blue→red gradient theme.
  Inspired by modern bot panels (Rimuru-style). No neon noise, just
  restrained accents over deep black.
*/

:root{
  --bg-0:        #07080f;
  --bg-1:        #0d0f1a;
  --bg-2:        #141726;

  --glass:       rgba(20, 24, 38, .62);
  --glass-2:     rgba(26, 30, 46, .78);
  --border:      rgba(255, 255, 255, .08);
  --border-hi:   rgba(255, 255, 255, .18);

  --txt:         #e9ecf5;
  --txt-muted:   #8a92a5;
  --txt-dim:     #5a6276;

  --blue:        #3b82f6;
  --indigo:      #6366f1;
  --violet:      #8b5cf6;
  --pink:        #e91e63;
  --red:         #ef4444;

  --grad:        linear-gradient(135deg, #2b6eff 0%, #8b5cf6 45%, #ef4444 100%);
  --grad-soft:   linear-gradient(135deg, rgba(43,110,255,.18) 0%, rgba(139,92,246,.18) 45%, rgba(239,68,68,.18) 100%);
  --grad-hover:  linear-gradient(135deg, #3e80ff 0%, #9b70ff 45%, #ff5b5b 100%);

  --shadow-lg:   0 18px 60px rgba(0,0,0,.55);
  --shadow-md:   0 10px 30px rgba(0,0,0,.35);
  --shadow-inset: inset 0 1px 0 rgba(255,255,255,.05);
}

/* ── Reset / base ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text",
              "Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:15px;
  line-height:1.5;
  color:var(--txt);
  background:var(--bg-0);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
button{font:inherit;color:inherit;border:none;background:transparent;cursor:pointer}
input,textarea,select{font:inherit;color:inherit}
a{color:inherit}
.hidden{display:none !important}
.muted{color:var(--txt-muted)}
.error-msg{color:#ff8a8a;margin-top:.8rem;font-size:.9rem}
code{
  font-family:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  background:rgba(255,255,255,.06);
  padding:.12em .4em;border-radius:6px;font-size:.9em;
  border:1px solid rgba(255,255,255,.05);
}

/* ── Ambient background (bluish-left, reddish-right glow on black) ─ */
.bg{
  position:fixed;inset:0;z-index:-1;overflow:hidden;
  background:
    radial-gradient(1100px 700px at 15% -10%, rgba(43,110,255,.22), transparent 60%),
    radial-gradient(900px 700px at 100% 110%, rgba(239,68,68,.18), transparent 60%),
    radial-gradient(700px 600px at 50% 50%, rgba(139,92,246,.08), transparent 70%),
    var(--bg-0);
}
.bg-blob{
  position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;
  animation:drift 28s ease-in-out infinite alternate;
}
.bg-blob-1{width:560px;height:560px;left:-120px;top:-120px;
  background:radial-gradient(circle,#2b6eff 0%,transparent 70%);}
.bg-blob-2{width:620px;height:620px;right:-160px;top:30vh;
  background:radial-gradient(circle,#ef4444 0%,transparent 70%);
  animation-duration:34s;animation-delay:-10s;}
.bg-blob-3{width:480px;height:480px;left:40vw;bottom:-140px;
  background:radial-gradient(circle,#8b5cf6 0%,transparent 70%);
  animation-duration:38s;animation-delay:-6s;}
@keyframes drift{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-30px) scale(1.06)}
  100%{transform:translate(-30px,40px) scale(.96)}
}

/* ── Glass surfaces ──────────────────────────────────────────────── */
.glass{
  background:var(--glass);
  -webkit-backdrop-filter:saturate(160%) blur(22px);
  backdrop-filter:saturate(160%) blur(22px);
  border:1px solid var(--border);
  box-shadow:var(--shadow-md),var(--shadow-inset);
  border-radius:22px;
}
.glass-sm{
  background:var(--glass-2);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  backdrop-filter:saturate(160%) blur(14px);
  border:1px solid var(--border);
  border-radius:16px;
}

/* ── Login view ──────────────────────────────────────────────────── */
.view{min-height:100vh;display:flex;flex-direction:column}
.login-view{align-items:center;justify-content:center;padding:2rem}
.login-card{
  max-width:460px;width:100%;padding:2.6rem 2rem 2.2rem;text-align:center;
  position:relative;overflow:hidden;
}
.login-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.55;pointer-events:none;
}
.brand-mark{
  font-size:2.8rem;line-height:1;margin-bottom:.5rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 4px 14px rgba(139,92,246,.35));
}
.brand-mark-sm{
  font-size:1.3rem;margin-right:.5rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.brand{
  margin:0 0 .4rem;font-size:1.9rem;font-weight:700;letter-spacing:-.02em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.tg-slot{min-height:44px;margin:1.4rem 0 .8rem;display:flex;justify-content:center}
.fine-print{font-size:.82rem;margin-top:1.2rem}

/* ── Topbar with grid: [brand] [centered nav] [user] ─────────────── */
.app-view{min-height:100vh}
.topbar{
  position:sticky;top:.75rem;z-index:50;
  margin:.75rem auto;
  max-width:calc(100% - 2.5rem);
  display:grid;
  grid-template-columns:minmax(180px,1fr) auto minmax(180px,1fr);
  align-items:center;gap:1rem;
  padding:.55rem .85rem;
}
.topbar-brand{
  display:flex;align-items:center;gap:.55rem;
  font-weight:600;font-size:1rem;
  white-space:nowrap;padding:0 .4rem;
}
#back-btn{padding:.38rem .85rem;font-size:.84rem}
.topbar-nav{
  display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;
  max-width:min(1100px, 90vw);
}
.topbar-user{
  display:flex;align-items:center;gap:.6rem;justify-content:flex-end;
}
.avatar{
  width:30px;height:30px;border-radius:50%;object-fit:cover;
  border:1.5px solid transparent;
  background:
    linear-gradient(var(--bg-1),var(--bg-1)) padding-box,
    var(--grad) border-box;
}
.user-name{
  font-size:.9rem;color:var(--txt);max-width:140px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* ── Pills / buttons ─────────────────────────────────────────────── */
.pill{
  padding:.48rem 1.05rem;border-radius:999px;
  background:rgba(255,255,255,.05);
  color:var(--txt);
  border:1px solid var(--border);
  font-size:.89rem;font-weight:500;
  transition:transform .15s ease,background .18s ease,
             border-color .18s ease,box-shadow .18s ease,color .18s ease;
  white-space:nowrap;
}
.pill:hover{
  background:rgba(255,255,255,.09);border-color:var(--border-hi);
  transform:translateY(-1px);
}
.pill.active{
  background:linear-gradient(135deg,rgba(43,110,255,.18),rgba(139,92,246,.18) 55%,rgba(231,80,92,.14));
  color:#fff;
  border-color:rgba(139,92,246,.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.10),
    0 0 0 1px rgba(139,92,246,.25),
    0 6px 18px rgba(43,110,255,.22);
}
.pill.active:hover{
  background:linear-gradient(135deg,rgba(43,110,255,.26),rgba(139,92,246,.24) 55%,rgba(231,80,92,.18));
  border-color:rgba(139,92,246,.6);
  transform:translateY(-1px);
}
.pill-primary{
  background:var(--grad);color:#fff;border-color:transparent;
  box-shadow:0 8px 22px rgba(59,130,246,.3);
}
.pill-primary:hover{background:var(--grad-hover)}
.pill-danger{
  background:rgba(239,68,68,.1);color:#ff7a7a;
  border-color:rgba(239,68,68,.22);
}
.pill-danger:hover{background:rgba(239,68,68,.18)}
.pill-ghost{background:transparent;border-color:rgba(255,255,255,.12)}

/* ── Content layout ──────────────────────────────────────────────── */
.content{padding:1rem 1rem 4rem;max-width:1200px;margin:0 auto;width:100%}

/* Gentle fade+slide-in when a route renders. Reapplied from JS by
   removing & re-adding the .route-in class; layout reflow between
   toggles restarts the keyframes. */
.route-in{animation:route-in .28s cubic-bezier(.2,.7,.3,1)}
@keyframes route-in{
  from{opacity:0;transform:translateY(8px)}
  to  {opacity:1;transform:translateY(0)}
}
.card, .kpi, .list-item{animation:card-in .32s cubic-bezier(.2,.7,.3,1) both}
@keyframes card-in{
  from{opacity:0;transform:translateY(6px) scale(.995)}
  to  {opacity:1;transform:translateY(0) scale(1)}
}
/* Respect user preference */
@media (prefers-reduced-motion: reduce){
  .route-in,.card,.kpi,.list-item{animation:none}
}
.page-title{
  margin:.5rem .5rem 1rem;font-size:1.55rem;font-weight:700;letter-spacing:-.015em;
}
.page-subtitle{margin:-.5rem .5rem 1.3rem;color:var(--txt-muted);font-size:.94rem}

.grid{display:grid;gap:1rem;margin-bottom:1.25rem}
.grid-services{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
/* Section headings that immediately follow a grid need breathing room */
.content h2.page-title{margin-top:1.4rem}
.content h2.page-title:first-child{margin-top:0}

.card{
  padding:1.25rem 1.2rem;display:flex;flex-direction:column;gap:.7rem;
  position:relative;overflow:hidden;
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:var(--grad-soft);opacity:0;transition:opacity .25s ease;
  pointer-events:none;
}
.card.clickable{cursor:pointer}
.card.clickable:hover{
  transform:translateY(-3px);
  border-color:var(--border-hi);
  box-shadow:var(--shadow-lg),var(--shadow-inset);
}
.card.clickable:hover::after{opacity:.5}
.card > *{position:relative;z-index:1}
.card-title{
  display:flex;align-items:center;gap:.55rem;
  font-weight:600;font-size:1.04rem;letter-spacing:-.005em;
}
.card-emoji{font-size:1.3rem}
.card-desc{color:var(--txt-muted);font-size:.9rem;margin:0}

/* ── Forms ───────────────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:.85rem}
.form label{font-size:.82rem;font-weight:500;color:var(--txt-muted);margin-bottom:.2rem}
.input,.textarea,.select{
  width:100%;padding:.78rem 1rem;border-radius:14px;
  background:rgba(255,255,255,.04);
  color:var(--txt);
  border:1px solid var(--border);
  transition:border-color .15s,box-shadow .15s,background .15s;
  outline:none;font-family:inherit;
}
.input::placeholder,.textarea::placeholder{color:var(--txt-dim)}
.textarea{
  min-height:150px;resize:vertical;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:.92rem;
}
.input:focus,.textarea:focus,.select:focus{
  border-color:var(--violet);background:rgba(255,255,255,.06);
  box-shadow:0 0 0 4px rgba(139,92,246,.18);
}
/* Compact variant — for dense filter bars */
.filters-row{display:flex;gap:.45rem;flex-wrap:wrap;align-items:center;margin-bottom:.7rem}
.filters-row .input,
.filters-row .select,
.filters-row .btn{
  padding:.42rem .7rem;font-size:.82rem;border-radius:10px;
}
.filters-row .input{max-width:200px}
.filters-row .select{max-width:170px}
.filters-row input[type="date"]{max-width:140px}
/* Dropdown <option> — Firefox/Chrome render the open menu with the OS renderer,
   so without this the items appear white-on-white. */
.select option,
select option{
  background:#15162b;
  color:#eaeaea;
}
.select option:checked,
select option:checked,
.select option:hover,
select option:hover{
  background:#2b1f55;
  color:#fff;
}
.row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.row-end{display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}
.btn{
  padding:.66rem 1.15rem;border-radius:12px;font-weight:500;font-size:.92rem;
  background:rgba(255,255,255,.05);color:var(--txt);
  border:1px solid var(--border);
  transition:background .18s,transform .15s,border-color .18s,box-shadow .18s;
}
.btn:hover{background:rgba(255,255,255,.09);border-color:var(--border-hi);
  transform:translateY(-1px)}
.btn-primary{
  background:var(--grad);color:#fff;border-color:transparent;
  box-shadow:0 8px 24px rgba(59,130,246,.28);
}
.btn-primary:hover{background:var(--grad-hover);transform:translateY(-1px)}
.btn:disabled{opacity:.5;pointer-events:none}

/* ── Results / tables ────────────────────────────────────────────── */
.summary{display:flex;gap:.6rem;flex-wrap:wrap;margin:1rem 0}
.chip{
  padding:.4rem .85rem;border-radius:999px;font-size:.85rem;font-weight:500;
  background:rgba(255,255,255,.05);color:var(--txt);
  border:1px solid var(--border);
}
.chip-ok{background:rgba(40,200,130,.12);color:#6fe3ad;
  border-color:rgba(40,200,130,.24)}
.chip-err{background:rgba(239,68,68,.12);color:#ff8f8f;
  border-color:rgba(239,68,68,.26)}
.chip-dup{background:rgba(139,92,246,.14);color:#bca7ff;
  border-color:rgba(139,92,246,.28)}

.list{display:flex;flex-direction:column;gap:.4rem;margin-top:.6rem}
.list-item{
  display:grid;grid-template-columns:auto 1fr auto;gap:.8rem;align-items:center;
  padding:.6rem .9rem;border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  font-size:.92rem;
}
.list-item.ok{background:rgba(40,200,130,.08);border-color:rgba(40,200,130,.2)}
.list-item.err{background:rgba(239,68,68,.07);border-color:rgba(239,68,68,.2)}
.list-item.dup{background:rgba(139,92,246,.07);border-color:rgba(139,92,246,.2)}
.list-item code{background:rgba(0,0,0,.3)}
.status-ico{font-weight:600;font-size:.95rem}

.table-wrap{overflow-x:auto;border-radius:18px}
.table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:520px}
.table th,.table td{padding:.6rem .85rem;text-align:left}
.table th{
  font-weight:600;color:var(--txt-muted);
  background:rgba(255,255,255,.03);
  text-transform:uppercase;font-size:.76rem;letter-spacing:.05em;
}
.table tr{border-top:1px solid var(--border)}
.table tbody tr:hover{background:rgba(255,255,255,.03)}

/* ── Toasts ──────────────────────────────────────────────────────── */
.toast-root{position:fixed;bottom:1.2rem;right:1.2rem;display:flex;
  flex-direction:column;gap:.6rem;z-index:1000;max-width:360px;pointer-events:none}
.toast{
  pointer-events:auto;
  padding:.75rem 1rem;border-radius:14px;
  background:rgba(18,20,30,.92);color:#fff;
  border:1px solid var(--border);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  font-size:.9rem;box-shadow:var(--shadow-lg);
  animation:toast-in .22s ease-out;
}
.toast.ok{background:linear-gradient(135deg,rgba(20,30,22,.94),rgba(40,120,80,.85));
  border-color:rgba(40,200,130,.35)}
.toast.err{background:linear-gradient(135deg,rgba(30,18,20,.94),rgba(170,40,40,.85));
  border-color:rgba(239,68,68,.4)}
@keyframes toast-in{from{transform:translateY(10px);opacity:0}
                    to{transform:translateY(0);opacity:1}}

/* ── Breadcrumbs ─────────────────────────────────────────────────── */
.breadcrumbs{display:flex;gap:.35rem;margin:0 .5rem 1rem;
  font-size:.88rem;color:var(--txt-muted);flex-wrap:wrap;align-items:center}
.breadcrumbs button{
  background:none;padding:0;color:var(--txt);
  text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:rgba(255,255,255,.25);
  transition:color .15s ease,text-decoration-color .15s ease;
}
.breadcrumbs button:hover{
  color:#fff;
  text-decoration-color:rgba(255,255,255,.6);
}
.breadcrumbs .sep{opacity:.5}

/* ── Stats KPI ───────────────────────────────────────────────────── */
.kpi-grid{display:grid;gap:.7rem;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:1rem}
.kpi{
  padding:1rem 1.1rem;border-radius:18px;
  background:var(--glass);
  border:1px solid var(--border);
  position:relative;overflow:hidden;
}
.kpi::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.15;pointer-events:none;
}
.kpi-label{font-size:.74rem;color:var(--txt-muted);text-transform:uppercase;
  letter-spacing:.08em;font-weight:500}
.kpi-value{font-size:1.5rem;font-weight:700;margin-top:.25rem;letter-spacing:-.01em}

.progress{height:5px;border-radius:999px;background:rgba(255,255,255,.05);
  overflow:hidden;margin-top:.55rem}
.progress-bar{
  height:100%;
  background:linear-gradient(90deg,#3b82f6 0%,#a855f7 55%,#ef4444 100%);
  opacity:.85;
  border-radius:999px;
}

/* ── Autofill fix (Chromium paints yellow on dark) ───────────────── */
input:-webkit-autofill,
textarea:-webkit-autofill{
  -webkit-box-shadow:0 0 0 1000px var(--bg-1) inset !important;
  -webkit-text-fill-color:var(--txt) !important;
  caret-color:var(--txt);
  transition:background-color 5000s ease-in-out 0s;
}

/* ── Selection ───────────────────────────────────────────────────── */
::selection{background:rgba(139,92,246,.35);color:#fff}

/* ── Scrollbar (webkit) ──────────────────────────────────────────── */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,.08);border-radius:999px;
  border:2px solid transparent;background-clip:padding-box;
}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.14);
  background-clip:padding-box;border:2px solid transparent}

/* ── Responsive ──────────────────────────────────────────────────── */
/* Tablet & below — stack the three topbar regions, but keep things tight */
@media (max-width:900px){
  .topbar{
    grid-template-columns:1fr;
    gap:.55rem;
    padding:.55rem .7rem;
  }
  .topbar-brand{
    justify-content:center;font-size:.95rem;padding:0;
    flex-wrap:wrap;row-gap:.35rem;
  }
  .topbar-nav{
    justify-content:center;
    gap:.35rem;
    max-width:100%;width:100%;
  }
  .topbar-nav .pill{
    padding:.42rem .75rem;
    font-size:.82rem;
  }
  .topbar-user{justify-content:center;gap:.45rem;flex-wrap:wrap}
  .user-name{max-width:220px;font-size:.85rem}
  #back-btn{padding:.32rem .7rem;font-size:.78rem}
}
/* Phones — shrink to fit, hide the name (avatar still shown) */
@media (max-width:520px){
  .topbar{
    margin:.5rem auto;
    max-width:calc(100% - 1rem);
    padding:.5rem .55rem;
    border-radius:18px;
    top:.5rem;
  }
  .topbar-brand{font-size:.88rem;gap:.4rem}
  .topbar-nav{
    gap:.3rem;
    /* Even rows: let pills grow so they line up instead of orphaning one */
  }
  .topbar-nav .pill{
    padding:.4rem .65rem;
    font-size:.78rem;
    flex:1 1 auto;
    min-width:max-content;
    text-align:center;
  }
  .topbar-user .pill{padding:.4rem .75rem;font-size:.8rem}
  .user-name{display:none}
  .avatar{width:26px;height:26px}
  #back-btn{padding:.3rem .6rem;font-size:.74rem}

  .page-title{font-size:1.25rem}
  .brand{font-size:1.6rem}
  .content{padding:.7rem .7rem 3rem}
}
/* Ultra-narrow (older Android, folded devices) — hide the wordmark */
@media (max-width:380px){
  .topbar-brand > span:not(.brand-mark-sm){display:none}
  .topbar-nav .pill{padding:.38rem .55rem;font-size:.75rem}
}
