/* ===== ATP Dashboard — Liquid Glass theme ===== */
:root{
  --ink:#eaf1ff; --ink2:#aebdd6; --muted:#7e8eac;
  --cyan:#34e0e4; --blue:#5b8cff; --violet:#9b7bff;
  --glass:rgba(255,255,255,.055); --glass2:rgba(255,255,255,.09);
  --stroke:rgba(255,255,255,.12); --stroke2:rgba(255,255,255,.22);
  --ok:#34d399; --ok-bg:rgba(52,211,153,.12); --warn:#fbbf24; --warn-bg:rgba(251,191,36,.12);
  --bad:#fb7185; --bad-bg:rgba(251,113,133,.14);
  --grad:linear-gradient(120deg,#34e0e4,#5b8cff 55%,#9b7bff);
  --radius:18px; --shadow:0 10px 40px rgba(2,8,28,.45);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{
  color:var(--ink);
  font:15px/1.6 "IBM Plex Sans",system-ui,sans-serif;-webkit-font-smoothing:antialiased;
  background:#060a16; position:relative; overflow-x:hidden;
}
/* aurora background */
body::before,body::after{content:"";position:fixed;z-index:-2;filter:blur(90px);opacity:.7;border-radius:50%}
body::before{width:60vw;height:60vw;left:-15vw;top:-20vw;
  background:radial-gradient(circle at 30% 30%,#1f6feb88,transparent 60%),radial-gradient(circle at 70% 70%,#34e0e455,transparent 60%);
  animation:float1 22s ease-in-out infinite}
body::after{width:55vw;height:55vw;right:-12vw;bottom:-18vw;
  background:radial-gradient(circle at 60% 40%,#9b7bff66,transparent 60%),radial-gradient(circle at 30% 70%,#e879f944,transparent 60%);
  animation:float2 26s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6vw,4vw) scale(1.08)}}
@keyframes float2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-5vw,-3vw) scale(1.12)}}
.bg-grid{position:fixed;inset:0;z-index:-1;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:46px 46px;mask:radial-gradient(circle at 50% 30%,#000 30%,transparent 80%)}

a{color:var(--cyan);text-decoration:none}
.muted{color:var(--muted)} .small{font-size:12.5px}
.mono{font-family:"IBM Plex Mono",monospace}
h1{font-family:"Sora",sans-serif;font-size:22px;font-weight:600;margin:0;letter-spacing:-.01em}
h3{font-family:"Sora",sans-serif;font-size:14px;font-weight:600;color:var(--ink2);margin:0 0 12px;letter-spacing:.01em}

/* glass primitive */
.glass{background:var(--glass);backdrop-filter:blur(22px) saturate(150%);-webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.08)}

/* shell */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{margin:14px 0 14px 14px;padding:20px 16px;display:flex;flex-direction:column;
  background:var(--glass);backdrop-filter:blur(22px) saturate(150%);-webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid var(--stroke);border-radius:22px;box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.08);
  position:sticky;top:14px;height:calc(100vh - 28px)}
.logo{display:flex;align-items:center;gap:11px;padding:4px 4px 18px;border-bottom:1px solid var(--stroke)}
.logo-mark{width:40px;height:40px;border-radius:12px;background:var(--grad);display:grid;place-items:center;
  font-family:"Sora";font-weight:700;font-size:13px;color:#04122a;letter-spacing:.5px;
  box-shadow:0 6px 18px rgba(52,224,228,.35),inset 0 1px 0 rgba(255,255,255,.5)}
.logo-text{font-family:"Sora";font-weight:600;font-size:14px;line-height:1.2}
.logo-text span{display:block;font-size:11px;color:var(--muted);font-weight:400;font-family:"IBM Plex Sans"}
.side-nav{display:flex;flex-direction:column;gap:4px;margin-top:18px}
.side-nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;color:var(--ink2);font-weight:500;border:1px solid transparent}
.side-nav a .ic{opacity:.8}
.side-nav a:hover{background:var(--glass2);color:#fff}
.side-nav a.active{background:linear-gradient(120deg,rgba(52,224,228,.18),rgba(91,140,255,.16));
  border-color:var(--stroke2);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.side-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--stroke)}
.org{font-size:12.5px;font-weight:600;color:#cfe0fb}

/* topbar */
.content{display:flex;flex-direction:column;min-width:0;padding:14px 18px 30px}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;margin-bottom:18px;
  background:var(--glass);backdrop-filter:blur(22px) saturate(150%);-webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid var(--stroke);border-radius:16px;box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.08);
  position:sticky;top:14px;z-index:5}
