/* ===== HOME PAGE ===== */
.home-page{
  min-height:100vh;
  overflow:hidden;
}

/* split layout */
.home-layout{
  display:flex;
  min-height:100vh;
}

/* ---- LEFT: banner panel ---- */
.home-banner-panel{
  flex:1 1 0;
  position:relative;
  overflow:hidden;
  min-height:100vh;
}
/* ---- Slideshow images ---- */
.home-slide-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform-origin:center center;
  opacity:0;
  /* imgFade: 35s cycle (7 slides × 5s). kenBurns: 24s pan/zoom */
  animation:
    imgFade   35s ease-in-out infinite,
    kenBurns  24s ease-in-out infinite alternate;
}

/* Stagger each slide's fade + desync their kenBurns phase */
/* delay syntax: imgFade-delay, kenBurns-delay */
.home-slide-img:nth-child(1){animation-delay: -1s,    0s;}
.home-slide-img:nth-child(2){animation-delay:  4s,   -3.4s;}
.home-slide-img:nth-child(3){animation-delay:  9s,   -6.8s;}
.home-slide-img:nth-child(4){animation-delay: 14s,  -10.2s;}
.home-slide-img:nth-child(5){animation-delay: 19s,  -13.6s;}
.home-slide-img:nth-child(6){animation-delay: 24s,  -17.0s;}
.home-slide-img:nth-child(7){animation-delay: 29s,  -20.4s;}

@keyframes imgFade{
  /* 0%→2.86% = 1s fade-in | 2.86%→14.28% = 4s visible | 14.28%→17.14% = 1s fade-out */
  0%     {opacity:0;}
  2.86%  {opacity:1;}
  14.28% {opacity:1;}
  17.14% {opacity:0;}
  100%   {opacity:0;}
}
@keyframes kenBurns{
  0%  {transform:scale(1)    translate(0%,   0%);}
  25% {transform:scale(1.07) translate(-1.5%,  1%);}
  50% {transform:scale(1.12) translate( 1.5%, -1%);}
  75% {transform:scale(1.07) translate(-1%,    1.5%);}
  100%{transform:scale(1)    translate(0%,   0%);}
}

/* gradient overlay: fades right edge into white + subtle dark at bottom */
.home-banner-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(to right,  transparent 55%, #f8faff 100%),
    linear-gradient(to top,    rgba(0,0,0,.28) 0%, transparent 35%);
  pointer-events:none;
}

/* caption at bottom-left of banner */
.home-banner-caption{
  position:absolute;
  bottom:28px;
  left:28px;
  right:45%;
  z-index:2;
}
.home-banner-caption span{
  display:inline-block;
  background:rgba(255,255,255,.22);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.4);
  border-radius:999px;
  padding:7px 18px;
  font-size:13px;
  font-weight:600;
  color:#fff;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
  letter-spacing:.03em;
  white-space:nowrap;
}

/* ---- RIGHT: content panel ---- */
.home-content-panel{
  flex:0 0 460px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 32px;
  background:linear-gradient(160deg, #f0f4ff 0%, #f0fdf9 55%, #faf5ff 100%);
  position:relative;
  z-index:1;
}

/* subtle right-panel decoration */
.home-content-panel::before{
  content:'';
  position:absolute;
  width:480px;height:480px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(165,180,252,.3),transparent 70%);
  top:-120px;right:-160px;
  pointer-events:none;
}
.home-content-panel::after{
  content:'';
  position:absolute;
  width:360px;height:360px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(167,243,208,.28),transparent 70%);
  bottom:-100px;left:-100px;
  pointer-events:none;
}

