/* ============================================================
   DTPS — app screens (auth, onboarding, profile, inbox, panels)
   Extends dtps.css. Same black & white system.
   ============================================================ */

/* ---------- centered auth shell ---------- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:calc(var(--nav-h) + 40px) 24px 60px;position:relative;overflow:hidden}
.auth-bg{position:absolute;inset:0;background-image:linear-gradient(var(--gray-1) 1px,transparent 1px),linear-gradient(90deg,var(--gray-1) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse 70% 70% at 50% 40%,#000,transparent 70%);opacity:.5;pointer-events:none}
.auth-card{width:100%;max-width:440px;position:relative;z-index:2}
.auth-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gray-5);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.auth-eyebrow .dot{width:7px;height:7px;background:var(--ink);border-radius:50%}
.auth-title{font-family:var(--disp);font-weight:900;font-size:clamp(40px,9vw,68px);letter-spacing:-0.04em;line-height:0.85;margin-bottom:14px}
.auth-sub{font-size:15px;color:var(--gray-7);line-height:1.5;margin-bottom:34px}

/* ---------- forms ---------- */
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-5);margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--body);font-size:16px;padding:15px 16px;
  border:2px solid var(--ink);background:var(--paper);color:var(--ink);
  transition:background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;background:var(--gray-1)}
.field textarea{resize:vertical;min-height:90px;font-family:var(--body)}
.field .hint{font-family:var(--mono);font-size:10px;color:var(--gray-5);margin-top:7px;letter-spacing:0.03em}
.field-error{font-family:var(--mono);font-size:12px;color:var(--ink);background:var(--gray-1);border-left:2px solid var(--ink);padding:11px 14px;margin-bottom:20px;letter-spacing:0.02em}
.btn-full{width:100%;text-align:center}
.btn-block{display:block;width:100%;text-align:center;border:none}

.auth-foot{margin-top:24px;font-family:var(--mono);font-size:12px;color:var(--gray-5);letter-spacing:0.03em;text-align:center}
.auth-foot a{color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:1px}

/* ---------- onboarding ---------- */
.ob-shell{min-height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}
.ob-bg{position:absolute;inset:0;background-image:linear-gradient(var(--gray-1) 1px,transparent 1px),linear-gradient(90deg,var(--gray-1) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000,transparent 75%);opacity:.4;pointer-events:none}
.ob-top{padding:30px 40px;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:2}
.ob-logo{font-family:var(--disp);font-weight:900;font-size:24px;letter-spacing:-0.03em}
.ob-progress{display:flex;gap:8px}
.ob-progress .dot{width:34px;height:3px;background:var(--gray-3);transition:background .4s}
.ob-progress .dot.active{background:var(--ink)}
.ob-progress .dot.done{background:var(--ink)}
.ob-main{flex:1;display:flex;align-items:center;justify-content:center;padding:20px 24px 60px;position:relative;z-index:2}
.ob-step{width:100%;max-width:520px;opacity:0;transform:translateY(30px);transition:opacity .6s var(--ease),transform .6s var(--ease);position:absolute;pointer-events:none}
.ob-step.active{opacity:1;transform:none;position:relative;pointer-events:auto}
.ob-stepnum{font-family:var(--mono);font-size:12px;letter-spacing:0.25em;text-transform:uppercase;color:var(--gray-5);margin-bottom:16px}
.ob-q{font-family:var(--disp);font-weight:800;font-size:clamp(30px,5.5vw,52px);letter-spacing:-0.03em;line-height:0.95;margin-bottom:14px}
.ob-help{font-size:15px;color:var(--gray-7);line-height:1.5;margin-bottom:30px;max-width:420px}
.ob-actions{display:flex;gap:14px;margin-top:30px;align-items:center}
.ob-back{font-family:var(--mono);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gray-5);background:none;border:none;padding:10px 0;transition:color .3s}
.ob-back:hover{color:var(--ink)}

