:root{
  --bg:#030303;
  --bg2:#090909;
  --panel:#0d0d0d;
  --panel2:#141414;
  --line:#2d2d2d;
  --line2:#4e4e4e;
  --txt:#e9e9e9;
  --muted:#a4a4a4;
  --boot:#d4ff25;
  --accent:#d4ff25;
  --shadow:0 18px 40px rgba(0,0,0,.55);
}
*{box-sizing:border-box}
html,body{
  margin:0;
  width:100%;
  height:100%;
  overflow:hidden;
  font-family:Consolas, "Courier New", monospace;
  background:#000;
  color:var(--txt);
}
button,textarea,input{
  font:inherit;
}
.hidden{display:none!important}

#bootScreen{
  position:fixed;
  inset:0;
  background:#000;
  color:var(--boot);
  padding:18px 20px;
  z-index:99999;
  display:flex;
  flex-direction:column;
}
#bootOutput{
  margin:0;
  white-space:pre-wrap;
  line-height:1.33;
  font-size:14px;
  flex:1;
  overflow:auto;
}
.boot-status{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:10px;
}
.boot-progress-wrap{
  width:100%;
  height:8px;
  border:1px solid rgba(212,255,37,.45);
  background:#071000;
}
#bootProgress{
  width:0%;
  height:100%;
  background:linear-gradient(90deg,#8cc800,#d4ff25);
}
#bootHint{
  font-size:14px;
  opacity:.9;
}

#desktop{
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(212,255,37,.06), transparent 24%),
    radial-gradient(circle at bottom left, rgba(212,255,37,.04), transparent 20%),
    linear-gradient(180deg, #060606, #090909 55%, #040404);
}
#desktopNoise{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.055;
  background-image:
    linear-gradient(rgba(255,255,255,.15) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.15) 1px, transparent 1px);
  background-size:3px 3px, 3px 3px;
  mix-blend-mode:soft-light;
}
#desktopIcons{
  position:absolute;
  top:18px;
  left:16px;
  display:flex;
  flex-direction:column;
  gap:14px;
  z-index:5;
}
.desktop-icon{
  width:92px;
  padding:0;
  border:none;
  background:transparent;
  color:#f2f2f2;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  cursor:pointer;
}
.desktop-icon:hover .icon-glyph{
  box-shadow:0 0 0 1px rgba(212,255,37,.28) inset, 0 0 22px rgba(212,255,37,.08);
}
.icon-glyph{
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  border:1px solid #5a5a5a;
  background:linear-gradient(180deg,#141414,#0a0a0a);
  color:var(--accent);
  font-size:22px;
}
.icon-label{
  font-size:12px;
  line-height:1.2;
  text-align:center;
  text-shadow:0 1px 2px rgba(0,0,0,.8);
}

#taskbar{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:44px;
  background:rgba(10,10,10,.97);
  border-top:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 10px;
  z-index:30;
}
#startButton{
  min-width:72px;
  height:30px;
  border:1px solid #575757;
  background:linear-gradient(180deg,#171717,#101010);
  color:var(--accent);
  cursor:pointer;
  font-weight:700;
}
#taskbarApps{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  flex:1;
}
.taskbar-app{
  max-width:180px;
  height:29px;
  padding:0 10px;
  border:1px solid #313131;
  background:#141414;
  color:#ddd;
  cursor:pointer;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.taskbar-app.active{
  border-color:#788e18;
  color:#fff;
}
#taskbarClock{
  min-width:150px;
  text-align:right;
  color:#d8d8d8;
  font-size:13px;
}