.crumb{font-family:"Sora";font-weight:600}
.user{display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--grad);color:#04122a;display:grid;place-items:center;font-weight:700;font-size:13px}
.uname{font-weight:500} .logout{color:var(--ink2);font-size:13px;margin-left:6px}
.logout:hover{color:var(--bad)}
.wrap{max-width:1180px;width:100%}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:22px}
.stat{padding:16px 18px;background:var(--glass);backdrop-filter:blur(22px) saturate(150%);-webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid var(--stroke);border-radius:16px;box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.08);position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;
  background:var(--grad);opacity:.14;filter:blur(8px)}
.stat .k{font-size:12px;color:var(--muted);font-weight:500}
.stat .v{font-family:"Sora";font-size:30px;font-weight:700;margin-top:4px;letter-spacing:-.02em}
.stat.accent .v{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat.warnv .v{color:var(--warn)}

/* cards / forms */
.card{padding:18px;margin-bottom:18px;background:var(--glass);backdrop-filter:blur(22px) saturate(150%);
  -webkit-backdrop-filter:blur(22px) saturate(150%);border:1px solid var(--stroke);border-radius:16px;
  box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.08)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.row.between{justify-content:space-between}
.section-head{display:flex;align-items:center;justify-content:space-between;margin:8px 0 14px}
input,select{font:inherit;color:var(--ink);background:rgba(8,14,30,.5);border:1px solid var(--stroke);
  padding:11px 14px;border-radius:12px}
input::placeholder{color:var(--muted)}
input:focus,select:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(52,224,228,.18)}
input[type=file]{padding:8px;color:var(--ink2)}
button,.btn{font:inherit;font-weight:600;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:7px;
  background:var(--glass2);border:1px solid var(--stroke);padding:11px 16px;border-radius:12px;transition:.15s}
button:hover,.btn:hover{border-color:var(--stroke2);background:rgba(255,255,255,.14);transform:translateY(-1px)}
button.primary,.btn.primary{background:var(--grad);border:none;color:#04122a;box-shadow:0 8px 22px rgba(52,224,228,.3)}
button.primary:hover{filter:brightness(1.05);transform:translateY(-1px)}
button:disabled{opacity:.55;cursor:default;transform:none}

/* project grid */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.pcard{display:block;color:inherit;padding:20px;background:var(--glass);backdrop-filter:blur(22px) saturate(150%);
  -webkit-backdrop-filter:blur(22px) saturate(150%);border:1px solid var(--stroke);border-radius:18px;
  box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.08);transition:.18s;position:relative;overflow:hidden}
.pcard::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--grad);opacity:.8}
.pcard:hover{transform:translateY(-3px);border-color:var(--stroke2);box-shadow:0 18px 50px rgba(52,224,228,.18)}
.pcard .pname{font-family:"Sora";font-size:17px;font-weight:600}
.pcard .pcode{font-size:12px;color:var(--muted);font-family:"IBM Plex Mono";margin-top:3px}
.pcard .pmeta{display:flex;gap:20px;margin:16px 0 14px}
.pcard .pmeta .n{font-family:"Sora";font-size:19px;font-weight:700}
.pcard .pmeta .l{font-size:11px;color:var(--muted)}
.bar{height:8px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.bar>i{display:block;height:100%;background:var(--grad);border-radius:99px;box-shadow:0 0 12px rgba(52,224,228,.5)}
.barline{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:6px}
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:99px}
.pill.warn{background:var(--warn-bg);color:var(--warn);border:1px solid rgba(251,191,36,.3)}
.pill.ok{background:var(--ok-bg);color:var(--ok);border:1px solid rgba(52,211,153,.3)}

.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .big{font-size:42px;opacity:.4}