/* choice tiles */
.choice-grid{display:grid;gap:12px}
.choice-grid.two{grid-template-columns:1fr 1fr}
.choice-grid.three{grid-template-columns:1fr 1fr 1fr}
.choice{border:2px solid var(--ink);background:var(--paper);padding:22px 20px;cursor:pointer;text-align:left;transition:background .25s var(--ease-sharp),color .25s;position:relative}
.choice:hover{background:var(--gray-1)}
.choice.selected{background:var(--ink);color:var(--paper)}
.choice .c-title{font-family:var(--disp);font-weight:700;font-size:19px;letter-spacing:-0.02em;line-height:1}
.choice .c-desc{font-size:12.5px;color:var(--gray-7);margin-top:8px;line-height:1.4}
.choice.selected .c-desc{color:var(--gray-3)}

/* welcome finish */
.ob-welcome{position:fixed;inset:0;z-index:1000;background:var(--ink);color:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .6s,visibility .6s}
.ob-welcome.show{opacity:1;visibility:visible}
.ob-welcome .wlabel{font-family:var(--mono);font-size:13px;letter-spacing:0.5em;text-transform:uppercase;color:var(--gray-5);margin-bottom:24px;opacity:0;transform:translateY(20px)}
.ob-welcome.show .wlabel{animation:wIn .7s var(--ease) .3s forwards}
.ob-welcome .wname{font-family:var(--disp);font-weight:900;font-size:clamp(48px,12vw,150px);letter-spacing:-0.05em;line-height:0.85;text-align:center;opacity:0;transform:scale(1.3);filter:blur(10px)}
.ob-welcome.show .wname{animation:wName .8s var(--ease-sharp) .6s forwards}
.ob-welcome .wsub{font-family:var(--mono);font-size:12px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gray-5);margin-top:30px;opacity:0}
.ob-welcome.show .wsub{animation:wIn .7s var(--ease) 1.3s forwards}
@keyframes wIn{to{opacity:1;transform:none}}
@keyframes wName{to{opacity:1;transform:scale(1);filter:blur(0)}}

/* ---------- generic page container for app screens ---------- */
.app-page{padding:calc(var(--nav-h) + 70px) 40px 100px;max-width:1100px;margin:0 auto;min-height:100vh}
.app-head{margin-bottom:48px}
.app-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gray-5);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.app-eyebrow .dot{width:7px;height:7px;background:var(--ink);border-radius:50%}
.app-title{font-family:var(--disp);font-weight:900;font-size:clamp(40px,8vw,92px);letter-spacing:-0.04em;line-height:0.85}
.app-title .outline{-webkit-text-stroke:2px var(--ink);-webkit-text-fill-color:transparent}

/* cards / panels */
.panel{border:2px solid var(--line);margin-bottom:28px}
.panel-head{background:var(--ink);color:var(--paper);padding:18px 24px;font-family:var(--mono);font-size:11px;letter-spacing:0.15em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}
.panel-body{padding:28px 24px}
.panel-body.tight{padding:0}

/* profile header */
.prof-top{display:flex;gap:30px;align-items:center;margin-bottom:40px;flex-wrap:wrap}
.prof-avatar{width:120px;height:120px;border:2px solid var(--ink);background:var(--gray-1);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.prof-avatar img{width:100%;height:100%;object-fit:cover}
.prof-avatar .ph{font-family:var(--disp);font-weight:900;font-size:54px;color:var(--paper);-webkit-text-stroke:2px var(--gray-3);-webkit-text-fill-color:transparent}
.prof-id .pid-name{font-family:var(--disp);font-weight:900;font-size:clamp(32px,6vw,56px);letter-spacing:-0.03em;line-height:0.9}
.prof-id .pid-ign{font-family:var(--mono);font-size:13px;letter-spacing:0.1em;color:var(--gray-5);margin-top:10px;text-transform:uppercase}
.prof-meta{display:flex;gap:1px;background:var(--line);border:2px solid var(--line);margin-bottom:28px;flex-wrap:wrap}
.prof-meta .pm{background:var(--paper);padding:18px 22px;flex:1;min-width:120px}
.prof-meta .pm .k{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-5);margin-bottom:8px}
.prof-meta .pm .v{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:-0.02em}