#startMenu{
  position:absolute;
  left:10px;
  bottom:54px;
  width:220px;
  border:1px solid #3f3f3f;
  background:#0d0d0d;
  box-shadow:var(--shadow);
  z-index:35;
  overflow:hidden;
}
.start-header{
  padding:12px 12px 10px;
  color:var(--accent);
  border-bottom:1px solid #262626;
  background:linear-gradient(180deg,#141414,#101010);
}
.start-item{
  width:100%;
  border:none;
  border-bottom:1px solid #1e1e1e;
  background:#101010;
  color:#ededed;
  text-align:left;
  padding:12px;
  cursor:pointer;
}
.start-item:hover{
  background:#171717;
}

.window{
  position:absolute;
  width:560px;
  height:360px;
  background:#0f0f0f;
  border:1px solid #4a4a4a;
  box-shadow:var(--shadow);
  overflow:hidden;
  z-index:20;
}
.window.maximized{
  top:8px!important;
  left:8px!important;
  width:calc(100vw - 16px)!important;
  height:calc(100vh - 52px)!important;
}
.window-header{
  height:38px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 8px 0 12px;
  background:linear-gradient(180deg,#1e1e1e,#131313);
  border-bottom:1px solid #282828;
  user-select:none;
  cursor:move;
}
.window-title{
  font-size:14px;
  color:#f0f0f0;
}
.window-actions{
  display:flex;
  gap:6px;
}
.window-actions button{
  width:30px;
  height:28px;
  border:1px solid #474747;
  background:#111;
  color:#f1f1f1;
  cursor:pointer;
}
.window-content{
  height:calc(100% - 38px);
  padding:14px;
  overflow:auto;
  font-size:14px;
  line-height:1.62;
}
.about-wrap{
  max-width:640px;
}
.about-title{
  color:var(--accent);
  font-size:14px;
  margin-bottom:12px;
}
.terminal-screen{
  width:100%;
  min-height:100%;
  background:#090909;
  border:1px solid #272727;
  padding:12px;
  color:var(--accent);
  white-space:pre-wrap;
}
.link-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
}
.link-card{
  border:1px solid #2f2f2f;
  background:#111;
  padding:12px;
}
.link-card strong{
  display:block;
  color:var(--accent);
  margin-bottom:6px;
}
.link-card a{
  color:#f3f3f3;
  text-decoration:none;
}
.link-card a:hover{
  text-decoration:underline;
}
.muted{
  color:var(--muted);
  font-size:12px;
}
.auth-wrap, .contact-wrap{
  max-width:460px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.panel-title{
  color:var(--accent);
  font-size:14px;
}
.field, .field-textarea{
  width:100%;
  border:1px solid #2d2d2d;
  background:#0a0a0a;
  color:#f1f1f1;
  padding:10px 12px;
  outline:none;
}
.field-textarea{
  min-height:130px;
  resize:vertical;
}
.action-btn{
  width:max-content;
  min-width:140px;
  border:1px solid #556616;
  background:linear-gradient(180deg,#141a06,#101306);
  color:#eaf7a4;
  padding:10px 14px;
  cursor:pointer;
}
.status-box{
  border:1px solid #2d2d2d;
  background:#0b0b0b;
  color:#d7d7d7;
  padding:10px 12px;
  min-height:44px;
}
.abroad-content{
  border:1px solid #2d2d2d;
  background:#0a0a0a;
  padding:12px;
  display:none;
}
.abroad-content.show{
  display:block;
}
@media (max-width:720px){
  #bootOutput{font-size:15px}
  .window{
    width:94vw;
    height:64vh;
    left:3vw!important;
    top:8vh!important;
  }
}


.terminal-shell{
  display:flex;
  flex-direction:column;
  height:100%;
  gap:10px;
}
.terminal-screen{
  flex:1;
  min-height:0;
  background:#090909;
  border:1px solid #272727;
  padding:12px;
  color:var(--accent);
  white-space:pre-wrap;
  overflow:auto;
}
.terminal-input-row{
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid #2b2b2b;
  background:#0a0a0a;
  padding:10px 12px;
}
.terminal-prompt{
  color:var(--accent);
  flex:0 0 auto;
}
.terminal-input{
  flex:1;
  min-width:0;
  border:none;
  outline:none;
  background:transparent;
  color:#f1f1f1;
}
.term-response{
  color:#d8d8d8;
}
.term-error{
  color:#ff8f8f;
}
.term-accent{
  color:var(--accent);
}

#desktop::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:min(32vw,420px);
  height:min(32vw,420px);
  transform:translate(-50%,-50%);
  background-image:url('doa_poseidon_logo.png');
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  opacity:0.14;
  pointer-events:none;
  z-index:0;
  animation:doaLogoFloat 8s ease-in-out infinite;
}

@keyframes doaLogoFloat{
  0%,100%{transform:translate(-50%,-50%); opacity:0.13;}
  50%{transform:translate(-50%,calc(-50% - 6px)); opacity:0.17;}
}

#cornerAuth{
  position:absolute;
  right:14px;
  bottom:54px;
  display:flex;
  gap:10px;
  z-index:34;
}
.corner-auth-btn{
  width:86px;
  height:42px;
  border:1px solid #353535;
  background:linear-gradient(180deg,#131313,#0b0b0b);
  color:#f0f0f0;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.corner-auth-btn:hover{
  border-color:#676767;
  background:linear-gradient(180deg,#171717,#0e0e0e);
}
#authModal{
  position:fixed;
  inset:0;
  z-index:999999;
}
.auth-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.62);
  backdrop-filter:blur(2px);
}
.auth-modal-card{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(92vw,420px);
  background:#0d0d0d;
  border:1px solid #3b3b3b;
  box-shadow:0 22px 60px rgba(0,0,0,.55);
  padding:18px;
}
.auth-modal-title{
  color:var(--accent);
  font-size:18px;
  margin-bottom:6px;
}
.auth-modal-subtitle{
  color:#cfcfcf;
  font-size:13px;
  margin-bottom:14px;
}
.auth-sms-row{
  display:flex;
  gap:10px;
  margin-top:10px;
}
.auth-sms-row .field{
  flex:1;
}
.auth-modal-actions{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(140px,140px) minmax(110px,110px);
  gap:10px;
  align-items:stretch;
  margin-top:12px;
}
.auth-modal-actions > *{min-width:0;}
.auth-close-btn{
  min-width:110px;
  border:1px solid #404040;
  background:#111;
  color:#f1f1f1;
  padding:10px 14px;
  cursor:pointer;
}


