
/* PART 10: final design unification layer
   - 기능/저장키/onclick 변경 없음
   - 기존 CSS 위에 얹는 통일 스타일만 적용
*/
:root{
  --tr-bg:#f6f7fb;
  --tr-card:#ffffff;
  --tr-ink:#172033;
  --tr-muted:#687086;
  --tr-line:#e7eaf2;
  --tr-blue:#2563eb;
  --tr-blue2:#1d4ed8;
  --tr-red:#ef4444;
  --tr-green:#16a34a;
  --tr-gold:#f59e0b;
  --tr-shadow:0 14px 34px rgba(17,24,39,.08);
  --tr-radius:22px;
}
*{box-sizing:border-box}
html{background:var(--tr-bg)}
body{background:var(--tr-bg);color:var(--tr-ink);letter-spacing:-.02em}
body.tkdPremium{background:linear-gradient(135deg,#f8fafc 0%,#eef4ff 45%,#fff7ed 100%)}
a{color:inherit;text-decoration:none}
img,canvas,svg,video{max-width:100%;height:auto}
button,input,select,textarea{font-family:inherit}
button{cursor:pointer}
.container,.wrap,.appWrap,.screen,.page,.pageWrap,.tkd-container{max-width:1180px;margin-left:auto;margin-right:auto}
.card,.panel,.box,.section,.widget,.auditCard,.trLoginPanel,.trLoginHero,[class*="Card"],[class*="card"]{
  border-radius:var(--tr-radius);
  border:1px solid rgba(226,232,240,.9);
  box-shadow:var(--tr-shadow);
}
.card,.panel,.box,.section,.widget,.auditCard,[class*="Card"],[class*="card"]{background:rgba(255,255,255,.94)}
.trLoginScreen{min-height:100svh;display:grid;place-items:center;padding:28px;gap:20px}
.trLoginHero,.trLoginPanel{width:min(960px,100%);backdrop-filter:blur(12px)}
.trLoginHero{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;padding:30px;background:linear-gradient(135deg,#0f172a,#1d4ed8 58%,#f97316);color:#fff}
.trLoginHero h1{margin:.25rem 0;font-size:clamp(36px,6vw,64px);line-height:1;font-weight:900}
.trLoginHero p{margin:0;color:rgba(255,255,255,.82)}
.badge,.trPlatformPill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:7px 12px;font-weight:800;font-size:12px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25)}
.trPlatformPills{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.trLoginPanel{padding:24px;background:rgba(255,255,255,.92)}
.trLoginPanel h2{margin:0 0 6px;font-size:24px}.trLoginPanel p{color:var(--tr-muted);margin-top:0}.trLoginRoles{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.trLoginRole{border:1px solid #dbeafe;background:#fff;border-radius:20px;padding:18px;text-align:left;box-shadow:0 10px 24px rgba(37,99,235,.08);transition:.18s ease}.trLoginRole:hover{transform:translateY(-2px);border-color:#93c5fd;box-shadow:0 16px 34px rgba(37,99,235,.15)}.trLoginRole b{display:block;font-size:20px;margin-bottom:8px}.trLoginRole small{display:block;color:var(--tr-muted);line-height:1.45}.trLoginQuick{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.btn,button,.trLoginQuick a,[class*="btn"],[class*="Btn"]{border-radius:14px;min-height:40px}
.btn,button.primary,.primary,[class*="primary"]{font-weight:800}
input,select,textarea{border:1px solid #d9e2f1;border-radius:14px;padding:12px 13px;background:#fff;color:var(--tr-ink);outline:none}input:focus,select:focus,textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 4px rgba(37,99,235,.10)}textarea{line-height:1.5}
table{width:100%;border-collapse:separate;border-spacing:0}th{color:#475569;background:#f8fafc}td,th{border-bottom:1px solid #eef2f7;padding:10px 12px}tr:last-child td{border-bottom:0}
.grid,.cards,.menuGrid,.dashboardGrid,[class*="grid"],[class*="Grid"]{gap:14px}.screenTitle,h1,h2,h3{letter-spacing:-.04em}.muted,.sub,.desc,small{color:var(--tr-muted)}
.roleBadge,.pill,.chip,.tag,.status,[class*="badge"],[class*="Badge"],[class*="pill"],[class*="Pill"]{border-radius:999px}
nav,.topbar,.header,.appHeader,.pageHeader{backdrop-filter:blur(10px)}
.modal,.popup,.dialog,[role="dialog"]{border-radius:24px;box-shadow:0 24px 80px rgba(15,23,42,.22)}
.scrollX,.tableWrap,.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}::-webkit-scrollbar-track{background:#f1f5f9}
@media (max-width:900px){.trLoginHero{align-items:flex-start;flex-direction:column}.trPlatformPills{justify-content:flex-start}.trLoginRoles{grid-template-columns:repeat(2,minmax(0,1fr))}.container,.wrap,.appWrap,.screen,.page,.pageWrap,.tkd-container{width:100%;padding-left:14px;padding-right:14px}}
@media (max-width:560px){body{font-size:15px}.trLoginScreen{padding:16px}.trLoginHero,.trLoginPanel{padding:20px;border-radius:22px}.trLoginRoles{grid-template-columns:1fr}.trLoginRole{padding:16px}.grid,.cards,.menuGrid,.dashboardGrid,[class*="grid"],[class*="Grid"]{grid-template-columns:1fr!important}.btn,button,input,select,textarea{width:100%;max-width:100%}td,th{white-space:nowrap}.bottomDock,.dock,.navDock{padding-bottom:calc(10px + env(safe-area-inset-bottom))}}