/* disciplinary chips (public = type only) */
.disc-list{display:flex;flex-wrap:wrap;gap:8px}
.disc-chip{font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;border:1.5px solid var(--ink);padding:8px 13px;display:flex;gap:8px;align-items:center}
.disc-chip .date{color:var(--gray-5);font-size:10px}
.disc-empty{font-family:var(--mono);font-size:12px;color:var(--gray-5);letter-spacing:0.03em}

/* roster rows (team page + edit) */
.roster-rows{display:flex;flex-direction:column}
.rrow{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--gray-1)}
.rrow:last-child{border-bottom:none}
.rrow .ravatar{width:46px;height:46px;border:1.5px solid var(--ink);background:var(--gray-1);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.rrow .ravatar img{width:100%;height:100%;object-fit:cover}
.rrow .ravatar .ph{font-family:var(--disp);font-weight:900;font-size:18px;color:var(--paper);-webkit-text-stroke:1.5px var(--gray-3);-webkit-text-fill-color:transparent}
.rrow .rinfo{flex:1;min-width:0}
.rrow .rname{font-family:var(--disp);font-weight:700;font-size:18px;letter-spacing:-0.01em}
.rrow .rsub{font-family:var(--mono);font-size:11px;color:var(--gray-5);letter-spacing:0.05em;margin-top:3px}
.rrow .rtag{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:5px 10px;border:1px solid var(--ink)}
.rrow .rtag.cap{background:var(--ink);color:var(--paper)}
.rrow-actions{display:flex;gap:8px}

/* small buttons */
.mini{font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;padding:9px 14px;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);transition:.25s var(--ease-sharp)}
.mini:hover{background:var(--ink);color:var(--paper)}
.mini.solid{background:var(--ink);color:var(--paper)}
.mini.solid:hover{background:var(--paper);color:var(--ink)}

/* inbox */
.msg{border:2px solid var(--line);margin-bottom:12px;padding:20px 22px;transition:background .25s}
.msg.unread{background:var(--gray-1)}
.msg-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.msg-kind{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:4px 9px;border:1px solid var(--ink)}
.msg-date{font-family:var(--mono);font-size:10px;color:var(--gray-5)}
.msg-subject{font-family:var(--disp);font-weight:700;font-size:18px;letter-spacing:-0.01em;margin-bottom:6px}
.msg-body{font-size:14px;color:var(--gray-7);line-height:1.5}
.msg-actions{display:flex;gap:10px;margin-top:16px}

/* tabs (staff/admin panels) */
.tabs{display:flex;gap:0;border:2px solid var(--ink);margin-bottom:32px;max-width:560px}
.tab{flex:1;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:15px;background:var(--paper);color:var(--ink);border:none;border-right:2px solid var(--ink);cursor:pointer;transition:.2s}
.tab:last-child{border-right:none}
.tab.active{background:var(--ink);color:var(--paper)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* data table */
.dtable{width:100%;border-collapse:collapse;border:2px solid var(--line)}
.dtable th{background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;text-align:left;padding:14px 16px;font-weight:400}
.dtable td{padding:14px 16px;border-bottom:1px solid var(--gray-1);font-size:14px;vertical-align:middle}
.dtable tr:last-child td{border-bottom:none}
.dtable tr:hover td{background:var(--gray-1)}
.dtable .mono{font-family:var(--mono);font-size:12px}

/* inline form row */
.form-row{display:grid;gap:16px;margin-bottom:20px}
.form-row.two{grid-template-columns:1fr 1fr}
.form-row.three{grid-template-columns:1fr 1fr 1fr}

/* search result list */
.result-list{border:2px solid var(--line);max-height:280px;overflow-y:auto}
.result-item{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--gray-1);gap:12px}
.result-item:last-child{border-bottom:none}
.result-item .ri-name{font-family:var(--disp);font-weight:700;font-size:16px}
.result-item .ri-sub{font-family:var(--mono);font-size:11px;color:var(--gray-5)}