/* Fun games */
.fun-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.fun-card{
  border:1px solid #2f2f2f;
  background:#111;
  padding:12px;
}
.fun-card strong{
  display:block;
  color:var(--accent);
  margin-bottom:6px;
}
.fun-btn{
  margin-top:10px;
  min-width:110px;
  border:1px solid #556616;
  background:linear-gradient(180deg,#141a06,#101306);
  color:#eaf7a4;
  padding:8px 12px;
  cursor:pointer;
}
.fun-panel{
  border:1px solid #2f2f2f;
  background:#090909;
  padding:12px;
}
.fun-panel-title{
  color:var(--accent);
  font-size:14px;
  margin-bottom:8px;
}
.snake-canvas{
  display:block;
  margin-top:10px;
  background:#050505;
  border:1px solid #232323;
}
.reaction-box{
  margin-top:10px;
  min-height:90px;
  border:1px solid #2f2f2f;
  background:#181818;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  user-select:none;
}
.reaction-box.go{
  background:#224c18;
  color:#f2f2f2;
}
.dice-result{
  margin-top:12px;
  font-size:28px;
  color:#f1f1f1;
}
.guess-row,.rps-row{
  display:flex;
  gap:10px;
  margin-top:10px;
  flex-wrap:wrap;
}
.guess-input{
  max-width:140px;
}
.memory-grid{
  display:grid;
  grid-template-columns:repeat(4,60px);
  gap:10px;
  margin-top:12px;
}
.memory-card{
  width:60px;
  height:60px;
  border:1px solid #313131;
  background:#131313;
  color:#f4f4f4;
  cursor:pointer;
}
.memory-card.matched{
  border-color:#788e18;
  color:#d4ff25;
}
.ttt-grid{
  display:grid;
  grid-template-columns:repeat(3,70px);
  gap:8px;
  margin-top:12px;
}
.ttt-cell{
  width:70px;
  height:70px;
  border:1px solid #313131;
  background:#131313;
  color:#f4f4f4;
  font-size:24px;
  cursor:pointer;
}

/* Auth success */
.auth-status-success{
  display:flex;
  align-items:center;
  gap:8px;
  color:#67e08a;
  font-weight:700;
}
.auth-status-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#67e08a;
}
.auth-countdown-row{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:6px;
  color:#8bd9a2;
  font-size:12px;
}
#authStatus.success{
  border-color:rgba(103,224,138,.35);
  background:rgba(18,48,28,.48);
}

/* Game floating windows */
.game-floating-window{
  position:fixed;
  width:420px;
  max-width:92vw;
  max-height:80vh;
  background:#0c0c0c;
  border:1px solid #333;
  z-index:9999;
  box-shadow:0 0 20px rgba(0,0,0,0.8);
}
.game-window-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 10px;
  background:#111;
  border-bottom:1px solid #333;
  font-size:12px;
  cursor:move;
}
.game-window-body{
  padding:12px;
  max-height:calc(80vh - 40px);
  overflow:auto;
}
.game-window-close{
  background:none;
  border:none;
  color:#ccc;
  cursor:pointer;
  font-size:14px;
}