/* hub/me */
.hub-block .hub-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.hub-code{font-family:"IBM Plex Mono";font-weight:600;color:#cfe0fb}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{background:var(--glass2);border:1px solid var(--stroke);padding:8px 13px;border-radius:10px;font-weight:500;font-size:13px;color:var(--ink)}
.chip:hover{border-color:var(--cyan);color:#fff}
.chipwrap{display:inline-flex;align-items:stretch}
.chipwrap .chip{border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}
.chipwrap form{display:inline-flex}
.chip-x{padding:0 9px;background:var(--glass2);border:1px solid var(--stroke);border-right:none;border-radius:0;
  color:var(--muted);font-size:11px;line-height:1;display:inline-flex;align-items:center;cursor:pointer}
.chipwrap form .chip-x{border-right:1px solid var(--stroke);border-radius:0 10px 10px 0}
.chipwrap > .chip-x:hover{color:var(--cyan);border-color:var(--cyan)}
.chipwrap form .chip-x:hover{color:var(--bad);border-color:var(--bad);background:var(--bad-bg)}
.iconbtn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 7px;border-radius:6px;vertical-align:middle}
.iconbtn:hover{color:var(--cyan);background:var(--glass2)}

/* review */
.review{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}
.pool{display:flex;flex-direction:column;gap:9px;max-height:76vh;overflow:auto;padding:12px;
  background:var(--glass);border:1px solid var(--stroke);border-radius:16px;box-shadow:inset 0 1px 0 rgba(255,255,255,.06);min-height:140px}
.photocard{display:flex;gap:10px;align-items:center;padding:8px;border-radius:12px;cursor:grab;
  background:var(--glass2);border:1px solid var(--stroke)}
.photocard:hover{border-color:var(--cyan)}
.photocard img{width:54px;height:54px;object-fit:cover;border-radius:9px;flex:none}
.photocard b{color:var(--cyan);font-family:"IBM Plex Mono";font-size:15px}
.pmeta2{font-size:11px;display:flex;flex-direction:column;min-width:0;color:var(--ink2)}
.pmeta2 span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slots{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:20px}
.slot{padding:11px 12px;border-radius:14px;min-height:84px;background:var(--glass);border:1px solid var(--stroke);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);transition:.15s}
.slot .slabel{font-size:11px;color:var(--muted);font-weight:600}
.slot .edit{width:100%;margin-top:6px;text-align:center;font-weight:700;font-family:"IBM Plex Mono";background:rgba(8,14,30,.4)}
.slot .sflag{font-size:10px;color:var(--warn);margin-top:5px;min-height:12px;word-break:break-word}
.slot.ok{border-color:rgba(52,211,153,.5);background:var(--ok-bg)} .slot.ok .edit{color:var(--ok)}
.slot.warn{border-color:rgba(251,191,36,.5);background:var(--warn-bg)}
.slot.bad{border-color:rgba(251,113,133,.55);background:var(--bad-bg)} .slot.bad .sflag{color:var(--bad)}
.slot.empty{border-style:dashed;opacity:.75}
.slot.drop{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(52,224,228,.2)}

/* overlay + toast */
.overlay{position:fixed;inset:0;background:rgba(4,8,20,.55);backdrop-filter:blur(6px);display:none;place-items:center;z-index:50}
.overlay.show{display:grid}
.lbox{padding:30px 34px;text-align:center;max-width:360px;background:var(--glass2);backdrop-filter:blur(26px) saturate(160%);
  border:1px solid var(--stroke2);border-radius:20px;box-shadow:var(--shadow)}
.lmsg{margin-top:16px;font-weight:500;color:var(--ink)}
.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.18);border-top-color:var(--cyan);border-radius:50%;margin:0 auto;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);padding:12px 20px;border-radius:13px;
  font-size:13px;font-weight:600;opacity:0;pointer-events:none;transition:.22s;z-index:60;max-width:90vw;
  background:var(--glass2);backdrop-filter:blur(20px);border:1px solid var(--stroke2);box-shadow:var(--shadow);color:#fff}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:rgba(52,211,153,.6)} .toast.warn{border-color:rgba(251,191,36,.6)} .toast.bad{border-color:rgba(251,113,133,.6)}

/* ===== Login hero ===== */
.hero{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.hero-left{position:relative;padding:54px 60px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--ink2);
  background:var(--glass);border:1px solid var(--stroke);padding:7px 13px;border-radius:99px;width:fit-content;backdrop-filter:blur(12px)}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.hero-title{font-family:"Sora";font-size:clamp(34px,5vw,58px);font-weight:700;line-height:1.05;letter-spacing:-.02em;margin:0}
.hero-title .gr{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{color:var(--ink2);font-size:16px;max-width:460px;margin-top:18px;line-height:1.7}
.hero-feats{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px}
.hero-feat{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink2)}
.hero-feat .fi{width:30px;height:30px;border-radius:9px;background:var(--glass2);border:1px solid var(--stroke);display:grid;place-items:center;color:var(--cyan)}
.hero-foot{font-size:12.5px;color:var(--muted)}
.hero-orbit{position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:520px;height:520px;opacity:.5;pointer-events:none}
.hero-right{display:grid;place-items:center;padding:30px}
.login-card{width:100%;max-width:380px;padding:38px 34px;background:var(--glass);backdrop-filter:blur(26px) saturate(160%);
  -webkit-backdrop-filter:blur(26px) saturate(160%);border:1px solid var(--stroke2);border-radius:24px;box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.12)}
.login-card .logo-mark{width:48px;height:48px;border-radius:14px;font-size:15px}
.login-card h2{font-family:"Sora";font-size:22px;margin:16px 0 4px}
.login-card form{display:flex;flex-direction:column;gap:12px;margin-top:22px}
.login-card input{padding:13px 15px}
.err{color:var(--bad);font-size:13px;background:var(--bad-bg);border:1px solid rgba(251,113,133,.3);padding:10px;border-radius:10px}
@media(max-width:900px){
  .shell{grid-template-columns:1fr}.sidebar{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}.review{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr}.hero-left{display:none}
}