.empty-state{font-family:var(--mono);font-size:13px;color:var(--gray-5);letter-spacing:0.03em;padding:40px 0;text-align:center}

.notice{font-family:var(--mono);font-size:12px;letter-spacing:0.03em;color:var(--ink);border:1.5px solid var(--ink);padding:14px 16px;margin-bottom:24px;line-height:1.5}
.notice.warn{background:var(--gray-1)}

@media(max-width:768px){
  .app-page{padding:calc(var(--nav-h) + 40px) 20px 70px}
  .form-row.two,.form-row.three{grid-template-columns:1fr}
  .choice-grid.three{grid-template-columns:1fr}
  .prof-top{gap:20px}
  .tabs{max-width:none}
}

/* ---------- live match red pulse (schedule + anywhere) ---------- */
.m-status.live-now{
  color:#FF2020 !important;
  font-weight:700;
  display:inline-flex;align-items:center;gap:8px;
}
.m-status.live-now .live-dot{
  width:9px;height:9px;border-radius:50%;background:#FF2020;
  box-shadow:0 0 0 0 rgba(255,32,32,0.7);
  animation:livePulse 1.4s infinite;
}
@keyframes livePulse{
  0%{box-shadow:0 0 0 0 rgba(255,32,32,0.7);}
  70%{box-shadow:0 0 0 9px rgba(255,32,32,0);}
  100%{box-shadow:0 0 0 0 rgba(255,32,32,0);}
}
a.match{text-decoration:none;color:inherit;cursor:pointer;transition:background .2s}
a.match:hover{background:var(--gray-1)}
a.match.is-live:hover{background:rgba(255,32,32,0.06)}

/* ---------- avatar edit ---------- */
.avatar-edit{display:flex;gap:20px;align-items:center}
.avatar-controls{display:flex;flex-direction:column;gap:8px;align-items:flex-start}

/* ---------- theme picker ---------- */
.theme-group-label{font-family:var(--mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-5);margin:18px 0 12px}
.theme-group-label:first-child{margin-top:0}
.theme-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px}
.theme-card{border:2px solid var(--line);background:var(--paper);padding:14px;cursor:pointer;text-align:left;transition:transform .15s var(--ease-sharp),border-color .2s;color:var(--ink)}
.theme-card:hover{transform:translateY(-2px)}
.theme-card.selected{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.theme-swatch{display:flex;height:34px;border:1px solid var(--line);margin-bottom:10px;overflow:hidden}
.theme-swatch span{flex:1}
.theme-swatch .sw-paper{background:var(--paper)}
.theme-swatch .sw-ink{background:var(--ink)}
.theme-swatch .sw-accent{background:var(--accent)}
.theme-name{font-family:var(--disp);font-weight:700;font-size:16px;letter-spacing:-0.01em}
.theme-desc{font-family:var(--mono);font-size:10px;color:var(--gray-5);margin-top:4px;letter-spacing:0.02em}

/* swatch should show each theme's OWN colors, not the active theme's */
.theme-card[data-theme="default"] .theme-swatch{--paper:#fff;--ink:#0A0A0A;--accent:#0A0A0A}
.theme-card[data-theme="midnight"] .theme-swatch{--paper:#0B0B0E;--ink:#F5F5F7;--accent:#F5F5F7}
.theme-card[data-theme="slate"] .theme-swatch{--paper:#1A1D23;--ink:#E8EBF0;--accent:#5B8DEF}
.theme-card[data-theme="cyber"] .theme-swatch{--paper:#080510;--ink:#E6F9FF;--accent:#00F0FF}
.theme-card[data-theme="sakura"] .theme-swatch{--paper:#FFF5F7;--ink:#3A2730;--accent:#FF6FA5}
.theme-card[data-theme="fragpunk"] .theme-swatch{--paper:#0D0A12;--ink:#FFFFFF;--accent:#FF2D7E}

@media(max-width:680px){ .theme-row{grid-template-columns:1fr 1fr} }
