:root{
  --black:#050303;
  --black2:#090607;
  --red:#c41420;
  --red2:#7e0710;
  --white:#fff8f2;
  --muted:#b9aaa6;
  --line:rgba(255,255,255,.12);
  --panel:rgba(255,255,255,.045);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--black);color:var(--white);font-family:Inter,Arial,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1160px,calc(100% - 40px));margin:auto}
.nav{min-height:86px;border-bottom:1px solid rgba(196,20,32,.25);background:rgba(5,3,3,.94);backdrop-filter:blur(14px);position:sticky;top:0;z-index:10}
.nav-inner{min-height:86px;display:flex;align-items:center;justify-content:space-between;gap:26px}
.logo{display:inline-flex;align-items:center;flex:0 0 auto}
.logo img{height:46px;width:auto;max-width:230px;object-fit:contain;mix-blend-mode:screen}
.nav-links{display:flex;gap:30px;align-items:center;color:#d8cbc6;white-space:nowrap}
.nav-links a{font-size:15px;opacity:.86}.nav-links a:hover{opacity:1}
.hero{position:relative;min-height:calc(100vh - 86px);padding:74px 0 86px;overflow:hidden;background:radial-gradient(circle at 18% 10%,rgba(196,20,32,.20),transparent 36%),linear-gradient(180deg,#120507 0%,#050303 74%)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,470px);gap:58px;align-items:center}
.hero-copy{min-width:0}.kicker{color:#ff3140;letter-spacing:.24em;text-transform:uppercase;font-size:12px;font-weight:900;line-height:1.45}
.hero h1,.page-title{font-family:Georgia,'Times New Roman',serif;font-size:clamp(48px,7.2vw,94px);line-height:1;letter-spacing:-.045em;margin:18px 0 20px;max-width:760px;overflow-wrap:normal}
.hero p,.lead{color:#ded2cb;font-size:20px;line-height:1.55;max-width:650px;margin:0}
.hero-actions,.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.btn,button.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 20px;border:1px solid rgba(255,255,255,.24);border-radius:0;background:#111;color:var(--white);font-weight:900;letter-spacing:.02em;cursor:pointer;transition:.16s;font-size:15px;line-height:1.1;text-align:center;white-space:nowrap}
.btn.red{background:var(--red);border-color:var(--red);color:#fff}.btn.red:hover{background:#e01826}.btn.dark:hover,.btn:hover{border-color:rgba(255,255,255,.46);transform:translateY(-1px)}.btn.ghost{background:transparent}.btn.full{width:100%}
.hero-card{border:1px solid var(--line);background:#070505;padding:10px;box-shadow:0 28px 90px rgba(0,0,0,.42);min-width:0}
.hero-card img{height:560px;width:100%;object-fit:cover;object-position:center 58%;filter:brightness(.9) contrast(1.04) saturate(1.05)}
.caption{border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:15px;padding:14px 4px 2px;color:#d9cbc4;font-size:13px;line-height:1.35}
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#080505}
.strip-inner{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px}.strip-item{padding:24px 20px;border-right:1px solid var(--line);min-width:0}.strip-item:last-child{border-right:0}.strip-item b{font-family:Georgia,serif;font-size:23px;line-height:1.15}.strip-item span{display:block;color:var(--muted);margin-top:7px;line-height:1.45}
.section{padding:80px 0;border-top:1px solid rgba(255,255,255,.08)}.section-title{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:30px}.section-title h2{font-family:Georgia,serif;font-size:clamp(34px,5vw,62px);letter-spacing:-.045em;line-height:1;margin:0}.section-title p{color:var(--muted);max-width:440px;line-height:1.55}.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.gallery img{height:285px;width:100%;object-fit:cover;object-position:center 58%;border:1px solid var(--line);filter:brightness(.9) contrast(1.04) saturate(1.04)}
.split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}.panel,.card{border:1px solid var(--line);background:var(--panel);padding:26px;min-width:0}.panel h3,.card h2,.card h3{font-family:Georgia,serif;font-size:clamp(28px,3.2vw,34px);line-height:1.05;letter-spacing:-.035em;margin:0 0 12px}.quiet{color:var(--muted);line-height:1.55}.footer{border-top:1px solid var(--line);padding:34px 0;color:var(--muted)}.footer-inner{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;line-height:1.45}
/* app */
.app-body{background:radial-gradient(circle at 0 0,rgba(196,20,32,.13),transparent 34%),#050303}.app-shell{min-height:100vh;display:grid;grid-template-columns:250px minmax(0,1fr)}.side{height:100vh;position:sticky;top:0;border-right:1px solid var(--line);background:#060404;padding:22px;overflow:auto}.side .logo img{height:44px;max-width:190px}.side-nav{display:grid;gap:6px;margin-top:44px}.side-nav a{padding:13px 10px;border-left:3px solid transparent;color:#cbbfba}.side-nav a.active,.side-nav a:hover{background:rgba(255,255,255,.05);border-color:var(--red);color:#fff}.app-main{padding:38px 44px 90px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:26px;min-width:0}.topbar h1{font-family:Georgia,serif;font-size:clamp(42px,5.8vw,70px);letter-spacing:-.05em;line-height:1;margin:0;overflow-wrap:anywhere}.topbar p{color:var(--muted);margin:8px 0 0;line-height:1.45;max-width:760px}.app-grid{display:grid;grid-template-columns:minmax(290px,.9fr) minmax(0,1.1fr);gap:18px}.form{display:grid;gap:16px}label{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:#c5b6b0;font-weight:900;margin-bottom:8px}input,select{width:100%;min-height:50px;background:#090707;border:1px solid rgba(255,255,255,.22);border-radius:0;color:#fff;padding:0 13px;font:inherit;min-width:0}input:focus,select:focus{outline:2px solid rgba(196,20,32,.35);border-color:var(--red)}select option{background:#100b0c}.choices{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.choice{min-height:48px;border:1px solid rgba(255,255,255,.22);background:#090707;color:#fff;border-radius:0;font-weight:800;cursor:pointer;line-height:1.1;padding:0 8px}.choice.selected{background:rgba(196,20,32,.28);border-color:var(--red)}.notice{border-left:4px solid var(--red);background:rgba(196,20,32,.1);padding:15px;margin-top:14px;color:#f5e9e4;line-height:1.45}.empty{border:1px dashed rgba(255,255,255,.2);padding:24px;text-align:center;color:var(--muted);line-height:1.45}.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.18);padding:5px 8px;font-size:12px;color:#d6cbc6;background:rgba(255,255,255,.04);line-height:1.2;white-space:nowrap}.live-dot{width:8px;height:8px;border-radius:50%;background:#2fe66f;box-shadow:0 0 16px #2fe66f}.person{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;border-bottom:1px solid var(--line);padding:14px 0}.person:last-child{border-bottom:0}.person b{font-size:18px;line-height:1.25}.mini{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.45;overflow-wrap:anywhere}.admin-table{width:100%;border-collapse:collapse;border:1px solid var(--line);background:rgba(255,255,255,.025)}.admin-table th,.admin-table td{text-align:left;padding:13px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top;line-height:1.35}.admin-table th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#c5b6b0}.metric-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:18px}.metric{border:1px solid var(--line);background:rgba(255,255,255,.04);padding:18px;min-width:0}.metric b{display:block;font-family:Georgia,serif;font-size:34px;line-height:1}.metric span{color:var(--muted);font-size:13px;line-height:1.35}.mobile-top{display:none}.bottom-nav{display:none}.badge{display:inline-flex;align-items:center;gap:8px;min-width:0}.initials{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:#fff;font-weight:900;flex:0 0 auto}.admin-alert{border:1px solid rgba(196,20,32,.42);background:linear-gradient(180deg,rgba(196,20,32,.14),rgba(255,255,255,.03));padding:18px;margin-bottom:18px}.admin-alert h2{font-family:Georgia,serif;font-size:clamp(30px,4vw,42px);line-height:1.05;margin:0 0 5px;letter-spacing:-.035em}.login-wrap{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,1fr)}.login-art{background:url('assets/table-1.jpg') center 58%/cover;position:relative;min-width:0}.login-art:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,3,3,.1),#050303)}.login-panel{display:flex;align-items:center;justify-content:center;padding:40px;min-width:0}.login-box{width:min(430px,92vw);min-width:0}.login-box .logo img{height:58px;max-width:270px}.login-box h1{font-family:Georgia,serif;font-size:clamp(48px,7vw,62px);line-height:1;letter-spacing:-.05em;margin:28px 0 14px}.role-links{display:grid;gap:10px;margin-top:24px}.role-link{border:1px solid var(--line);padding:18px;background:rgba(255,255,255,.04)}.role-link:hover{border-color:var(--red)}.role-link b{font-size:18px}.role-link span{display:block;color:var(--muted);margin-top:4px;line-height:1.4}.status-line{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:13px;line-height:1.3;white-space:nowrap;flex:0 0 auto}.pulse{width:8px;height:8px;border-radius:50%;background:#2fe66f;box-shadow:0 0 16px #2fe66f;animation:pulse 1.4s infinite;flex:0 0 auto}.soft-card{background:rgba(255,255,255,.03)}.compact-section{padding-top:0;padding-bottom:24px}.last-section{padding-bottom:0}@keyframes pulse{50%{opacity:.35}}
@media(max-width:980px){.nav-links{display:none}.hero-grid,.split,.login-wrap{grid-template-columns:1fr}.hero-card img{height:420px}.strip-inner{grid-template-columns:1fr}.strip-item{border-right:0;border-bottom:1px solid var(--line)}.strip-item:last-child{border-bottom:0}.gallery{grid-template-columns:1fr 1fr}.app-shell{display:block}.side{display:none}.mobile-top{display:flex;position:sticky;top:0;min-height:68px;z-index:20;align-items:center;justify-content:space-between;gap:14px;background:rgba(5,3,3,.94);border-bottom:1px solid var(--line);padding:10px 16px}.mobile-top .logo img{height:38px;max-width:180px}.app-main{padding:26px 16px 92px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#070505;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));z-index:30}.bottom-nav a{text-align:center;padding:13px 4px;color:var(--muted);font-size:12px}.bottom-nav a.active{color:#fff}.login-art{min-height:230px}.metric-row{grid-template-columns:1fr}.app-grid{grid-template-columns:1fr}.topbar{align-items:flex-start}.person{grid-template-columns:1fr}.person .btn{width:100%}}
@media(max-width:620px){.container{width:min(100% - 28px,1160px)}.logo img{height:38px;max-width:180px}.hero{padding:44px 0 60px;min-height:auto}.hero h1,.page-title{font-size:clamp(44px,14vw,58px);line-height:1.02;letter-spacing:-.035em}.hero p,.lead{font-size:17px}.hero-actions .btn{width:100%}.gallery{grid-template-columns:1fr}.gallery img{height:300px}.section{padding:58px 0}.section-title{display:block}.caption{display:block}.card,.panel{padding:20px}.admin-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.login-box h1{font-size:48px}.choices{grid-template-columns:1fr}.topbar{display:block}.topbar .status-line{margin-top:12px}.btn,button.btn{white-space:normal}.kicker{letter-spacing:.18em}.strip-item b{font-size:21px}}
.btn.small{min-height:34px;padding:8px 10px;font-size:12px;letter-spacing:.06em}

.hidden{display:none!important}.match-mode-card{margin-bottom:18px}.mode-head{display:flex;align-items:center;justify-content:space-between;gap:18px}.mode-toggle{display:flex;gap:10px;flex-wrap:wrap}.steps{display:grid;gap:12px;margin-top:10px}.steps div{display:grid;grid-template-columns:38px minmax(0,1fr);gap:12px;align-items:start;border-bottom:1px solid var(--line);padding:12px 0}.steps div:last-child{border-bottom:0}.steps b{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:#fff;font-family:Georgia,serif}.steps span{color:#ded2cb;line-height:1.45}@media(max-width:760px){.mode-head{display:block}.mode-toggle{margin-top:16px}.mode-toggle .btn{width:100%}}

.small-note{margin-top:16px;font-size:13px;line-height:1.45}

.login-error{
  margin-top:14px;
  padding:12px 14px;
  border:1px solid rgba(210,35,35,.55);
  background:rgba(210,35,35,.11);
  color:#fff;
  font-size:14px;
  line-height:1.45;
}


/* =========================================================
   Responsive V1 polish
   Desktop stays information-rich
   Mobile becomes a deliberate touch-first layout
   ========================================================= */

button,input,select,a{-webkit-tap-highlight-color:transparent}
input,select,button{font-size:16px}
body{overflow-x:hidden}

/* Public header logo */
.nav .logo img{
  width:clamp(220px,23vw,286px);
  height:auto;
  max-width:none;
}
.nav-inner{min-height:96px}

/* Better desktop rhythm */
.app-main{max-width:1500px;width:100%;margin:0 auto}
.card,.panel,.metric,.admin-alert{box-shadow:0 18px 50px rgba(0,0,0,.14)}
.form .btn[type="submit"]{margin-top:4px}

/* Tablet */
@media (max-width:1100px){
  .app-main{padding:32px 28px 94px}
  .app-grid{grid-template-columns:minmax(280px,.95fr) minmax(0,1.05fr)}
  .hero-grid{gap:34px}
}

/* Mobile app layout */
@media (max-width:980px){
  body.app-body{padding-bottom:76px}

  .mobile-top{
    min-height:72px;
    padding:10px max(16px,env(safe-area-inset-right)) 10px max(16px,env(safe-area-inset-left));
    box-shadow:0 8px 30px rgba(0,0,0,.24);
  }
  .mobile-top .logo img{
    width:190px;
    height:auto;
    max-width:56vw;
  }

  .app-main{
    padding:22px max(16px,env(safe-area-inset-right)) calc(104px + env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));
  }

  .topbar{
    margin-bottom:20px;
    display:block;
  }
  .topbar h1{
    font-size:clamp(38px,11vw,54px);
    line-height:1.02;
    overflow-wrap:normal;
  }
  .topbar p{
    font-size:15px;
    line-height:1.5;
    margin-top:9px;
  }
  .topbar .status-line{
    display:inline-flex;
    margin-top:14px;
    padding:8px 10px;
    border:1px solid var(--line);
    background:rgba(255,255,255,.035);
  }

  .app-grid{display:grid;grid-template-columns:1fr;gap:14px}
  .card,.panel{padding:20px 17px}
  .card h2,.card h3,.panel h3{font-size:30px}

  .form{gap:18px}
  label{font-size:11px;margin-bottom:9px}
  input,select{
    min-height:56px;
    padding:0 15px;
    border-color:rgba(255,255,255,.28);
  }

  .choices{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:7px;
  }
  .choice{
    min-height:54px;
    padding:8px 6px;
    font-size:14px;
  }

  .btn,button.btn{
    min-height:54px;
    padding:10px 17px;
    font-size:15px;
  }

  /* Primary action stays easy to reach on player tap-in */
  body[data-page="player"] #tapForm > .btn[type="submit"]{
    position:sticky;
    bottom:84px;
    z-index:12;
    box-shadow:0 14px 30px rgba(0,0,0,.4);
  }

  .bottom-nav{
    grid-template-columns:repeat(auto-fit,minmax(62px,1fr));
    padding-bottom:env(safe-area-inset-bottom);
    box-shadow:0 -10px 32px rgba(0,0,0,.35);
  }
  .bottom-nav a{
    min-height:62px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:10px 5px;
    line-height:1.2;
    border-top:3px solid transparent;
  }
  .bottom-nav a.active{
    color:#fff;
    border-top-color:var(--red);
    background:rgba(196,20,32,.08);
  }

  .metric-row{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:7px;
  }
  .metric{
    padding:14px 10px;
    text-align:center;
  }
  .metric b{font-size:28px}
  .metric span{font-size:11px}

  .person{
    grid-template-columns:minmax(0,1fr);
    padding:17px 0;
  }
  .person .btn{width:100%}

  .mode-head{display:block}
  .mode-toggle{margin-top:14px;display:grid;grid-template-columns:1fr 1fr}
  .mode-toggle .btn{width:100%}

  .notice,.admin-alert{padding:15px}
}

/* Phone-specific public website */
@media (max-width:720px){
  .container{width:min(100% - 30px,1160px)}
  .nav{min-height:78px}
  .nav-inner{min-height:78px}
  .nav .logo img{
    width:215px;
    max-width:70vw;
  }

  .hero{
    padding:38px 0 52px;
    background:radial-gradient(circle at 15% 8%,rgba(196,20,32,.22),transparent 42%),linear-gradient(180deg,#120507 0%,#050303 76%);
  }
  .hero-grid{gap:28px}
  .hero h1,.page-title{
    font-size:clamp(43px,13.2vw,60px);
    line-height:1.01;
    margin:14px 0 18px;
  }
  .hero p,.lead{font-size:17px;line-height:1.55}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:24px}
  .hero-actions .btn{width:100%}
  .hero-card{padding:7px}
  .hero-card img{height:360px;object-position:center 62%}
  .caption{font-size:12px;padding:12px 3px 3px}

  .section{padding:54px 0}
  .section-title{margin-bottom:22px}
  .section-title h2{font-size:42px}
  .section-title p{margin-bottom:0}
  .gallery{gap:9px}
  .gallery img{height:280px}
  .strip-item{padding:20px 4px}
}

/* Small phones */
@media (max-width:520px){
  .app-main{padding-left:13px;padding-right:13px}
  .card,.panel{padding:18px 14px}
  .choices{grid-template-columns:1fr}
  .choice{min-height:52px;text-align:left;padding-left:15px}
  .metric-row{grid-template-columns:1fr 1fr}
  .metric:last-child:nth-child(odd){grid-column:1/-1}

  .login-wrap{display:block}
  .login-art{min-height:150px}
  .login-panel{padding:24px 15px 42px}
  .login-box{width:100%}
  .login-box .logo img{
    width:260px;
    height:auto;
    max-width:80vw;
  }
  .login-box h1{font-size:44px;margin-top:22px}

  /* Convert admin tables into clean mobile cards */
  .admin-table,
  .admin-table thead,
  .admin-table tbody,
  .admin-table tr,
  .admin-table th,
  .admin-table td{
    display:block;
    width:100%;
  }
  .admin-table{
    border:0;
    background:transparent;
    overflow:visible;
  }
  .admin-table thead{display:none}
  .admin-table tbody{display:grid;gap:12px}
  .admin-table tr{
    border:1px solid var(--line);
    background:rgba(255,255,255,.035);
    padding:12px 14px;
  }
  .admin-table td{
    border:0;
    border-bottom:1px solid rgba(255,255,255,.08);
    padding:9px 0;
    display:grid;
    grid-template-columns:minmax(92px,38%) minmax(0,1fr);
    gap:10px;
    text-align:right;
    overflow-wrap:anywhere;
  }
  .admin-table td:last-child{
    border-bottom:0;
    display:block;
    padding-top:13px;
  }
  .admin-table td::before{
    content:attr(data-label);
    text-align:left;
    color:#c5b6b0;
    font-size:10px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
  }
  .admin-table td:last-child::before{display:none}
  .admin-table td .btn{width:100%}
}


/* Mobile logo and login layout refinement */
@media (max-width: 720px) {
  .nav-inner {
    position: relative;
    justify-content: center !important;
  }

  .nav .logo {
    margin: 0 auto;
  }

  .nav .logo img {
    display: block;
    margin: 0 auto;
  }

  .nav-links {
    position: absolute;
    right: 14px;
  }

  .login-page {
    min-height: 100vh;
    background: #050303;
    padding: 0;
  }

  .login-mobile-shell {
    width: 100%;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }

  .login-mobile-logo {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 24px 18px 18px;
    background: #060304;
  }

  .login-mobile-logo img {
    width: 260px;
    max-width: 78vw;
    height: auto;
    display: block;
  }

  .login-mobile-photo {
    width: 100%;
    height: 235px;
    background-image:
      linear-gradient(to bottom, rgba(0,0,0,.03), rgba(0,0,0,.28)),
      url("assets/table-1.jpg");
    background-size: cover;
    background-position: center 62%;
    border-top: 1px solid rgba(196,20,32,.3);
    border-bottom: 1px solid rgba(255,255,255,.08);
  }

  .login-mobile-panel {
    padding: 30px 24px calc(46px + env(safe-area-inset-bottom));
    background: #050303;
  }

  .login-mobile-panel h1 {
    font-size: clamp(42px, 12vw, 58px);
    line-height: 1.02;
    margin: 0 0 14px;
  }

  .login-mobile-panel .quiet {
    line-height: 1.55;
  }

  .login-mobile-panel .form {
    margin-top: 26px;
  }
}

@media (min-width: 721px) {
  .login-mobile-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(420px, .95fr) minmax(500px, 1.05fr);
    grid-template-rows: auto 1fr;
    background: #050303;
  }

  .login-mobile-logo {
    grid-column: 2;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 34px 58px 10px;
  }

  .login-mobile-logo img {
    width: 320px;
    height: auto;
  }

  .login-mobile-photo {
    grid-column: 1;
    grid-row: 1 / span 2;
    min-height: 100vh;
    background-image:
      linear-gradient(to right, rgba(0,0,0,.05), rgba(0,0,0,.4)),
      url("assets/table-1.jpg");
    background-size: cover;
    background-position: center;
  }

  .login-mobile-panel {
    grid-column: 2;
    padding: 44px 58px 64px;
    align-self: start;
    max-width: 680px;
  }
}


/* =========================================================
   Unified production portal additions
   ========================================================= */
:root{
  --success:#4bc47b;
  --warning:#e5ab42;
  --danger:#e24a55;
}
[hidden],.hidden{display:none!important}
button:disabled,.btn:disabled{opacity:.48;cursor:not-allowed}
.auth-error,.auth-success{
  margin-top:14px;padding:13px 14px;border:1px solid var(--line);
  font-size:14px;line-height:1.45
}
.auth-error{border-color:rgba(226,74,85,.6);background:rgba(226,74,85,.1)}
.auth-success{border-color:rgba(75,196,123,.55);background:rgba(75,196,123,.09)}
.portal-note{font-size:13px;line-height:1.5;color:var(--muted);margin-top:16px}
.portal-note a{color:#fff}
.status-success{color:var(--success)}
.status-warning{color:var(--warning)}
.status-danger{color:var(--danger)}
.action-row{display:flex;gap:10px;flex-wrap:wrap}
.action-row .btn{flex:0 0 auto}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th,.admin-table td{padding:14px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
.admin-table th{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted)}
.admin-table td{font-size:14px}
.player-match-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.player-match-actions .btn{min-width:140px}
.session-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.session-actions .btn{min-height:42px;padding:8px 13px}
.nav-spacer{margin-left:auto}
.logo-button{border:0;background:transparent;padding:0}
.password-rules{font-size:12px;color:var(--muted);line-height:1.5;margin-top:8px}
.loading-state{opacity:.65;pointer-events:none}
.pill.pending{border-color:rgba(229,171,66,.5);color:#f2c36e}
.pill.active,.pill.confirmed,.pill.accepted{border-color:rgba(75,196,123,.5);color:#7de2a3}
.pill.inactive,.pill.declined{border-color:rgba(226,74,85,.5);color:#ff7982}
.pill.waiting,.pill.sent{border-color:rgba(255,255,255,.25)}
.empty.compact{padding:18px}
.mobile-only{display:none}
.desktop-only{display:initial}
.login-mobile-panel{max-width:680px}
.login-mobile-panel .logo-inline{display:none}
.login-mobile-photo.admin-photo{background-image:linear-gradient(to bottom,rgba(0,0,0,.08),rgba(0,0,0,.42)),url("assets/table-4.jpg")}
.login-mobile-photo.super-photo{background-image:linear-gradient(to bottom,rgba(0,0,0,.08),rgba(0,0,0,.48)),url("assets/table-6.jpg")}
fieldset{border:0;padding:0;margin:0;min-width:0}
.legend-label{display:block;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:9px;color:#cdbfba}
.toast{
  position:fixed;right:22px;bottom:22px;z-index:9999;max-width:360px;
  padding:14px 16px;border:1px solid var(--line);background:#16090c;color:#fff;
  box-shadow:0 18px 55px rgba(0,0,0,.45);transform:translateY(12px);opacity:0;
  transition:.2s ease
}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{border-color:rgba(226,74,85,.65)}
.toast.success{border-color:rgba(75,196,123,.55)}

@media(max-width:980px){
  .mobile-only{display:initial}
  .desktop-only{display:none!important}
  .action-row{display:grid;grid-template-columns:1fr}
  .action-row .btn{width:100%}
  .player-match-actions{display:grid;grid-template-columns:1fr 1fr}
  .player-match-actions .btn{width:100%;min-width:0}
  .session-actions{justify-content:flex-end}
}

@media(max-width:520px){
  .player-match-actions{grid-template-columns:1fr}
  .table-wrap{overflow:visible}
  .toast{left:13px;right:13px;bottom:84px;max-width:none}
  .admin-table td::before{content:attr(data-label)}
}

.temp-password-result p{margin:10px 0}
.temp-password-box{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:14px;
  padding:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.25)
}
.temp-password-box code{
  flex:1;
  font-size:18px;
  font-weight:800;
  letter-spacing:.04em;
  overflow-wrap:anywhere
}
@media(max-width:520px){
  .temp-password-box{display:grid;grid-template-columns:1fr}
  .temp-password-box .btn{width:100%}
}