.pass-code-intro{
  margin-bottom:12px;
  border:1px solid rgba(212,255,37,.18);
  background:linear-gradient(180deg, rgba(26,26,26,.95), rgba(12,12,12,.95));
  padding:12px;
}
.pass-code-head{
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--accent);
  margin-bottom:10px;
}
.pass-code-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--accent);
}
.pass-code-lines{
  display:flex;
  flex-direction:column;
  gap:8px;
  color:#d8d8d8;
  font-size:13px;
  line-height:1.45;
}
.pass-code-lines span{
  color:#f2f2f2;
  font-weight:700;
}



.auth-mode-info{
  margin-bottom:12px;
  border:1px solid rgba(212,255,37,.14);
  background:rgba(212,255,37,.05);
  color:#e3edb0;
  padding:10px 12px;
  font-size:12px;
  line-height:1.45;
}
.auth-fields{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.auth-sms-row.hidden{display:none;}
.action-btn:disabled{
  opacity:.55;
  cursor:not-allowed;
}


.secure-panel-wrap{
  max-width:760px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.secure-panel-body{
  display:block;
}
.secure-placeholder-card{
  border:1px solid #2f2f2f;
  background:#0a0a0a;
  padding:18px;
  min-height:180px;
}
.secure-placeholder-title{
  color:var(--accent);
  font-size:18px;
  margin-bottom:12px;
}
.secure-placeholder-text{
  color:#e2e2e2;
  line-height:1.7;
}

.secure-panel-wrap{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.secure-panel-body{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.secure-placeholder-card,
.admin-card,
.admin-stat-card,
.admin-user-item,
.admin-log-item{
  border:1px solid #2d2d2d;
  background:#0a0a0a;
  padding:12px;
}
.secure-placeholder-title,
.admin-card-title,
.admin-stat-value{
  color:var(--accent);
}
.admin-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:12px;
}
.admin-column{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.admin-stats-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.admin-stat-label{
  color:var(--muted);
  font-size:12px;
  margin-bottom:6px;
}
.admin-stat-value{
  font-size:22px;
  font-weight:700;
}
.admin-form-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.admin-form-grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.admin-inline-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.admin-user-list,
.admin-log-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-height:340px;
  overflow:auto;
}
.admin-user-item{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.admin-user-actions{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.admin-check-row{
  display:flex;
  align-items:center;
  gap:8px;
  color:#d7d7d7;
  margin-top:10px;
}
.admin-template-body{
  min-height:180px;
}
@media (max-width:980px){
  .admin-grid{grid-template-columns:1fr;}
  .admin-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .admin-form-grid-2{grid-template-columns:1fr;}
  .admin-user-item{flex-direction:column;}
  .admin-user-actions{flex-direction:row; flex-wrap:wrap;}
}


.auth-link-btn{
  min-width:150px;
  border:1px solid #404040;
  background:#111;
  color:#dcdcdc;
  padding:10px 14px;
  cursor:pointer;
}
.auth-link-btn:hover{
  border-color:#5b5b5b;
}
.admin-inline-field{
  min-width:220px;
  width:auto;
  flex:1 1 220px;
}
.admin-template-top{
  align-items:center;
}
.admin-card-title{
  margin-bottom:10px;
  font-size:14px;
}
.admin-template-help{
  margin-top:8px;
}
@media (max-width:720px){
  .admin-stats-grid{grid-template-columns:1fr;}
}


.auth-modal-actions{
  display:grid;
  grid-template-columns:1.15fr 1fr 1fr;
  gap:10px;
  margin-top:12px;
}
.auth-modal-actions > button{
  width:100%;
  min-width:0;
  min-height:58px;
}
.auth-link-btn,
.auth-close-btn,
.auth-modal-actions .action-btn{
  white-space:normal;
  line-height:1.25;
}

.admin-shell{
  display:grid;
  grid-template-columns:220px minmax(0,1fr);
  gap:12px;
}
.admin-tree{
  border:1px solid #2d2d2d;
  background:#0a0a0a;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:12px;
  align-self:start;
  position:sticky;
  top:0;
}
.admin-tree-title{
  color:var(--accent);
  font-size:14px;
  font-weight:700;
}

.admin-tree-head{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
}
.admin-tree-head-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  width:100%;
}
.admin-tree-head-btn{
  min-width:0;
  width:100%;
  min-height:40px;
  padding:8px 10px;
}
.admin-logout-btn{
  min-width:0;
  width:100%;
  min-height:40px;
  padding:8px 10px;
}
.panel-logout-btn,
.admin-logout-btn{
  border:1px solid rgba(190,52,52,.8)!important;
  background:linear-gradient(180deg,#3a1010,#240909)!important;
  color:#ffd7d7!important;
}
.panel-logout-btn:hover,
.admin-logout-btn:hover{
  background:linear-gradient(180deg,#4a1414,#2d0b0b)!important;
  border-color:rgba(220,80,80,.95)!important;
}
.secure-card-actions{
  margin-top:14px;
  display:flex;
  justify-content:flex-end;
}

.admin-log-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:6px;
}
.admin-log-status{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#d8d8d8;
}
.admin-log-item.warn{
  border-color:rgba(255,193,7,.28);
}
.admin-log-item.fail{
  border-color:rgba(255,109,109,.28);
}
.admin-log-item.success{
  border-color:rgba(103,224,138,.28);
}
.admin-tree-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.admin-tree-group-label{
  color:var(--muted);
  font-size:12px;
  padding-left:4px;
}
.admin-tree-item{
  width:100%;
  text-align:left;
  border:1px solid #2d2d2d;
  background:#101010;
  color:#e8e8e8;
  padding:10px 12px 10px 20px;
  cursor:pointer;
  position:relative;
}
.admin-tree-item::before{
  content:"▸";
  position:absolute;
  left:8px;
  color:var(--accent);
  opacity:.85;
}
.admin-tree-item.active{
  border-color:#556616;
  background:linear-gradient(180deg,#141a06,#101306);
  color:#f1f6cf;
}
.admin-main{
  min-width:0;
}
.admin-section{
  display:none;
}
.admin-section.active{
  display:block;
}
.admin-section .admin-card{
  min-height:100%;
}

@media (max-width:900px){
  .admin-shell{
    grid-template-columns:1fr;
  }
  .admin-tree{
    position:relative;
    top:auto;
  }
}
@media (max-width:560px){
  .auth-modal-actions{
    grid-template-columns:1fr;
  }
}

.auth-link-btn{
  width:100%;
  border:1px solid #404040;
  background:#111;
  color:#f1f1f1;
  padding:10px 14px;
  cursor:pointer;
  text-align:center;
}
.admin-tree-item{
  text-align:left;
}
.admin-tree-group-label{
  color:#9ea85f;
  font-size:12px;
  margin:10px 0 6px;
}
@media (max-width: 640px){
  .auth-modal-actions{grid-template-columns:1fr;}
}


.auth-google-row{
  display:flex;
  gap:10px;
  margin-top:10px;
}
.auth-google-row.hidden{display:none;}
.auth-link-btn{
  width:100%;
  min-width:0;
  border:1px solid #3a3a3a;
  background:#111;
  color:#f1f1f1;
  padding:10px 12px;
  cursor:pointer;
  line-height:1.2;
  white-space:normal;
}
.admin-check-card{
  min-height:44px;
  border:1px solid #2d2d2d;
  background:#0b0b0b;
  padding:10px 12px;
}

.auth-modal-subtitle:empty{display:none;}

.contact-wrap{
  max-width:none;
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.contact-wrap .field-textarea{
  min-height:220px;
  flex:1 1 auto;
}
.contact-wrap .contact-status{
  min-height:52px;
}
.window[data-app="contact"] .window-content{
  overflow:auto;
  display:flex;
}
.window[data-app="contact"] .contact-wrap{
  padding-right:4px;
}

.admin-message-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-height:520px;
  overflow:auto;
}
.admin-message-item{
  border:1px solid #2d2d2d;
  background:#0a0a0a;
  padding:12px;
}
.admin-message-text{
  margin-top:10px;
  white-space:pre-wrap;
  line-height:1.6;
  color:#e2e2e2;
}
.admin-modal{
  position:fixed;
  inset:0;
  z-index:20000;
}
.admin-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.62);
  backdrop-filter:blur(2px);
}
.admin-modal-card{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(92vw,560px);
  background:#0d0d0d;
  border:1px solid #3b3b3b;
  box-shadow:0 22px 60px rgba(0,0,0,.55);
  padding:18px;
}
.admin-modal-actions{
  grid-template-columns:1fr 1fr !important;
}


.admin-log-filters{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:10px;}
#adminLogFilterStatus{margin-bottom:10px;}
.contact-wrap .contact-status{min-height:52px;white-space:normal;word-break:break-word;}
@media (max-width:900px){.admin-log-filters{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:560px){.admin-log-filters{grid-template-columns:1fr;}}


/* Final UI sizing patch */
.window[data-app="contact"] .window-content{padding:16px 16px 14px;overflow:auto;}
.window[data-app="contact"] .contact-wrap{max-width:none;min-height:100%;display:grid;grid-template-rows:auto auto auto minmax(280px,1fr) auto auto;gap:12px;}
.window[data-app="contact"] .contact-message{min-height:280px;height:100%;}
.window[data-app="contact"] .contact-send-btn{min-height:46px;}
.window[data-app="contact"] .contact-status{min-height:64px;display:flex;align-items:center;padding:12px;line-height:1.45;}
.window[data-app="links"] .window-content{padding:16px;overflow:auto;}
.window[data-app="links"] .fun-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;}
.window[data-app="links"] .fun-card{min-height:120px;}
.game-floating-window{width:min(760px,94vw);max-width:94vw;max-height:86vh;}
.game-window-body{padding:14px;max-height:calc(86vh - 40px);}
.game-floating-window[data-game="snake"],
.game-floating-window[data-game="memory"],
.game-floating-window[data-game="tictactoe"]{width:min(620px,94vw);}
.game-floating-window .fun-panel{min-height:420px;}
.game-floating-window[data-game="reaction"] .fun-panel,
.game-floating-window[data-game="dice"] .fun-panel,
.game-floating-window[data-game="guess"] .fun-panel,
.game-floating-window[data-game="coin"] .fun-panel,
.game-floating-window[data-game="rps"] .fun-panel{min-height:300px;}



.admin-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px;}
.admin-subtitle{color:var(--accent);font-size:13px;margin:6px 0 10px;}
.admin-split-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:14px;align-items:start;}
.admin-visitor-list,.admin-city-list{display:flex;flex-direction:column;gap:10px;max-height:560px;overflow:auto;}
.admin-visitor-item,.admin-city-item{border:1px solid #2d2d2d;background:#0a0a0a;padding:12px;}
.admin-visitor-item.new{border-color:rgba(103,224,138,.3);}
.admin-visitor-item.returning{border-color:rgba(113,164,255,.28);}
.admin-visitor-summary-grid{margin:12px 0 14px;}
.admin-message-item.is-hidden{opacity:.72;border-color:rgba(255,193,7,.28);}
.admin-message-actions .auth-close-btn{min-width:90px;}
.admin-tree-refresh-btn{min-width:0;width:100%;}
.admin-check-row.compact{margin-top:0;}
.window[data-app="securepanel"] .window-content{padding:10px;overflow:auto;}
.window[data-app="securepanel"] .admin-shell{grid-template-columns:230px minmax(760px,1fr);gap:12px;align-items:start;width:100%;min-width:0;}
.window[data-app="securepanel"] .admin-tree{padding:10px;}
.window[data-app="securepanel"] .admin-main{min-width:0;width:100%;overflow:visible;}
.window[data-app="securepanel"] .admin-section.active{display:block;width:100%;}
.window[data-app="securepanel"] .admin-card{min-width:0;width:100%;overflow:visible;}
.window[data-app="securepanel"] .admin-log-list,.window[data-app="securepanel"] .admin-message-list,.window[data-app="securepanel"] .admin-visitor-list,.window[data-app="securepanel"] .admin-city-list{max-height:480px;}
.window[data-app="securepanel"]{width:min(1240px,calc(100vw - 24px));height:min(820px,calc(100vh - 28px));min-width:1080px;min-height:760px;max-width:calc(100vw - 24px);max-height:calc(100vh - 28px);}
@media (max-width:1180px){.admin-split-grid{grid-template-columns:1fr;}.window[data-app="securepanel"] .admin-shell{grid-template-columns:1fr;}.window[data-app="securepanel"]{min-width:0;width:96vw;max-width:96vw;height:90vh;max-height:90vh;}}

.admin-tree{min-width:0;}
.window[data-app="securepanel"] .admin-main{overflow-x:auto;overflow-y:visible;}
