/* Admin-specific styles, layered on top of style.css */

.admin-shell{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem;position:relative;z-index:1}

/* login */
.login-wrap{min-height:calc(100vh - 60px);display:grid;place-items:center;padding:2rem 1.5rem}
.login-card{width:100%;max-width:420px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lift);padding:2.4rem 2rem;position:relative;z-index:1}
.login-card h1{font-family:"Fraunces";font-size:1.6rem;font-weight:600;margin-bottom:.3rem}
.login-card .lead{font-size:.9rem;color:var(--ink-soft);margin-bottom:1.6rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-family:"Spline Sans Mono";margin-bottom:.4rem}
.field input{width:100%;padding:.7rem .9rem;border:1px solid var(--line);border-radius:9px;background:#fff;font-family:"Outfit";font-size:.95rem;color:var(--ink)}
.field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,95,90,.12)}
.btn{cursor:pointer;font-family:"Outfit";font-weight:600;font-size:.9rem;letter-spacing:.02em;border:none;border-radius:99px;padding:.7rem 1.4rem;transition:.2s}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-deep)}
.btn-ghost{background:none;border:1px solid var(--line);color:var(--ink-soft)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-full{width:100%}
.err{color:var(--red);font-size:.84rem;margin-top:.6rem;min-height:1.1rem}

/* admin bar */
.admin-bar{background:var(--teal-deep);color:var(--paper);position:sticky;top:0;z-index:120}
.admin-bar-inner{max-width:var(--maxw);margin:0 auto;padding:.7rem 1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.admin-bar .ab-brand{font-family:"Fraunces";font-weight:600;display:flex;align-items:center;gap:.6rem}
.admin-bar .ab-brand .mark{width:30px;height:30px;border-radius:7px;background:rgba(207,161,74,.18);display:grid;place-items:center;color:var(--gold-bright)}
.admin-bar .pill{font-family:"Spline Sans Mono";font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(207,161,74,.2);color:var(--gold-bright);padding:.25rem .6rem;border-radius:99px}
.admin-bar .spacer{flex:1}
.admin-bar a,.admin-bar button{color:var(--paper)}
.admin-bar .ab-link{font-size:.8rem;text-decoration:none;opacity:.85;padding:.35rem .7rem;border-radius:99px;border:1px solid rgba(255,255,255,.18)}
.admin-bar .ab-link:hover{opacity:1;background:rgba(255,255,255,.1)}

/* dashboard */
.dash-head{padding:2.4rem 0 1.4rem}
.dash-head h1{font-family:"Fraunces";font-size:clamp(1.7rem,4vw,2.4rem);font-weight:600}
.dash-head p{color:var(--ink-soft);max-width:70ch;margin-top:.5rem;font-size:.95rem}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1.4rem 0 2rem}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.2rem}
.stat b{font-family:"Fraunces";font-size:1.8rem;font-weight:600;display:block;line-height:1}
.stat.on b{color:var(--green)}.stat.off b{color:var(--ink-soft)}
.stat span{font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em}

.toolbar{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;margin-bottom:1.4rem}
.toolbar .grow{flex:1}
.search{flex:1;min-width:220px;padding:.6rem .9rem;border:1px solid var(--line);border-radius:9px;background:#fff;font-family:"Outfit";font-size:.9rem}
.search:focus{outline:none;border-color:var(--teal)}
.saved-flag{font-size:.8rem;color:var(--green);opacity:0;transition:.3s;font-family:"Spline Sans Mono"}
.saved-flag.show{opacity:1}

/* admin module group */
.adm-mod{margin-bottom:2rem}
.adm-mod-head{display:flex;align-items:center;gap:.8rem;margin-bottom:.9rem;padding-bottom:.5rem;border-bottom:1px solid var(--line)}
.adm-mod-head .n{font-family:"Spline Sans Mono";font-size:.72rem;color:var(--gold);letter-spacing:.14em}
.adm-mod-head h2{font-family:"Fraunces";font-size:1.25rem;font-weight:600}
.adm-mod-head .count{margin-left:auto;font-size:.76rem;color:var(--ink-soft);font-family:"Spline Sans Mono"}

.adm-q{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.2rem;margin-bottom:.8rem;transition:.25s}
.adm-q.is-on{border-color:var(--green);box-shadow:inset 3px 0 0 var(--green)}
.adm-q-top{display:flex;gap:1rem;align-items:flex-start}
.adm-q .meta{flex:1;min-width:0}
.adm-q .qid{font-family:"Spline Sans Mono";font-size:.66rem;color:var(--gold);letter-spacing:.06em}
.adm-q .pf{font-size:.74rem;color:var(--ink-soft);margin-left:.5rem}
.adm-q .qtext{font-size:.95rem;font-weight:500;margin-top:.35rem}
.adm-q .atext{font-size:.85rem;color:var(--ink-soft);margin-top:.6rem;padding:.7rem .9rem;background:var(--parch);border-radius:8px;border:1px dashed var(--line);display:none}
.adm-q.show-ans .atext{display:block}
.adm-q .row2{display:flex;gap:.8rem;align-items:center;margin-top:.7rem}
.adm-q .peek{font-size:.78rem;color:var(--teal);background:none;border:none;cursor:pointer;text-decoration:underline;font-family:"Outfit";padding:0}

/* toggle switch */
.switch{position:relative;display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;flex:0 0 auto;user-select:none}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch .track{width:46px;height:26px;border-radius:99px;background:var(--line);transition:.25s;position:relative;flex:0 0 auto}
.switch .track::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:.25s}
.switch input:checked + .track{background:var(--green)}
.switch input:checked + .track::after{transform:translateX(20px)}
.switch .lbl{font-size:.78rem;font-weight:600;font-family:"Spline Sans Mono";letter-spacing:.05em;min-width:74px}
.switch input:checked ~ .lbl{color:var(--green)}
.switch:not(:has(input:checked)) .lbl{color:var(--ink-soft)}

.empty{text-align:center;padding:3rem 1rem;color:var(--ink-soft);font-style:italic}

@media(max-width:560px){
  .adm-q-top{flex-direction:column}
  .switch{align-self:flex-start}
}