/* title card */
.home-title-card{
  position:relative;
  z-index:1;
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(99,102,241,.16);
  border-radius:28px;
  padding:36px 36px;
  width:100%;
  text-align:center;
  box-shadow:0 8px 40px rgba(99,102,241,.12), inset 0 1px 0 rgba(255,255,255,.9);
  animation:cardRise .8s .1s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes cardRise{
  0%{opacity:0;transform:translateY(36px);}
  100%{opacity:1;transform:translateY(0);}
}

.home-badge{
  display:inline-block;
  background:linear-gradient(90deg,#e0e7ff,#fae8ff);
  border:1px solid rgba(99,102,241,.28);
  border-radius:999px;
  padding:5px 18px;
  font-size:13px;
  color:#4f46e5;
  font-weight:600;
  letter-spacing:.04em;
  margin:0 0 18px;
}

.home-h1{
  margin:0 0 10px;
  font-size:clamp(1.55rem,3.5vw,2.2rem);
  font-weight:800;
  line-height:1.3;
  color:#1e1b4b;
}
.home-en{
  background:linear-gradient(90deg,#6366f1,#a855f7);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  font-style:italic;
}

.home-school{
  margin:0 0 18px;
  font-size:clamp(.95rem,2vw,1.1rem);
  color:#374151;
  font-weight:500;
}

.home-meta{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  margin-bottom:22px;
}
.home-chip{
  background:linear-gradient(90deg,#e0e7ff,#ede9fe);
  border:1px solid rgba(99,102,241,.22);
  border-radius:999px;
  padding:5px 14px;
  font-size:13px;
  color:#3730a3;
  font-weight:500;
}

.home-divider{
  border:none;border-top:1px solid rgba(99,102,241,.15);
  margin:0 0 22px;
}

/* action cards */
.home-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  width:100%;
}
.home-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:18px 10px;
  border-radius:20px;
  text-decoration:none;
  border:1px solid transparent;
  transition:transform .18s, box-shadow .18s;
  cursor:pointer;
}
.home-card:hover{transform:translateY(-5px);}
.home-card-icon{font-size:1.9rem;line-height:1;}
.home-card-title{font-size:14px;font-weight:700;color:#1e1b4b;}
.home-card-desc{font-size:12px;font-weight:500;opacity:.7;color:#374151;}

.home-card--blue{
  background:linear-gradient(145deg,#e0e7ff,#c7d2fe);
  border-color:rgba(99,102,241,.25);
  box-shadow:0 4px 16px rgba(99,102,241,.18);
}
.home-card--blue:hover{box-shadow:0 10px 28px rgba(99,102,241,.32);}
.home-card--blue .home-card-title{color:#3730a3;}

.home-card--green{
  background:linear-gradient(145deg,#d1fae5,#a7f3d0);
  border-color:rgba(16,185,129,.25);
  box-shadow:0 4px 16px rgba(16,185,129,.18);
}
.home-card--green:hover{box-shadow:0 10px 28px rgba(16,185,129,.32);}
.home-card--green .home-card-title{color:#065f46;}
.home-card--green .home-card-desc{color:#047857;}

.home-card--gray{
  background:linear-gradient(145deg,#f1f5f9,#e2e8f0);
  border-color:rgba(148,163,184,.3);
  box-shadow:0 4px 16px rgba(100,116,139,.12);
}
.home-card--gray:hover{box-shadow:0 10px 28px rgba(100,116,139,.22);}
.home-card--gray .home-card-title{color:#1e293b;}

/* responsive */
@media(max-width:860px){
  .home-layout{flex-direction:column;}
  .home-banner-panel{min-height:52vw;max-height:56vh;flex:none;}
  .home-banner-overlay{
    background:
      linear-gradient(to bottom, transparent 60%, #f0f4ff 100%),
      linear-gradient(to top,    rgba(0,0,0,.22) 0%, transparent 35%);
  }
  .home-banner-caption{right:20px;}
  .home-content-panel{flex:none;padding:28px 20px 40px;}
}
@media(max-width:420px){
  .home-cards{grid-template-columns:1fr;}
  .home-card{flex-direction:row;justify-content:flex-start;padding:14px 18px;gap:14px;}
  .home-card-icon{font-size:1.5rem;}
}

/* ===== END HOME PAGE ===== */

:root{
  --bg:#f6f8ff;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --line:rgba(15,23,42,.12);
  --btn:#1d4ed8;
  --btn2:#eff6ff;
  --danger:#b91c1c;
  --ok:#15803d;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans Thai",sans-serif;color:var(--text);background:radial-gradient(1200px 700px at 50% 12%, #dbeafe 0%, var(--bg) 55%, #ffffff 100%)}
.page{min-height:100vh}
.center{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px}
.logo-wrap{display:flex;align-items:center;justify-content:center}
.logo{width:160px;height:160px}
.actions{display:flex;flex-direction:column;gap:12px;width:min(420px, 100%)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid rgba(29,78,216,.25);border-radius:12px;background:linear-gradient(180deg, rgba(29,78,216,.12), rgba(29,78,216,.08));color:var(--text);text-decoration:none;cursor:pointer}
.btn:hover{border-color:rgba(29,78,216,.45);background:linear-gradient(180deg, rgba(29,78,216,.16), rgba(29,78,216,.10))}
.btn.secondary{border-color:var(--line);background:transparent}
.container{max-width:980px;margin:0 auto;padding:20px}
.container.narrow{max-width:520px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.65);backdrop-filter: blur(10px)}
.title{font-weight:600}
.link{color:var(--text);text-decoration:none;opacity:.9}
.link:hover{opacity:1}
.linkbtn{background:none;border:none;color:var(--text);cursor:pointer;opacity:.9;padding:0}
.linkbtn:hover{opacity:1}
.card{background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:16px;padding:16px}
.field{display:flex;flex-direction:column;gap:6px;margin:10px 0}
.field span{color:var(--muted);font-size:14px}
input,select,textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.16);background:rgba(255,255,255,.9);color:var(--text);outline:none}
input:focus,select:focus,textarea:focus{border-color:rgba(29,78,216,.55)}
textarea{resize:vertical}
.row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.alert{padding:10px 12px;border-radius:12px;border:1px solid var(--line);margin-bottom:12px}
.alert.error{background:rgba(185,28,28,.10);border-color:rgba(185,28,28,.25)}
.alert.success{background:rgba(21,128,61,.10);border-color:rgba(21,128,61,.25)}
.hint{color:var(--muted);font-size:13px;margin-top:10px}
.muted{color:var(--muted)}
.table-wrap{overflow:auto}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{color:var(--muted);font-weight:600;white-space:nowrap}
.table tr:hover td{background:rgba(219,234,254,.35)}

.icon-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;text-decoration:none;border:1px solid var(--line);background:rgba(255,255,255,.7)}
.icon-link:hover{border-color:rgba(29,78,216,.25);background:rgba(239,246,255,.9)}

/* staff menu cards */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.menu-card{display:block;text-decoration:none;background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:18px;padding:16px;transition:transform .15s, box-shadow .15s, border-color .15s;color:var(--text)}
.menu-card:hover{transform:translateY(-4px);border-color:rgba(29,78,216,.25);box-shadow:0 14px 34px rgba(2,6,23,.08)}
.menu-icon{font-size:28px;line-height:1;margin-bottom:10px}
.menu-title{font-weight:800;margin-bottom:6px}
.menu-desc{color:var(--muted);font-size:13px}
@media(max-width:860px){.menu-grid{grid-template-columns:1fr}}

/* toast (reuse .alert styles) */
.toast{position:fixed;top:16px;right:16px;z-index:60;max-width:min(420px, calc(100vw - 32px))}

/* ===== DASHBOARD ===== */
.db-page{background:linear-gradient(135deg,#eef2ff 0%,#f0fdf4 50%,#faf5ff 100%);min-height:100vh;display:flex;flex-direction:column}
.db-page>main{flex:1 0 auto}

/* ── Topbar ── */
.db-topbar{display:flex;align-items:center;gap:10px;padding:0 20px;height:60px;min-height:60px;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(99,102,241,.12);position:sticky;top:0;z-index:40;box-shadow:0 1px 16px rgba(79,70,229,.07)}
.db-topbar-left{display:flex;align-items:center;gap:7px;flex-shrink:0}
.db-topbar-back{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:10px;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.18);color:#4f46e5;text-decoration:none;font-size:13px;font-weight:700;transition:background .15s,border-color .15s;cursor:pointer;white-space:nowrap}
.db-topbar-back:hover{background:rgba(99,102,241,.16);border-color:rgba(99,102,241,.38)}
.db-topbar-sep{width:1px;height:22px;background:rgba(15,23,42,.1);margin:0 2px;flex-shrink:0}
.db-topbar-home-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:rgba(99,102,241,.07);border:1px solid rgba(99,102,241,.15);color:#4f46e5;text-decoration:none;font-size:16px;transition:background .15s,border-color .15s;flex-shrink:0}
.db-topbar-home-btn:hover{background:rgba(99,102,241,.16);border-color:rgba(99,102,241,.38)}
.db-topbar-home-link{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:10px;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);color:#4f46e5;text-decoration:none;font-size:13px;font-weight:700;letter-spacing:.02em;transition:background .15s,border-color .15s;white-space:nowrap;flex-shrink:0}
.db-topbar-home-link:hover{background:rgba(99,102,241,.18);border-color:rgba(99,102,241,.45)}
.db-topbar-center{flex:1;min-width:0;text-align:center}
.db-topbar-title{font-size:15px;font-weight:800;color:#1e1b4b;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.db-topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.db-topbar-user{display:flex;flex-direction:column;align-items:flex-end;gap:1px}
.db-topbar-user-name{font-size:12px;font-weight:800;color:#1e1b4b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.db-topbar-user-role{font-size:10.5px;color:#6366f1;font-weight:600;white-space:nowrap}
/* Menu toggle button */
.db-menu-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:10px;background:linear-gradient(135deg,rgba(99,102,241,.09),rgba(168,85,247,.07));border:1px solid rgba(99,102,241,.22);color:#4f46e5;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;white-space:nowrap}
.db-menu-btn:hover{background:linear-gradient(135deg,rgba(99,102,241,.16),rgba(168,85,247,.13));border-color:rgba(99,102,241,.42);box-shadow:0 2px 12px rgba(99,102,241,.14)}
.db-menu-btn[aria-expanded=true]{background:linear-gradient(135deg,rgba(99,102,241,.22),rgba(168,85,247,.18));border-color:rgba(99,102,241,.55)}
.db-menu-btn-icon{font-size:15px;line-height:1;transition:transform .2s}
.db-menu-btn[aria-expanded=true] .db-menu-btn-icon{transform:rotate(90deg)}
/* Overlay */
.db-menu-overlay{display:none;position:fixed;inset:0;z-index:35;background:rgba(2,6,23,.16);backdrop-filter:blur(2px)}
.db-menu-overlay.is-open{display:block}
/* Slide-in panel */
.db-menu-panel{position:fixed;top:60px;right:0;z-index:38;width:min(320px,90vw);height:calc(100vh - 60px);overflow-y:auto;background:rgba(255,255,255,.97);backdrop-filter:blur(24px);border-left:1px solid rgba(99,102,241,.14);box-shadow:-4px 0 40px rgba(79,70,229,.15);padding:14px 10px 28px;transform:translateX(100%);transition:transform .22s cubic-bezier(.4,0,.2,1)}
.db-menu-panel.is-open{transform:translateX(0)}
.db-menu-user-card{display:flex;align-items:center;gap:12px;padding:10px 12px 14px;margin-bottom:6px;border-bottom:1px solid rgba(15,23,42,.07)}
.db-menu-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.db-menu-user-info{min-width:0}
.db-menu-user-name{font-size:13.5px;font-weight:800;color:#1e1b4b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.db-menu-user-role{font-size:11.5px;color:#6366f1;font-weight:600}
.db-menu-group-label{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#94a3b8;padding:8px 12px 4px}
.db-menu-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:11px;text-decoration:none;color:#334155;font-size:13.5px;font-weight:700;transition:background .14s,color .14s;position:relative;border:none;background:none;cursor:pointer;width:100%;text-align:left}
.db-menu-item:hover{background:rgba(99,102,241,.08);color:#1e1b4b}
.db-menu-item.is-active{background:rgba(224,231,255,.95);color:#1e1b4b}
.db-menu-item.is-active::before{content:'';position:absolute;left:0;top:20%;height:60%;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#6366f1,#a855f7)}
.db-menu-item-icon{font-size:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:rgba(99,102,241,.07);flex-shrink:0;transition:background .14s}
.db-menu-item.is-active .db-menu-item-icon{background:rgba(99,102,241,.18)}
.db-menu-item-label{flex:1}
.db-menu-item-check{color:#6366f1;font-size:13px}
.db-menu-divider{height:1px;background:rgba(15,23,42,.07);margin:8px 12px}
.db-menu-logout-item{color:#b91c1c!important}
.db-menu-logout-item:hover{background:rgba(185,28,28,.08)!important}
.db-menu-logout-item .db-menu-item-icon{background:rgba(185,28,28,.08)!important}
/* Footer */
.db-footer{padding:0 24px;margin-top:28px}
.db-footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;border-top:1px solid rgba(99,102,241,.1);padding:14px 0 22px}
.db-footer-brand{font-size:13px;font-weight:800;color:#6366f1;letter-spacing:.02em}
.db-footer-copy{font-size:11.5px;color:#94a3b8;font-weight:600}
@media(max-width:520px){
  .db-topbar{padding:0 12px}
  .db-topbar-user{display:none}
  .db-menu-btn-label{display:none}
  .db-topbar-title{font-size:14px}
}

.db-layout{display:grid;grid-template-columns:280px 1fr;gap:28px;max-width:1100px;margin:0 auto;padding:28px 24px;align-items:start}

/* Profile card */
.db-profile-col{position:sticky;top:72px}
.db-profile-card{background:rgba(255,255,255,.85);border:1px solid rgba(15,23,42,.1);border-radius:24px;padding:28px 22px;text-align:center;box-shadow:0 4px 28px rgba(99,102,241,.08);backdrop-filter:blur(10px)}
.db-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;font-size:30px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:0 4px 18px rgba(99,102,241,.35)}
.db-profile-name{font-size:17px;font-weight:800;color:#1e1b4b;margin-bottom:4px;line-height:1.3}
.db-profile-username{font-size:13px;color:#6366f1;font-weight:500;margin-bottom:12px}
.db-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:5px 14px;font-size:12px;font-weight:700;letter-spacing:.03em;margin-bottom:18px}
.db-badge--admin{background:linear-gradient(90deg,#ede9fe,#e0e7ff);color:#4f46e5;border:1px solid rgba(99,102,241,.25)}
.db-badge--teacher{background:linear-gradient(90deg,#dcfce7,#d1fae5);color:#166534;border:1px solid rgba(22,163,74,.25)}
.db-profile-info{text-align:left;border-top:1px solid rgba(15,23,42,.08);padding-top:14px;margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.db-info-row{display:flex;gap:8px;align-items:flex-start;font-size:13px}
.db-info-label{color:#94a3b8;font-weight:600;min-width:72px;flex-shrink:0}
.db-info-val{color:#334155;word-break:break-all}
.db-info-row--highlight .db-info-label{color:#d97706}
.db-info-row--highlight .db-info-val{color:#92400e;font-weight:600}
.db-edit-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px 14px;border-radius:12px;border:1px solid rgba(99,102,241,.3);background:linear-gradient(180deg,rgba(99,102,241,.1),rgba(99,102,241,.06));color:#4f46e5;text-decoration:none;font-size:14px;font-weight:700;transition:background .15s,border-color .15s}
.db-edit-btn:hover{background:linear-gradient(180deg,rgba(99,102,241,.18),rgba(99,102,241,.1));border-color:rgba(99,102,241,.5)}

/* Section label */
.db-section-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#94a3b8;margin-bottom:12px}

/* Menu grid */
.db-menu-grid{display:flex;flex-direction:column;gap:10px}
.db-menu-card{display:flex;align-items:center;gap:16px;padding:16px 18px;border-radius:18px;text-decoration:none;color:var(--text);border:1px solid transparent;transition:transform .15s,box-shadow .15s;animation:dbCardIn .35s ease both}
.db-menu-card:hover{transform:translateX(4px);box-shadow:0 6px 24px rgba(2,6,23,.1)}
.db-mc-icon{font-size:26px;line-height:1;flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(255,255,255,.6)}
.db-mc-body{flex:1;min-width:0}
.db-mc-title{font-weight:800;font-size:15px;color:#1e1b4b;line-height:1.3;margin-bottom:3px}
.db-mc-desc{font-size:12px;color:#64748b;line-height:1.4}
.db-mc-arrow{font-size:22px;color:rgba(15,23,42,.25);font-weight:300;flex-shrink:0;transition:color .15s}
.db-menu-card:hover .db-mc-arrow{color:rgba(15,23,42,.55)}

.db-card--indigo{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:rgba(99,102,241,.2)}
.db-card--indigo:hover{border-color:rgba(99,102,241,.4)}
.db-card--violet{background:linear-gradient(135deg,#f3e8ff,#ede9fe);border-color:rgba(168,85,247,.2)}
.db-card--violet:hover{border-color:rgba(168,85,247,.4)}
.db-card--green{background:linear-gradient(135deg,#dcfce7,#d1fae5);border-color:rgba(22,163,74,.2)}
.db-card--green:hover{border-color:rgba(22,163,74,.4)}
.db-card--amber{background:linear-gradient(135deg,#fef9c3,#fde68a);border-color:rgba(217,119,6,.2)}
.db-card--amber:hover{border-color:rgba(217,119,6,.4)}
.db-card--blue{background:linear-gradient(135deg,#dbeafe,#e0e7ff);border-color:rgba(59,130,246,.2)}
.db-card--blue:hover{border-color:rgba(59,130,246,.4)}
.db-card--gold{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:rgba(245,158,11,.2)}
.db-card--gold:hover{border-color:rgba(245,158,11,.4)}
.db-card--slate{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:rgba(100,116,139,.2)}
.db-card--slate:hover{border-color:rgba(100,116,139,.4)}

@keyframes dbCardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.db-menu-grid .db-menu-card:nth-child(1){animation-delay:.04s}
.db-menu-grid .db-menu-card:nth-child(2){animation-delay:.09s}
.db-menu-grid .db-menu-card:nth-child(3){animation-delay:.14s}
.db-menu-grid .db-menu-card:nth-child(4){animation-delay:.19s}

@media(max-width:860px){
  .db-layout{grid-template-columns:1fr}
  .db-profile-col{position:static}
}
/* ===== END DASHBOARD ===== */

/* ===== INNER PAGES (competitions, teachers, etc.) ===== */
.ip-layout{display:grid;grid-template-columns:360px 1fr;gap:28px;max-width:1100px;margin:0 auto;padding:28px 24px;align-items:start}
.ip-form-col{display:flex;flex-direction:column;gap:16px;position:sticky;top:72px}
.ip-list-col{min-width:0}

.ip-panel{background:rgba(255,255,255,.85);border:1px solid rgba(15,23,42,.1);border-radius:22px;padding:24px;box-shadow:0 4px 24px rgba(99,102,241,.07);backdrop-filter:blur(10px)}
.ip-panel--edit{border-color:rgba(99,102,241,.35);box-shadow:0 4px 24px rgba(99,102,241,.14)}
.ip-panel-header{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(15,23,42,.08)}
.ip-panel-icon{font-size:20px;line-height:1}
.ip-panel-title{font-size:16px;font-weight:800;color:#1e1b4b}

.ip-empty{text-align:center;padding:48px 24px;color:#94a3b8;background:rgba(255,255,255,.7);border-radius:18px;border:1px dashed rgba(15,23,42,.15)}

.ip-comp-list{display:flex;flex-direction:column;gap:10px}
.ip-comp-row{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.82);border:1px solid rgba(15,23,42,.09);border-radius:16px;padding:14px 16px;transition:box-shadow .15s,border-color .15s;animation:dbCardIn .3s ease both}
.ip-comp-row:hover{box-shadow:0 4px 18px rgba(99,102,241,.1);border-color:rgba(99,102,241,.2)}
.ip-comp-row--active{border-color:rgba(99,102,241,.45);box-shadow:0 4px 18px rgba(99,102,241,.16);background:linear-gradient(135deg,rgba(224,231,255,.5),rgba(237,233,254,.4))}
.ip-comp-main{flex:1;min-width:0}
.ip-comp-name{font-weight:800;font-size:15px;color:#1e1b4b;margin-bottom:6px}
.ip-comp-chips{display:flex;flex-wrap:wrap;gap:6px}
.ip-chip{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}
.ip-chip--blue{background:rgba(219,234,254,.8);color:#1d4ed8;border:1px solid rgba(59,130,246,.2)}
.ip-chip--green{background:rgba(220,252,231,.8);color:#166534;border:1px solid rgba(22,163,74,.2)}
.ip-chip--danger{background:rgba(254,226,226,.8);color:#b91c1c;border:1px solid rgba(239,68,68,.25)}
.ip-chip--muted{background:rgba(15,23,42,.04);color:var(--muted);border:1px solid var(--line)}
.ip-comp-subnote{margin-top:8px;font-size:12px;color:#b91c1c;font-weight:600}
.ip-comp-subnote--muted{color:var(--muted);font-weight:500}
.ip-comp-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.ip-edit-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;text-decoration:none;border:1px solid rgba(15,23,42,.12);background:rgba(255,255,255,.8);font-size:15px;flex-shrink:0;transition:background .15s,border-color .15s}
.ip-edit-btn:hover{background:rgba(224,231,255,.9);border-color:rgba(99,102,241,.35)}
.ip-edit-btn[disabled]{opacity:.45;cursor:not-allowed}
.ip-delete-btn{background:rgba(254,226,226,.75);border-color:rgba(239,68,68,.22)}
.ip-delete-btn:hover{background:rgba(254,202,202,.85);border-color:rgba(239,68,68,.35)}

/* Modal (confirm delete) */
.ip-modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.42);display:none;align-items:center;justify-content:center;padding:18px;z-index:80}
.ip-modal-backdrop--open{display:flex}
.ip-modal{width:min(520px,100%);background:rgba(255,255,255,.92);border:1px solid rgba(15,23,42,.12);border-radius:20px;padding:20px 22px;box-shadow:0 18px 60px rgba(2,6,23,.25);backdrop-filter:blur(10px)}
.ip-modal-title{font-size:16px;font-weight:900;color:#1e1b4b;margin-bottom:10px}
.ip-modal-body{font-size:14px;color:#334155;line-height:1.6;margin-bottom:16px}
.ip-modal-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center}
.btn.danger{background:#ef4444;border-color:#ef4444}
.btn.danger:hover{filter:brightness(.95)}

@media(max-width:860px){
  .ip-layout{grid-template-columns:1fr}
  .ip-form-col{position:static}
}
/* ===== END INNER PAGES ===== */

/* ===== TEACHER COMPETITIONS LIST PAGE ===== */
.tc-page{max-width:960px;margin:0 auto;padding:28px 24px}
.tc-school-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#e0e7ff,#ede9fe);border:1px solid rgba(99,102,241,.25);border-radius:18px;padding:16px 20px;margin-bottom:24px}
.tc-school-icon{font-size:30px;flex-shrink:0}
.tc-school-info{flex:1;min-width:0}
.tc-school-label{font-size:11px;color:#6366f1;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.tc-school-name{font-size:17px;font-weight:800;color:#1e1b4b}
.tc-change-btn{font-size:13px;font-weight:600;color:#6366f1;text-decoration:none;border:1px solid rgba(99,102,241,.35);border-radius:10px;padding:6px 14px;background:rgba(255,255,255,.7);white-space:nowrap;transition:background .15s,box-shadow .15s;flex-shrink:0}
.tc-change-btn:hover{background:#fff;box-shadow:0 2px 8px rgba(99,102,241,.15)}
.tc-header-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.tc-count-badge{font-size:12px;font-weight:700;background:rgba(99,102,241,.12);color:#4f46e5;border-radius:999px;padding:3px 12px;border:1px solid rgba(99,102,241,.18)}
.tc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.tc-comp-card{position:relative;display:flex;flex-direction:column;gap:0;padding:20px;border-radius:20px;text-decoration:none;color:var(--text);border:1px solid transparent;transition:transform .15s,box-shadow .15s,border-color .15s;animation:dbCardIn .35s ease both;cursor:pointer;overflow:hidden;isolation:isolate}
.tc-comp-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(2,6,23,.1)}
.tc-comp-card--registered{border-color:rgba(34,197,94,.28);box-shadow:inset 0 0 0 1px rgba(220,252,231,.85)}
.tc-comp-card--registered::before{content:'';position:absolute;inset:auto -18% -34% auto;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(187,247,208,.3) 0%,rgba(187,247,208,0) 72%);z-index:0}
.tc-comp-card > *{position:relative;z-index:1}
.tc-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.tc-card-icon{width:52px;height:52px;font-size:28px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:rgba(255,255,255,.65);flex-shrink:0}
.tc-card-num{font-size:11px;font-weight:700;color:rgba(30,27,75,.35);background:rgba(255,255,255,.5);border-radius:8px;padding:2px 8px;height:fit-content}
.tc-card-body{flex:1;margin-bottom:14px}
.tc-card-name{font-size:16px;font-weight:800;color:#1e1b4b;line-height:1.35;margin-bottom:5px}
.tc-card-hint{font-size:12px;color:#64748b}
.tc-card-footer{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tc-registered-mark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:0}
.tc-registered-badge{display:flex;flex-direction:column;align-items:center;gap:8px;transform:translateY(8px)}
.tc-registered-disc{width:86px;height:86px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:800;color:#16a34a;background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(240,253,244,.92));border:1px solid rgba(34,197,94,.22);box-shadow:0 16px 30px rgba(34,197,94,.16);opacity:.92}
.tc-registered-label{font-size:11px;font-weight:800;letter-spacing:.04em;color:#166534;background:rgba(255,255,255,.8);border:1px solid rgba(34,197,94,.16);border-radius:999px;padding:4px 10px;box-shadow:0 8px 18px rgba(34,197,94,.1)}
.tc-arrow{margin-left:auto;font-size:20px;color:rgba(30,27,75,.25);font-weight:300;flex-shrink:0;transition:color .15s}
.tc-comp-card:hover .tc-arrow{color:rgba(30,27,75,.55)}
.tc-comp-card--registered:hover{box-shadow:inset 0 0 0 1px rgba(220,252,231,.92),0 10px 30px rgba(22,163,74,.12)}
.tc-grid .tc-comp-card:nth-child(1){animation-delay:.04s}
.tc-grid .tc-comp-card:nth-child(2){animation-delay:.08s}
.tc-grid .tc-comp-card:nth-child(3){animation-delay:.12s}
.tc-grid .tc-comp-card:nth-child(4){animation-delay:.16s}
.tc-grid .tc-comp-card:nth-child(5){animation-delay:.20s}
.tc-grid .tc-comp-card:nth-child(6){animation-delay:.24s}
.tc-grid .tc-comp-card:nth-child(7){animation-delay:.28s}
.tc-grid .tc-comp-card:nth-child(8){animation-delay:.32s}
@media(max-width:640px){.tc-grid{grid-template-columns:1fr}.tc-school-banner{flex-wrap:wrap}}
/* ===== END TEACHER COMPETITIONS LIST PAGE ===== */

/* ===== TEACHER REGISTER COMPETITOR PAGE ===== */
.tr-quota-panel{background:linear-gradient(135deg,rgba(224,231,255,.6),rgba(237,233,254,.5))}
.tr-quota-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tr-quota-item{display:flex;flex-direction:column;align-items:center;padding:14px 10px;border-radius:14px;text-align:center}
.tr-quota--blue{background:rgba(219,234,254,.7);border:1px solid rgba(59,130,246,.2)}
.tr-quota--green{background:rgba(220,252,231,.7);border:1px solid rgba(22,163,74,.2)}
.tr-quota-num{font-size:26px;font-weight:900;line-height:1;margin-bottom:4px}
.tr-quota--blue .tr-quota-num{color:#1d4ed8}
.tr-quota--green .tr-quota-num{color:#166534}
.tr-quota-lbl{font-size:12px;font-weight:600;color:#475569}
.tr-seq{width:28px;height:28px;border-radius:50%;background:rgba(99,102,241,.1);color:#4f46e5;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tr-reg-row{transition:box-shadow .15s,border-color .15s}
/* ===== END TEACHER REGISTER COMPETITOR PAGE ===== */

/* ===== CHOOSE SCHOOL PAGE ===== */
.cs-page{max-width:1160px;margin:0 auto;padding:24px 24px 48px;min-height:90vh;background:radial-gradient(circle at 20% 20%,rgba(99,102,241,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(236,72,153,.03) 0%,transparent 50%)}
.cs-alert{margin-bottom:18px;animation:dbCardIn .4s ease both}
.cs-layout{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}
.cs-left,.cs-right{min-width:0;display:flex;flex-direction:column;gap:18px}

/* guide card */
.cs-guide-card{background:#fff;border:1px solid rgba(99,102,241,.15);border-radius:24px;padding:26px 24px;box-shadow:0 10px 40px -10px rgba(99,102,241,.1);position:relative;overflow:hidden}
.cs-guide-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:6px;background:linear-gradient(90deg,#6366f1,#ec4899)}
.cs-panel-title{font-size:18px;font-weight:900;color:#1e1b4b;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.cs-panel-title::before{content:"";width:4px;height:20px;background:#6366f1;border-radius:4px}
.cs-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.cs-steps li{display:flex;align-items:flex-start;gap:14px;position:relative}
.cs-steps li::after{content:"";position:absolute;left:13px;top:28px;bottom:-12px;width:2px;background:#e2e8f0}
.cs-steps li:last-child::after{display:none}
.cs-steps li:nth-child(1) .cs-step-num{background:#6366f1}
.cs-steps li:nth-child(2) .cs-step-num{background:#8b5cf6}
.cs-steps li:nth-child(3) .cs-step-num{background:#ec4899}
.cs-step-num{width:28px;height:28px;border-radius:50%;color:#fff;font-size:13px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(99,102,241,.3);z-index:2}
.cs-step-text{font-size:14px;color:#334155;line-height:1.6;font-weight:500;padding-top:2px}

/* add school card (bottom left) */
.cs-add-card{background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid rgba(148,163,184,.2);border-radius:24px;padding:24px;box-shadow:0 4px 20px rgba(15,23,42,.06)}
.cs-add-title{font-size:16px;font-weight:800;color:#0f172a;margin-bottom:4px}

/* hero (right top) */
.cs-hero{background:linear-gradient(135deg,#4f46e5 0%,#9333ea 100%);border-radius:24px;padding:28px 32px;color:#fff;display:flex;flex-direction:column;align-items:flex-start;gap:8px;box-shadow:0 12px 36px -8px rgba(99,102,241,.4);position:relative;overflow:hidden}
.cs-hero::after{content:"🏫";position:absolute;right:-10px;bottom:-20px;font-size:140px;opacity:.15;filter:grayscale(1);pointer-events:none}
.cs-hero-icon{font-size:42px;margin-bottom:6px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}
.cs-hero-title{font-size:20px;font-weight:900;line-height:1.2;text-shadow:0 2px 4px rgba(0,0,0,.1)}
.cs-hero-sub{font-size:14px;opacity:.9;font-weight:500;max-width:90%}
.tc-count-badge{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(4px)}

/* search */
.cs-search-wrap{display:flex;align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:18px;padding:0 16px;margin-bottom:20px;box-shadow:0 4px 12px rgba(15,23,42,.03);transition:all .2s;height:52px}
.cs-search-wrap:focus-within{border-color:#6366f1;box-shadow:0 4px 20px rgba(99,102,241,.15);transform:translateY(-1px)}
.cs-search-icon{font-size:18px;margin-right:12px;opacity:.6}
.cs-search-input{font-size:16px;font-weight:600}

/* grid */
.cs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:24px}
.cs-school-card{
  position:relative;display:flex;align-items:center;gap:14px;padding:18px;padding-top:42px;
  background:#fff;border:2px solid transparent;border-radius:20px;
  cursor:pointer;transition:all .2s cubic-bezier(.25,.8,.25,1);
  box-shadow:0 4px 12px rgba(15,23,42,.05), 0 0 0 1px rgba(15,23,42,.05);
}
.cs-school-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(99,102,241,.12);border-color:#a5b4fc}
.cs-school-card--active{
  background:#eff6ff;
  border-color:#6366f1;
  box-shadow:0 8px 24px rgba(99,102,241,.15);
}
.cs-school-card--active .cs-school-letter{background:linear-gradient(135deg,#4f46e5,#ec4899);transform:rotate(-6deg)}

/* card internal elements */
.cs-school-letter{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#64748b,#94a3b8);color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 10px rgba(0,0,0,.15);transition:transform .3s}
.cs-school-info{flex:1;min-width:0}
.cs-school-name{font-weight:800;color:#1e293b;font-size:14px;line-height:1.4}
.cs-school-actions{position:absolute;top:10px;right:10px;display:flex;gap:6px;opacity:0;transform:translateY(-5px);transition:all .2s}
.cs-school-card:hover .cs-school-actions{opacity:1;transform:translateY(0)}
.cs-school-iconbtn{width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e2e8f0;color:#64748b;font-size:14px;box-shadow:0 2px 6px rgba(0,0,0,.05);transition:.15s}
.cs-school-iconbtn:hover{background:#f1f5f9;color:#334155;transform:scale(1.1)}
.cs-school-iconbtn--danger:hover{background:#fee2e2;color:#ef4444;border-color:#fecaca}

.cs-school-check{width:24px;height:24px;border-radius:50%;background:#10b981;color:#fff;font-size:13px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(16,185,129,.4);animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}
.cs-school-check--hidden{display:none}

/* action bar */
.cs-action-bar{
  display:flex;align-items:center;gap:18px;
  background:rgba(255,255,255,.9);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.6);
  border-radius:24px;padding:16px 24px;
  position:sticky;bottom:24px;
  box-shadow:0 12px 48px -8px rgba(99,102,241,.2), 0 0 0 1px rgba(99,102,241,.1);
  z-index:10;
}
.cs-action-bar--disabled{filter:grayscale(1);opacity:.5;pointer-events:none}
.cs-sel-label{font-size:11px;font-weight:800;text-transform:uppercase;color:#64748b;letter-spacing:1px}
.cs-sel-name{font-size:16px;font-weight:900;color:#1e1b4b}
.cs-confirm-btn{background:linear-gradient(135deg,#4f46e5,#ec4899);padding:14px 32px;font-size:15px;border-radius:16px;box-shadow:0 8px 24px -4px rgba(236,72,153,.4);position:relative;overflow:hidden}
.cs-confirm-btn::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.2),transparent);pointer-events:none}
.cs-confirm-btn:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 12px 32px -4px rgba(236,72,153,.5)}

/* no result */
.cs-no-result{text-align:center;padding:60px;color:#94a3b8;font-weight:700;font-size:16px}

@keyframes popIn{from{transform:scale(0)}to{transform:scale(1)}}
@media(max-width:900px){.cs-layout{grid-template-columns:1fr}}
/* ===== END CHOOSE SCHOOL PAGE ===== */

/* ===== RESULTS PAGE ===== */
.rs-page{max-width:900px;margin:0 auto;padding:28px 24px}

/* --- Competition list --- */
/* results list */
.rs-two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.rs-col{display:flex;flex-direction:column;gap:14px}

/* column headers */
.rs-col-head{display:flex;align-items:center;gap:14px;padding:18px 20px;border-radius:20px;border:1.5px solid transparent}
.rs-col-head-icon{font-size:32px;line-height:1;flex-shrink:0}
.rs-col-head-title{font-size:16px;font-weight:900;line-height:1.2}
.rs-col-head-sub{font-size:12.5px;font-weight:700;opacity:.7;margin-top:2px}
.rs-col-head--pending{background:rgba(241,245,249,.7);border-color:rgba(148,163,184,.25);color:#475569}
.rs-col-head--done{
  background:linear-gradient(135deg,rgba(22,163,74,.12) 0%,rgba(16,185,129,.07) 100%);
  border-color:rgba(22,163,74,.35);
  color:#15803d;
  box-shadow:0 4px 18px rgba(22,163,74,.1);
}
.rs-col-head--done .rs-col-head-title{font-size:18px;color:#15803d}

/* empty state in col */
.rs-col-empty{text-align:center;padding:28px 16px;font-size:13px;font-weight:700;color:#94a3b8;background:rgba(248,250,252,.6);border-radius:16px;border:1.5px dashed rgba(15,23,42,.1)}

.rs-comp-list{display:flex;flex-direction:column;gap:10px}
.rs-comp-row{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;background:rgba(255,255,255,.88);border:1.5px solid rgba(15,23,42,.09);border-radius:20px;padding:18px 20px;box-shadow:0 2px 12px rgba(99,102,241,.06);transition:box-shadow .18s,border-color .18s,transform .15s;animation:dbCardIn .35s ease both}
.rs-comp-row:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(2,6,23,.12);border-color:rgba(99,102,241,.28)}
.rs-comp-row--done{
  border-color:rgba(22,163,74,.4);
  background:linear-gradient(135deg,rgba(240,253,244,.97) 0%,rgba(255,255,255,.9) 100%);
  box-shadow:0 3px 14px rgba(22,163,74,.1);
}
.rs-comp-row--done:hover{border-color:rgba(22,163,74,.65);box-shadow:0 10px 32px rgba(22,163,74,.18);transform:translateY(-2px)}
.rs-comp-main{flex:1;min-width:0}
.rs-comp-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:15px;font-weight:900;color:#1e1b4b;margin-bottom:8px}
.rs-comp-title-text{flex:1;min-width:0}
.rs-comp-status-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:800;color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);border-radius:999px;padding:4px 12px;white-space:nowrap;box-shadow:0 2px 8px rgba(22,163,74,.35);letter-spacing:.02em}
.rs-comp-meta{display:flex;flex-wrap:wrap;gap:6px}
.rs-comp-arrow{font-size:22px;opacity:.55;flex-shrink:0}

/* announced column — call-to-action arrow */
.rs-announced-arrow{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1px;flex-shrink:0;
  padding:7px 12px;
  border-radius:12px;
  background:linear-gradient(135deg,#16a34a,#22c55e);
  color:#fff;
  box-shadow:0 3px 10px rgba(22,163,74,.3);
  transition:filter .15s,transform .12s;
}
.rs-comp-row--done:hover .rs-announced-arrow{filter:brightness(1.1);transform:scale(1.07)}
.rs-announced-label{font-size:10.5px;font-weight:800;letter-spacing:.04em;line-height:1}
.rs-announced-arrow>span:last-child{font-size:16px;line-height:1}

@media(max-width:780px){.rs-two-col{grid-template-columns:1fr}}
@media(max-width:540px){.rs-col-head{padding:14px 16px}.rs-comp-row{padding:14px 16px}}

/* --- Competition detail header --- */
.rs-detail-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(15,23,42,.08)}
.rs-detail-title{font-size:22px;font-weight:900;color:#1e1b4b;line-height:1.25}
.rs-detail-hint{font-size:13px;color:var(--muted);font-weight:600;white-space:nowrap}

/* --- School list and cards --- */
.rs-school-list{display:flex;flex-direction:column;gap:12px}
.rs-school{background:rgba(255,255,255,.88);border:1.5px solid rgba(15,23,42,.09);border-radius:20px;overflow:hidden;box-shadow:0 2px 14px rgba(99,102,241,.07);animation:dbCardIn .35s ease both}
.rs-school[open]{box-shadow:0 8px 32px rgba(2,6,23,.1)}
.rs-school-sum{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;cursor:pointer;user-select:none}
.rs-school-sum::-webkit-details-marker{display:none}
.rs-school-sum:hover{background:rgba(224,231,255,.12)}
.rs-school-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1}
.rs-rank-badge{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;flex-shrink:0;background:rgba(99,102,241,.1);color:#4f46e5}
.rs-rank-badge--gold{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 14px rgba(245,158,11,.4);font-size:18px;width:46px;height:46px;border-radius:14px}
.rs-rank-badge--silver{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff;width:42px;height:42px}
.rs-rank-badge--bronze{background:linear-gradient(135deg,#cd7c3f,#b45309);color:#fff;width:42px;height:42px}
.rs-school-info{min-width:0}
.rs-school-sup{font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;margin-bottom:2px;color:#64748b}
.rs-school-sup--gold{color:#b45309}
.rs-school-sup--silver{color:#475569}
.rs-school-sup--bronze{color:#92400e}
.rs-school-name{font-weight:900;color:#1e1b4b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rs-school-name--gold{font-size:18px;color:#92400e}
.rs-school-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.rs-school-score{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.rs-school-score-lbl{font-size:11px;color:var(--muted);font-weight:700}
.rs-school-score-val{font-size:18px;font-weight:900;color:#1e1b4b}
.rs-school-score-val--gold{font-size:24px;color:#92400e}
.rs-school-body{border-top:1px solid rgba(15,23,42,.07);padding:16px 18px}

/* Champion card special styles */
.rs-school--gold{border-color:rgba(245,158,11,.45);box-shadow:0 8px 40px rgba(245,158,11,.2),0 2px 12px rgba(99,102,241,.06)}
.rs-school--gold .rs-school-sum{background:linear-gradient(135deg,rgba(254,252,232,.95),rgba(254,243,199,.75))}
.rs-school--gold[open] .rs-school-sum{background:linear-gradient(135deg,rgba(254,243,199,.95),rgba(253,230,138,.6))}
.rs-school--gold .rs-school-body{background:rgba(254,252,232,.4)}
.rs-school--silver{border-color:rgba(100,116,139,.28)}
.rs-school--silver .rs-school-sum{background:linear-gradient(135deg,rgba(248,250,252,.95),rgba(226,232,240,.7))}
.rs-school--bronze{border-color:rgba(180,83,9,.22)}
.rs-school--bronze .rs-school-sum{background:linear-gradient(135deg,rgba(255,251,235,.95),rgba(254,243,199,.55))}

/* Medal tags */
.rs-medal{font-size:13px;font-weight:800;border-radius:999px;padding:5px 14px;white-space:nowrap;flex-shrink:0;border:1px solid transparent}
.rs-medal--gold{background:linear-gradient(135deg,#fef9c3,#fde68a);color:#92400e;border-color:rgba(245,158,11,.35);font-size:14px;padding:6px 16px}
.rs-medal--silver{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#334155;border-color:rgba(100,116,139,.3)}
.rs-medal--bronze{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:rgba(217,119,6,.25)}
.rs-medal--cert{background:linear-gradient(135deg,#dcfce7,#d1fae5);color:#166534;border-color:rgba(22,163,74,.2)}
.rs-medal--none{background:rgba(241,245,249,.9);color:#64748b;border-color:rgba(15,23,42,.1)}

/* Roster */
.rs-roster{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:4px}
.rs-roster-col{background:rgba(15,23,42,.03);border:1px solid rgba(15,23,42,.07);border-radius:14px;padding:14px 16px}
.rs-roster-title{font-size:12px;font-weight:900;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.rs-roster-empty{font-size:13px;color:var(--muted)}
.rs-roster-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px;color:#334155;font-size:13px}
.rs-roster-item{display:flex;align-items:center;justify-content:space-between;gap:10px}
.rs-roster-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rs-pdf{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:999px;border:none;background:linear-gradient(135deg,#ef4444 0%,#dc2626 50%,#b91c1c 100%);color:#fff;font-size:12px;font-weight:700;letter-spacing:.04em;text-decoration:none;flex-shrink:0;cursor:pointer;position:relative;overflow:hidden;box-shadow:0 2px 8px rgba(220,38,38,.35);transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,filter .18s;white-space:nowrap}
.rs-pdf::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.22) 0%,transparent 60%);pointer-events:none}
.rs-pdf:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px rgba(220,38,38,.5);filter:brightness(1.08)}
.rs-pdf:active{transform:translateY(0) scale(.97);box-shadow:0 2px 6px rgba(220,38,38,.3);filter:brightness(.96)}

@media(max-width:720px){.rs-detail-head{flex-direction:column;align-items:flex-start}.rs-roster{grid-template-columns:1fr}.rs-school-right{gap:8px}.rs-school-name--gold{font-size:16px}.rs-school-score-val--gold{font-size:20px}}
/* ===== END RESULTS PAGE ===== */

/* ===== TEACHERS LIST PAGE ===== */
.tl-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.tl-card{border-radius:20px;padding:18px 18px 16px;text-decoration:none;color:var(--text);border:1px solid transparent;animation:dbCardIn .3s ease both;transition:box-shadow .15s,transform .15s}
.tl-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(2,6,23,.1)}
.tl-card-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.tl-avatar{width:48px;height:48px;border-radius:14px;font-size:20px;font-weight:900;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tl-avatar--indigo{background:linear-gradient(135deg,#6366f1,#8b5cf6)}
.tl-avatar--violet{background:linear-gradient(135deg,#8b5cf6,#a78bfa)}
.tl-avatar--green{background:linear-gradient(135deg,#16a34a,#22c55e)}
.tl-avatar--amber{background:linear-gradient(135deg,#d97706,#f59e0b)}
.tl-avatar--blue{background:linear-gradient(135deg,#2563eb,#60a5fa)}
.tl-avatar--gold{background:linear-gradient(135deg,#b45309,#f59e0b)}
.tl-avatar--slate{background:linear-gradient(135deg,#475569,#94a3b8)}
.tl-card-name-wrap{flex:1;min-width:0}
.tl-card-name{font-size:15px;font-weight:800;color:#1e1b4b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-card-username{font-size:12px;color:#64748b;margin-top:2px}
.tl-card-info{display:flex;flex-direction:column;gap:7px}
.tl-info-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:#334155}
.tl-info-icon{flex-shrink:0;font-size:13px;margin-top:1px}
.tl-info-val{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.tl-info-email{color:#6366f1;font-size:12.5px}
@media(max-width:1000px){.tl-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.tl-grid{grid-template-columns:1fr}}
/* ===== END TEACHERS LIST PAGE ===== */

/* ===== LOGIN PAGE ===== */
.lg-body{min-height:100vh;display:flex;align-items:stretch;background:linear-gradient(135deg,#eef2ff 0%,#f5f3ff 50%,#ede9fe 100%);padding:0}
.lg-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;width:100%}

.lg-brand{background:linear-gradient(160deg,#4f46e5 0%,#7c3aed 60%,#6d28d9 100%);display:flex;align-items:center;justify-content:center;padding:48px 40px;position:relative;overflow:hidden}
.lg-brand::before{content:'';position:absolute;inset:-80px;background:radial-gradient(circle at 30% 40%,rgba(255,255,255,.08) 0%,transparent 55%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.05) 0%,transparent 45%);pointer-events:none}
.lg-brand-inner{position:relative;z-index:1;max-width:380px;text-align:left}
.lg-logo{font-size:56px;line-height:1;margin-bottom:24px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.lg-brand-title{font-size:26px;font-weight:900;color:#fff;line-height:1.25;margin-bottom:14px}
.lg-brand-sub{font-size:15px;color:rgba(255,255,255,.72);line-height:1.7;margin-bottom:32px}
.lg-brand-dots{display:flex;gap:10px}
.lg-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.35)}
.lg-dot:first-child{background:rgba(255,255,255,.85);width:28px;border-radius:999px}

.lg-form-col{display:flex;align-items:center;justify-content:center;padding:40px 32px}
.lg-form-card{width:min(420px,100%);background:rgba(255,255,255,.9);border:1px solid rgba(15,23,42,.1);border-radius:26px;padding:36px 32px;box-shadow:0 16px 60px rgba(99,102,241,.12);backdrop-filter:blur(12px)}
.lg-form-header{text-align:center;margin-bottom:28px}
.lg-form-icon{font-size:36px;margin-bottom:10px;line-height:1}
.lg-form-title{font-size:22px;font-weight:900;color:#1e1b4b;margin-bottom:6px}
.lg-form-sub{font-size:13px;color:#64748b;line-height:1.5}
.lg-action-stack{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.lg-action-stack .btn{margin-top:0}
.lg-action-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.95fr);gap:10px;align-items:stretch}
.lg-action-row .btn{width:100%;min-width:0;white-space:nowrap}
.lg-submit-btn{width:100%;padding:13px;font-size:15px;font-weight:800;letter-spacing:.02em;border-radius:14px;background:linear-gradient(135deg,#6366f1,#7c3aed);border:0;color:#fff;cursor:pointer;transition:filter .15s,transform .12s}
.lg-submit-btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
.lg-regis-btn,.lg-forgot-btn{padding:12px 10px;font-size:13px;font-weight:700;letter-spacing:0;border-radius:12px;border:0;color:#fff;cursor:pointer;transition:filter .15s,transform .12s}
.lg-regis-btn{background:linear-gradient(135deg,#467d03,#4be97d)}
.lg-regis-btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
.lg-forgot-btn{background:linear-gradient(135deg,#0f766e,#14b8a6)}
.lg-forgot-btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
.lg-footer{text-align:center;margin-top:22px}
.lg-back-link{font-size:13px;color:#6366f1;text-decoration:none;font-weight:600;opacity:.8;transition:opacity .15s}
.lg-back-link:hover{opacity:1}

@media(max-width:700px){.lg-wrap{grid-template-columns:1fr}.lg-brand{display:none}.lg-form-col{min-height:100svh;padding:28px 20px}}
@media(max-width:420px){.lg-action-row{gap:8px}.lg-regis-btn,.lg-forgot-btn{padding:11px 8px;font-size:12px}}
/* ===== END LOGIN PAGE ===== */

/* ===== JUDGE PAGE ===== */
.jd-page{max-width:1100px;margin:0 auto;padding:28px 24px}
.jd-layout{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}
.jd-left{position:sticky;top:72px}
.jd-hint{font-size:13px;color:#64748b;font-weight:600;line-height:1.6}
.jd-right{min-width:0}
.jd-row{align-items:stretch}
.jd-form .field input{height:40px}
@media(max-width:860px){.jd-form .row{flex-direction:column}}
@media(max-width:860px){.jd-layout{grid-template-columns:1fr}.jd-left{position:static}}
/* ===== END JUDGE PAGE ===== */

/* ===== PROFILE PAGE ===== */
.pf-id-card{text-align:center;padding:32px 24px 24px}

.pf-avatar-wrap{display:flex;justify-content:center;margin-bottom:16px}
.pf-avatar{width:80px;height:80px;border-radius:24px;font-size:32px;font-weight:900;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(2,6,23,.15)}
.pf-avatar--indigo{background:linear-gradient(135deg,#6366f1,#8b5cf6)}
.pf-avatar--violet{background:linear-gradient(135deg,#8b5cf6,#a78bfa)}
.pf-avatar--green{background:linear-gradient(135deg,#16a34a,#22c55e)}
.pf-avatar--amber{background:linear-gradient(135deg,#d97706,#f59e0b)}
.pf-avatar--blue{background:linear-gradient(135deg,#2563eb,#60a5fa)}
.pf-avatar--gold{background:linear-gradient(135deg,#b45309,#f59e0b)}

.pf-id-name{font-size:20px;font-weight:900;color:#1e1b4b;margin-bottom:4px;line-height:1.25}
.pf-id-username{font-size:13px;color:#64748b;font-weight:600;margin-bottom:18px}

.pf-id-rows{display:flex;flex-direction:column;gap:10px;text-align:left;border-top:1px solid rgba(15,23,42,.08);padding-top:18px;margin-top:4px}
.pf-id-row{display:flex;align-items:flex-start;gap:9px;font-size:13.5px}
.pf-id-icon{flex-shrink:0;font-size:14px;margin-top:1px}
.pf-id-val{flex:1;min-width:0;color:#334155;font-weight:500;word-break:break-word}
.pf-id-school{font-weight:700;color:#1e1b4b}
.pf-id-email{color:#6366f1}

.pf-divider{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid rgba(15,23,42,.1);border-bottom:1px solid rgba(15,23,42,.07);padding:12px 0;margin:12px 0 16px;font-size:14px;font-weight:800;color:#1e1b4b}
.pf-divider small{font-size:12px;font-weight:500;color:#64748b}

.pf-actions{display:flex;align-items:center;gap:14px;margin-top:8px}
.pf-cancel{font-size:14px;color:#64748b;text-decoration:none;font-weight:600;transition:color .15s}
.pf-cancel:hover{color:#1e1b4b}
/* ===== END PROFILE PAGE ===== */

/* ===== CERTIFICATES PAGE ===== */
.cf-layout{max-width:1200px}
.cf-upload .btn{margin-top:8px}

.cf-templates{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.cf-thumb{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(15,23,42,.12);background:rgba(255,255,255,.9);cursor:pointer;transition:transform .12s,border-color .12s,box-shadow .12s}
.cf-thumb:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(2,6,23,.1);border-color:rgba(99,102,241,.25)}
.cf-thumb input{position:absolute;inset:0;opacity:0;cursor:pointer}
.cf-thumb img{width:100%;height:92px;object-fit:cover;display:block}
.cf-thumb--selected{border-color:rgba(22,163,74,.45);box-shadow:0 8px 24px rgba(22,163,74,.12)}
.cf-thumb--selected::after{content:'✓';position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:999px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;box-shadow:0 6px 18px rgba(22,163,74,.28)}

.cf-editor{display:flex;flex-direction:column;gap:14px}
.cf-canvas{position:relative;border-radius:18px;overflow:hidden;border:1px solid rgba(15,23,42,.12);background:rgba(255,255,255,.85)}
.cf-template{width:100%;height:auto;display:block}

.cf-box{position:absolute;left:0;top:0;transform:translate(-50%,-50%);max-width:80%;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.75);border:1px solid rgba(99,102,241,.25);backdrop-filter:blur(10px);box-shadow:0 10px 28px rgba(2,6,23,.12);cursor:grab;text-align:center}
.cf-box--drag{cursor:grabbing;box-shadow:0 14px 40px rgba(2,6,23,.18)}
.cf-text{line-height:1.3;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cf-name{font-weight:900}
.cf-meta{font-weight:700;opacity:.85}

.cf-controls{display:flex;flex-direction:column;gap:10px}
.cf-sliders{display:flex;align-items:flex-end;gap:14px}
.cf-actions{display:flex;justify-content:flex-end}
.cf-hr{border:none;border-top:1px solid rgba(15,23,42,.1);margin:18px 0}

.cf-list{display:flex;flex-direction:column;gap:10px}
.cf-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.84);border:1px solid rgba(15,23,42,.09);box-shadow:0 2px 12px rgba(99,102,241,.06)}
.cf-row-main{flex:1;min-width:0}
.cf-row-name{font-size:14px;font-weight:900;color:#1e1b4b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cf-row-sub{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.cf-pdf{width:40px;height:40px;border-radius:14px;border:1px solid rgba(15,23,42,.12);background:rgba(255,255,255,.9);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .12s,box-shadow .12s,border-color .12s}
.cf-pdf:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(2,6,23,.1);border-color:rgba(99,102,241,.25)}

@media(max-width:860px){
  .cf-templates{grid-template-columns:repeat(2,1fr)}
  .cf-sliders{flex-direction:column;align-items:stretch}
}
/* ===== END CERTIFICATES PAGE ===== */

/* ===== CERTIFICATES PAGE v2 ===== */

/* layout -------------------------------------------------------- */
.cf2-root{
  display:grid;
  grid-template-columns:minmax(240px, 1fr) minmax(0, 4fr) minmax(240px, 1fr);
  gap:24px;
  max-width:none;
  margin:0;
  padding:24px 24px 48px;
  align-items:start;
}

/* prevent grid children from forcing overflow */
.cf2-sidebar,.cf2-center,.cf2-settings{min-width:0}

/* toast --------------------------------------------------------- */
.cf2-toast{
  display:flex;align-items:center;gap:8px;
  max-width:1280px;margin:20px auto 0;padding:14px 20px;
  border-radius:16px;font-size:14px;font-weight:700;
  border:1px solid transparent;
}
.cf2-toast--success{background:rgba(22,163,74,.08);border-color:rgba(22,163,74,.25);color:#15803d}
.cf2-toast--error  {background:rgba(220,38,38,.07);border-color:rgba(220,38,38,.22);color:#b91c1c}

/* sidebar ------------------------------------------------------- */
.cf2-sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:16px}

/* card ---------------------------------------------------------- */
.cf2-card{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(15,23,42,.1);
  border-radius:22px;
  padding:22px 22px 20px;
  box-shadow:0 4px 24px rgba(99,102,241,.07);
  backdrop-filter:blur(8px);
}

.cf2-card-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
}
.cf2-card-head--editor{justify-content:space-between}
.cf2-card-head-left{display:flex;align-items:center;gap:10px}

.cf2-step{
  flex-shrink:0;
  width:28px;height:28px;
  border-radius:50%;
  background:linear-gradient(135deg,#6366f1,#7c3aed);
  color:#fff;
  font-size:13px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(99,102,241,.3);
}
.cf2-card-title{font-size:15px;font-weight:800;color:#1e1b4b}
.cf2-drag-hint{font-size:12px;color:#64748b;font-weight:500}
.cf2-badge{
  flex-shrink:0;
  padding:3px 10px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(124,58,237,.1));
  border:1px solid rgba(99,102,241,.18);
  font-size:12px;font-weight:800;color:#4f46e5;
}

/* upload / dropzone -------------------------------------------- */
.cf2-upload-form{display:flex;flex-direction:column;gap:10px}

.cf2-dropzone{
  display:flex;flex-direction:column;align-items:center;
  gap:4px;
  padding:18px 12px;
  border-radius:16px;
  border:2px dashed rgba(99,102,241,.3);
  background:rgba(238,242,255,.35);
  cursor:pointer;
  transition:border-color .15s,background .15s;
  text-align:center;
  user-select:none;
}
.cf2-dropzone:hover,.cf2-dropzone--chosen{
  border-color:rgba(99,102,241,.55);
  background:rgba(238,242,255,.6);
}
.cf2-dropzone input[type="file"]{
  position:absolute;
  width:1px;height:1px;
  opacity:0;pointer-events:none;
}
.cf2-dropzone-icon{font-size:26px;line-height:1}
.cf2-dropzone-label{font-size:13px;font-weight:700;color:#4338ca;margin-top:2px}
.cf2-dropzone-sub  {font-size:11.5px;color:#94a3b8;font-weight:500}

.cf2-btn-upload{
  width:100%;
  border-radius:14px;
  padding:9px;
  font-size:13.5px;font-weight:800;
  background:linear-gradient(135deg,#6366f1,#8b5cf6);
  color:#fff;border:none;cursor:pointer;
  transition:filter .15s,transform .12s;
}
.cf2-btn-upload:hover{filter:brightness(1.07);transform:translateY(-1px)}

/* template thumbnails ------------------------------------------ */
.cf2-template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px}

.cf2-thumb-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}

.cf2-thumb{
  position:relative;border-radius:12px;overflow:hidden;
  border:2px solid rgba(15,23,42,.1);
  cursor:pointer;
  transition:border-color .12s,box-shadow .12s,transform .12s;
  background:rgba(248,250,252,.9);
}
.cf2-thumb input{position:absolute;inset:0;opacity:0;cursor:pointer}
.cf2-thumb img{width:100%;height:110px;object-fit:contain;display:block;background:rgba(255,255,255,.9)}
.cf2-thumb:hover{border-color:rgba(99,102,241,.35);transform:translateY(-2px);box-shadow:0 6px 20px rgba(99,102,241,.12)}
.cf2-thumb--on{border-color:rgba(22,163,74,.5);box-shadow:0 6px 20px rgba(22,163,74,.12)}
.cf2-thumb-check{
  position:absolute;top:5px;right:5px;
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#16a34a,#15803d);
  color:#fff;font-size:12px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(22,163,74,.3);
}

.cf2-thumb-delete{
  width:38px;height:34px;
  border-radius:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.75);
  color:var(--danger);
  font-size:16px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:background .14s,border-color .14s,transform .12s;
}
.cf2-thumb-delete:hover{background:rgba(254,226,226,.7);border-color:rgba(185,28,28,.25);transform:translateY(-1px)}

.cf2-btn-select{
  width:100%;margin-top:10px;
  padding:9px;border-radius:14px;
  font-size:13.5px;font-weight:800;
  background:linear-gradient(135deg,#16a34a,#22c55e);
  color:#fff;border:none;cursor:pointer;
  transition:filter .15s,transform .12s;
}
.cf2-btn-select:hover{filter:brightness(1.06);transform:translateY(-1px)}

/* center template select: keep button compact */
.cf2-center .cf2-template-form{display:flex;flex-direction:column;align-items:center}
.cf2-center .cf2-template-form .cf2-btn-select{width:auto;padding:10px 18px}

/* empty / welcome --------------------------------------------- */
.cf2-empty{
  display:flex;flex-direction:column;align-items:center;
  gap:8px;padding:18px 12px;
  font-size:13px;color:#94a3b8;font-weight:600;text-align:center;line-height:1.5;
}
.cf2-welcome{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:260px;text-align:center;gap:10px;
}
.cf2-welcome-icon {font-size:52px;line-height:1}
.cf2-welcome-title{font-size:18px;font-weight:900;color:#1e1b4b}
.cf2-welcome-sub  {font-size:14px;color:#94a3b8;font-weight:500;line-height:1.6}

/* center + settings columns ----------------------------------- */
.cf2-center{display:flex;flex-direction:column;gap:20px}
.cf2-settings{display:flex;flex-direction:column;gap:20px}

/* In the right settings column, show sections top-to-bottom */
.cf2-settings .cf2-style-cols{grid-template-columns:1fr}

/* canvas wrap with template image + draggable overlays */
.cf2-canvas-wrap{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.1);
  background:rgba(248,250,252,.9);
  box-shadow:0 6px 28px rgba(99,102,241,.08);
  user-select:none;
}
.cf2-template-img{width:100%;height:auto;display:block}

/* draggable text boxes ---------------------------------------- */
.cf2-box{
  position:absolute;
  left:0;top:0;
  transform:translate(-50%,-50%);
  max-width:80%;
  border-radius:14px;
  border:1.5px solid rgba(99,102,241,.3);
  padding:8px 14px 10px;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(12px);
  box-shadow:0 8px 28px rgba(2,6,23,.1);
  cursor:grab;
  text-align:center;
}
.cf2-box:focus-visible{outline:2px solid #6366f1;outline-offset:2px}
.cf2-box--dragging{cursor:grabbing;box-shadow:0 16px 44px rgba(2,6,23,.18);z-index:10}
.cf2-box--name{border-color:rgba(99,102,241,.4);background:rgba(238,242,255,.78)}
.cf2-box--meta{border-color:rgba(16,185,129,.35);background:rgba(236,253,245,.78)}
.cf2-box--certno{border-color:rgba(245,158,11,.38);background:rgba(254,252,232,.78)}

.cf2-box-label{
  font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.09em;
  color:#6366f1;opacity:.8;margin-bottom:2px;
  line-height:1;
}
.cf2-box--meta .cf2-box-label{color:#059669}
.cf2-box--certno .cf2-box-label{color:#b45309}
.cf2-box-text{
  line-height:1.35;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-weight:700;
}

/* controls form ----------------------------------------------- */
.cf2-controls-form{margin-top:0}

.cf2-style-cols{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.cf2-style-card{
  border-radius:18px;
  border:1px solid rgba(15,23,42,.09);
  padding:16px 16px 14px;
  background:rgba(248,250,252,.75);
  display:flex;flex-direction:column;gap:12px;
  min-width:0;
}
.cf2-style-card--name{border-color:rgba(99,102,241,.18);background:rgba(238,242,255,.35)}
.cf2-style-card--meta{border-color:rgba(16,185,129,.18);background:rgba(236,253,245,.35)}
.cf2-style-card--certno{border-color:rgba(245,158,11,.20);background:rgba(254,252,232,.35)}

.cf2-style-head{display:flex;align-items:center;gap:8px;margin-bottom:0}
.cf2-style-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
}
.cf2-style-dot--name{background:linear-gradient(135deg,#6366f1,#8b5cf6)}
.cf2-style-dot--meta{background:linear-gradient(135deg,#10b981,#059669)}
.cf2-style-dot--certno{background:linear-gradient(135deg,#f59e0b,#d97706)}
.cf2-style-title{font-size:13.5px;font-weight:800;color:#1e1b4b}

/* single control row */
.cf2-ctrl-row{
  display:flex;align-items:center;gap:10px;
  min-height:32px;
}
.cf2-ctrl-label{
  flex-shrink:0;
  width:48px;
  font-size:12px;font-weight:700;color:#64748b;
}

/* slider */
.cf2-slider-track{
  flex:1;display:flex;align-items:center;gap:8px;min-width:0;
}
.cf2-slider{
  flex:1;min-width:0;
  height:5px;
  accent-color:#6366f1;
  cursor:pointer;
}
.cf2-slider-val{
  flex-shrink:0;
  min-width:30px;
  text-align:right;
  font-size:12px;font-weight:800;color:#6366f1;
  font-variant-numeric:tabular-nums;
}

/* font select */
.cf2-select{
  flex:1;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.9);
  font-size:12.5px;font-weight:600;color:#1e1b4b;
  padding:0 8px;
  cursor:pointer;
  transition:border-color .15s;
  min-width:0;
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2394a3b8'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 8px center;
  padding-right:26px;
}
.cf2-select:focus{outline:2px solid rgba(99,102,241,.4);border-color:rgba(99,102,241,.4)}

/* text/number inputs */
.cf2-input{
  flex:1;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.9);
  font-size:12.5px;
  font-weight:700;
  color:#1e1b4b;
  padding:0 10px;
  min-width:0;
  transition:border-color .15s,box-shadow .15s;
}
.cf2-input:focus{outline:2px solid rgba(99,102,241,.4);border-color:rgba(99,102,241,.4)}
.cf2-input::placeholder{color:#94a3b8;font-weight:600}

/* color picker */
.cf2-color-wrap{display:flex;align-items:center;gap:8px}
.cf2-colorpicker{
  flex-shrink:0;
  width:32px;height:32px;
  border-radius:10px;
  border:1.5px solid rgba(15,23,42,.12);
  padding:2px;
  background:rgba(255,255,255,.9);
  cursor:pointer;
  transition:border-color .15s;
}
.cf2-colorpicker:hover{border-color:rgba(99,102,241,.4)}
.cf2-color-hex{
  font-size:12px;font-weight:700;color:#64748b;
  font-variant-numeric:tabular-nums;
  font-family:ui-monospace,"Cascadia Code",Consolas,monospace;
}

/* save button */
.cf2-save-row{
  display:flex;justify-content:flex-end;
  margin-top:18px;
}
.cf2-btn-save{
  padding:11px 28px;
  border-radius:16px;
  font-size:14px;font-weight:800;
  background:linear-gradient(135deg,#6366f1,#7c3aed);
  color:#fff;border:none;cursor:pointer;
  box-shadow:0 6px 22px rgba(99,102,241,.28);
  transition:filter .15s,transform .12s,box-shadow .15s;
}
.cf2-btn-save:hover{filter:brightness(1.07);transform:translateY(-2px);box-shadow:0 10px 30px rgba(99,102,241,.38)}
.cf2-btn-save:active{transform:translateY(0)}

/* competitor list ---------------------------------------------- */
.cf2-comp-list{display:flex;flex-direction:column;gap:8px}

.cf2-comp-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 2px 12px rgba(99,102,241,.05);
  transition:box-shadow .12s,border-color .12s;
}
.cf2-comp-row:hover{box-shadow:0 6px 20px rgba(99,102,241,.1);border-color:rgba(99,102,241,.15)}

.cf2-comp-idx{
  flex-shrink:0;
  width:26px;height:26px;
  border-radius:8px;
  background:rgba(238,242,255,.7);
  border:1px solid rgba(99,102,241,.15);
  font-size:12px;font-weight:900;color:#6366f1;
  display:flex;align-items:center;justify-content:center;
}
.cf2-comp-info{flex:1;min-width:0}
.cf2-comp-name{
  font-size:14px;font-weight:800;color:#1e1b4b;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:5px;
}
.cf2-comp-chips{display:flex;flex-wrap:wrap;gap:5px}

.cf2-chip{
  display:inline-flex;align-items:center;
  padding:3px 9px;
  border-radius:999px;
  font-size:11.5px;font-weight:700;
  border:1px solid transparent;
}
.cf2-chip--blue{
  background:rgba(239,246,255,.85);border-color:rgba(59,130,246,.2);color:#2563eb;
}
.cf2-chip--gold{
  background:rgba(254,252,232,.85);border-color:rgba(202,138,4,.22);color:#b45309;
}

/* PDF download button */
.cf2-pdf-btn{
  flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;
  width:54px;height:52px;
  border-radius:14px;
  border:1.5px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.9);
  cursor:pointer;
  font-size:11px;font-weight:800;color:#4f46e5;
  transition:border-color .12s,box-shadow .12s,background .12s,transform .1s;
}
.cf2-pdf-icon{font-size:20px;line-height:1}
.cf2-pdf-btn:hover{
  border-color:rgba(99,102,241,.4);
  box-shadow:0 6px 20px rgba(99,102,241,.14);
  background:rgba(238,242,255,.9);
  transform:translateY(-2px);
}
.cf2-pdf-btn:active{transform:translateY(0)}
.cf2-pdf-btn:disabled,.cf2-pdf-btn--loading{opacity:.55;cursor:wait}

/* responsive --------------------------------------------------- */
@media(max-width:1100px){
  .cf2-root{grid-template-columns:280px 1fr}
  .cf2-settings{grid-column:2}
  .cf2-style-cols{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .cf2-root{grid-template-columns:1fr;padding:16px 14px 40px}
  .cf2-sidebar{position:static}
  .cf2-style-cols{grid-template-columns:1fr}
  .cf2-template-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:540px){
  .cf2-template-grid{grid-template-columns:repeat(3,1fr)}
  .cf2-comp-chips{flex-direction:column}
}
/* ===== END CERTIFICATES PAGE v2 ===== */

/* ===== REPORTS PAGE ===== */
.rp-page{max-width:960px;margin:0 auto;padding:28px 24px 60px}

.rp-banner{display:flex;align-items:center;gap:18px;background:linear-gradient(135deg,#fef9c3,#fde68a);border:1px solid rgba(217,119,6,.25);border-radius:22px;padding:20px 24px;margin-bottom:18px;box-shadow:0 4px 20px rgba(217,119,6,.1)}
.rp-banner-icon{font-size:36px;flex-shrink:0;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.6);border-radius:16px}
.rp-banner-body{flex:1;min-width:0}
.rp-banner-title{font-size:18px;font-weight:800;color:#78350f;line-height:1.3;margin-bottom:3px}
.rp-banner-sub{font-size:13px;color:#92400e;line-height:1.5}
.rp-banner-badge{display:flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.65);border:1px solid rgba(217,119,6,.3);border-radius:16px;padding:10px 20px;flex-shrink:0;min-width:80px}
.rp-count{font-size:30px;font-weight:900;color:#b45309;line-height:1}
.rp-count-label{font-size:11px;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

.rp-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.rp-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;border-radius:999px;padding:5px 14px;border:1px solid transparent}
.rp-legend-item--blue{background:rgba(219,234,254,.85);color:#1d4ed8;border-color:rgba(59,130,246,.2)}
.rp-legend-item--amber{background:rgba(254,243,199,.85);color:#b45309;border-color:rgba(217,119,6,.2)}

.rp-comp-row{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.85);border:1px solid rgba(15,23,42,.09);border-radius:18px;padding:16px 18px;transition:box-shadow .15s,border-color .15s;animation:dbCardIn .32s ease both;backdrop-filter:blur(6px)}
.rp-comp-row--1{animation-delay:.04s}.rp-comp-row--2{animation-delay:.08s}.rp-comp-row--3{animation-delay:.12s}.rp-comp-row--4{animation-delay:.16s}.rp-comp-row--5{animation-delay:.20s}.rp-comp-row--6{animation-delay:.24s}.rp-comp-row--7{animation-delay:.28s}.rp-comp-row--8{animation-delay:.32s}.rp-comp-row--9{animation-delay:.36s}.rp-comp-row--10{animation-delay:.40s}
.rp-comp-row:hover{box-shadow:0 6px 22px rgba(99,102,241,.1);border-color:rgba(99,102,241,.22)}
.rp-comp-num{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(99,102,241,.1);color:#4f46e5;font-size:13px;font-weight:800}
.rp-comp-body{flex:1;min-width:0}
.rp-comp-name{font-size:15px;font-weight:800;color:#1e1b4b;line-height:1.3;margin-bottom:6px}
.rp-comp-meta{display:flex;flex-wrap:wrap;gap:6px}
.rp-comp-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}
.rp-action-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:12px;font-size:13px;font-weight:700;text-decoration:none;border:1px solid transparent;transition:transform .14s,box-shadow .14s,filter .14s;white-space:nowrap}
.rp-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(2,6,23,.12)}
.rp-action-btn:active{transform:translateY(0)}
.rp-action-btn--blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;border-color:rgba(59,130,246,.25)}
.rp-action-btn--blue:hover{filter:brightness(1.04);border-color:rgba(59,130,246,.45)}
.rp-action-btn--amber{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309;border-color:rgba(217,119,6,.25)}
.rp-action-btn--amber:hover{filter:brightness(1.04);border-color:rgba(217,119,6,.45)}
.rp-action-icon{font-size:16px;line-height:1}

@media(max-width:620px){
  .rp-comp-row{flex-wrap:wrap}
  .rp-comp-actions{width:100%;justify-content:flex-end}
  .rp-banner{flex-wrap:wrap}
  .rp-banner-badge{flex-direction:row;gap:8px;min-width:auto;padding:8px 16px}
}
/* ===== END REPORTS PAGE ===== */

/* ===== STAFF REGISTER PAGE ===== */
.rg-login-link{color:#4f46e5;text-decoration:none;font-size:14px;font-weight:600;opacity:.85;transition:opacity .15s}
.rg-login-link:hover{opacity:1}

.rg-page{min-height:calc(100vh - 58px);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:40px 24px 60px;gap:16px}

.rg-card{width:min(540px,100%);background:rgba(255,255,255,.88);border:1px solid rgba(15,23,42,.1);border-radius:24px;padding:32px 28px;box-shadow:0 8px 40px rgba(99,102,241,.1);backdrop-filter:blur(12px);animation:dbCardIn .35s ease both}

.rg-card-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(15,23,42,.08)}
.rg-card-icon{font-size:28px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-radius:18px;flex-shrink:0;box-shadow:0 4px 14px rgba(99,102,241,.18)}
.rg-card-title{font-size:18px;font-weight:800;color:#1e1b4b;line-height:1.3;margin-bottom:3px}
.rg-card-sub{font-size:13px;color:#64748b;line-height:1.4}

.rg-section-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#94a3b8;margin:4px 0 2px}
.rg-required{color:#ef4444;font-size:12px;margin-left:2px}
.rg-auto-badge{display:inline-flex;align-items:center;background:rgba(99,102,241,.1);color:#4f46e5;border-radius:999px;padding:1px 8px;font-size:11px;font-weight:700;margin-left:6px;vertical-align:middle}
.rg-readonly{background:rgba(241,245,249,.9)!important;color:#64748b;cursor:default}

.rg-submit-btn{margin-top:22px;width:100%;padding:13px 16px;border-radius:14px;border:none;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:15px;font-weight:800;cursor:pointer;letter-spacing:.02em;transition:filter .15s,transform .12s,box-shadow .15s;box-shadow:0 4px 18px rgba(99,102,241,.3)}
.rg-submit-btn:hover{filter:brightness(1.07);transform:translateY(-1px);box-shadow:0 8px 24px rgba(99,102,241,.38)}
.rg-submit-btn:active{transform:translateY(0);filter:brightness(.98)}
.rg-hint{color:#94a3b8;font-size:13px;margin-top:14px;margin-bottom:0;text-align:center;line-height:1.5}

.rg-success-card{width:min(540px,100%);background:linear-gradient(135deg,rgba(220,252,231,.9),rgba(209,250,229,.85));border:1px solid rgba(22,163,74,.25);border-radius:24px;padding:32px 28px;box-shadow:0 8px 32px rgba(22,163,74,.12);display:flex;gap:20px;align-items:flex-start;animation:dbCardIn .35s ease both}
.rg-success-icon{font-size:36px;flex-shrink:0;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.7);border-radius:18px}
.rg-success-body{flex:1;min-width:0}
.rg-success-title{font-size:18px;font-weight:800;color:#14532d;margin-bottom:4px}
.rg-success-msg{font-size:14px;color:#166534;margin-bottom:14px;line-height:1.5}
.rg-username-badge{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.7);border:1px solid rgba(22,163,74,.25);border-radius:12px;padding:10px 14px;margin-bottom:16px}
.rg-username-label{font-size:12px;color:#166534;font-weight:600;white-space:nowrap}
.rg-username-val{font-size:16px;color:#14532d;font-weight:900;letter-spacing:.04em}
.rg-goto-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:12px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;text-decoration:none;font-size:14px;font-weight:700;box-shadow:0 4px 14px rgba(22,163,74,.3);transition:filter .15s,transform .12s}
.rg-goto-btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.rg-submit-btn-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}

.fp-card{width:min(620px,100%)}
.fp-card-header{margin-bottom:22px}
.fp-form{display:flex;flex-direction:column;gap:14px}
.fp-hint{color:#64748b;font-size:13px;line-height:1.6;margin:2px 0 0}
.fp-secondary-link{display:inline-flex;align-items:center;justify-content:center;width:100%;margin-top:10px;padding:12px 16px;border-radius:14px;border:1px solid rgba(99,102,241,.22);background:rgba(255,255,255,.72);color:#4f46e5;text-decoration:none;font-size:14px;font-weight:700;transition:background .15s,border-color .15s}
.fp-secondary-link:hover{background:#fff;border-color:rgba(99,102,241,.4)}
.fp-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:8px}
.fp-meta-card{padding:14px 16px;border-radius:18px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.12)}
.fp-meta-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:6px}
.fp-meta-value{font-size:13px;color:#334155;line-height:1.55}
.fp-swal-text{margin:0 0 12px;color:#334155;font-size:14px;line-height:1.7;text-align:left}
.fp-swal-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px;color:#334155;font-size:13px;line-height:1.6;text-align:left}
.fp-swal-list li{margin:0}
@media(max-width:640px){.fp-meta{grid-template-columns:1fr}}
/* ===== END STAFF REGISTER PAGE ===== */
