/* ============================================================================
   rust.yellow51.dev — community theme (LuffyRust-style)
   Atmospheric photo background, floating translucent rounded panels,
   Poppins, centered hero, colorful rounded buttons.
   ========================================================================== */

:root{
  --bg-base:#0f1417;
  --panel:rgba(23,28,33,.86);       /* floating translucent panel */
  --panel-2:rgba(31,38,43,.92);     /* raised */
  --panel-solid:#1b2125;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);

  --accent:#e2562f;                 /* orange-red brand */
  --accent-hot:#f06a3a;
  --accent-deep:#b23c1c;
  --accent-soft:rgba(226,86,47,.16);

  --green:#5f9a39; --green-hot:#6fae44; --green-deep:#3f6b25;
  --blue:#2f74b5;  --blue-hot:#3a86cf; --blue-deep:#1f5081;
  --discord:#5865f2; --discord-hot:#6b78ff;
  --steam:#2a475e; --steam-acc:#66c0f4;
  --gray-btn:#3a4248;

  --ink:#eef1f3;
  --ink-dim:#aeb6bc;
  --ink-faint:#7e878d;

  --ok:#7cc24a; --warn:#e3a93a; --err:#e0573c;

  --radius:12px; --radius-sm:8px;
  --shadow:0 18px 40px -18px rgba(0,0,0,.75);
  --maxw:1200px;

  --f-head:"Poppins","Segoe UI",sans-serif;
  --f-body:"Poppins","Segoe UI",sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--f-body);font-size:16px;line-height:1.6;
  color:var(--ink);background:var(--bg-base);-webkit-font-smoothing:antialiased;
  position:relative;min-height:100vh;
}
/* fixed atmospheric background + dark legibility overlay */
body::before{content:"";position:fixed;inset:0;z-index:-2;
  background:var(--site-bg, url('../img/bg.svg')) center center/cover no-repeat;}
body::after{content:"";position:fixed;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(12,16,19,.62),rgba(11,14,16,.86) 65%,rgba(9,12,14,.93));}
.wrap{position:relative;z-index:1}

a{color:var(--accent-hot);text-decoration:none}
a:hover{color:var(--accent)}
img{max-width:100%;display:block}
hr{border:none;border-top:1px solid var(--line);margin:1.5rem 0}

h1,h2,h3,h4{font-family:var(--f-head);font-weight:700;line-height:1.12;margin:.2em 0 .5em}
h1{font-size:clamp(2rem,5vw,3.3rem);font-weight:800}
h2{font-size:clamp(1.4rem,3vw,2rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
code{font-family:var(--f-mono);font-size:.86em;background:rgba(0,0,0,.35);border:1px solid var(--line);
  padding:.1em .4em;border-radius:5px;color:var(--accent-hot)}
pre{background:rgba(0,0,0,.4);border:1px solid var(--line);border-left:3px solid var(--accent);
  padding:1rem;overflow:auto;border-radius:var(--radius-sm)}
pre code{background:none;border:none;padding:0;color:var(--ink)}
blockquote{border-left:3px solid var(--accent);margin:1rem 0;padding:.4rem 1rem;
  background:rgba(0,0,0,.25);color:var(--ink-dim);border-radius:0 var(--radius-sm) var(--radius-sm) 0}

.container{max-width:var(--maxw);margin:0 auto;padding:0 1.25rem}
.hazard{height:0;margin:0}   /* divider not used in this theme */

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);backdrop-filter:blur(8px);position:relative}
.panel.riveted::before,.panel.riveted::after{display:none}

/* =========================================================================
   TOP NAV — floating translucent rounded bar
   ====================================================================== */
.topbar{position:sticky;top:0;z-index:50;background:transparent;padding:14px 0}
.topbar .bar{display:flex;align-items:flex-start;gap:1.1rem;min-height:62px;height:auto;overflow:visible;padding:10px 18px;
  background:rgba(20,25,29,.82);border:1px solid var(--line-2);border-radius:16px;
  backdrop-filter:blur(12px);box-shadow:0 14px 30px -16px rgba(0,0,0,.8)}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--f-head);font-weight:800;
  font-size:1.25rem;color:var(--ink);letter-spacing:.02em;flex:0 0 auto;white-space:nowrap}
.brand .mark{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:var(--accent);color:#fff;font-family:var(--f-head);font-weight:800;font-size:1.1rem;
  box-shadow:0 0 0 2px rgba(255,255,255,.12),0 4px 12px -4px var(--accent)}
.brand .logo-img{width:42px;height:42px;border-radius:10px;object-fit:cover;
  box-shadow:0 0 0 1px var(--line-2),0 4px 14px -6px rgba(0,0,0,.7)}
.footer .brand .logo-img{width:34px;height:34px;border-radius:8px}
.sidebar .logo img{width:30px;height:30px;border-radius:7px;object-fit:cover}
.brand b{color:var(--accent)}
.nav{display:flex;gap:.6rem;margin-left:auto;align-items:flex-start;flex:1 1 auto;min-width:0}
.nav-scroll{display:flex;gap:.3rem;align-items:center;flex:1 1 auto;min-width:0;flex-wrap:wrap}
.nav-actions{display:flex;align-items:center;gap:.4rem;flex:0 0 auto;min-height:38px}
.nav a{font-family:var(--f-head);font-weight:600;letter-spacing:.02em;font-size:.95rem;
  color:var(--ink-dim);padding:.5rem .85rem;border-radius:9px;text-transform:uppercase}
.nav-scroll a{flex:0 0 auto;white-space:nowrap}
.nav a:hover{color:var(--ink);background:rgba(255,255,255,.06)}
.nav a.active{color:#fff;background:rgba(255,255,255,.07)}
.nav a.active::after{content:"";display:block;height:2px;width:60%;margin:4px auto 0;background:var(--accent);border-radius:2px}
.nav .nav-discord{margin-left:.2rem}
.nav-toggle{display:none;background:rgba(255,255,255,.05);border:1px solid var(--line-2);color:var(--ink);
  font-size:1.4rem;border-radius:9px;width:42px;height:42px;cursor:pointer}

.userchip{display:flex;align-items:center;gap:.5rem;padding:.25rem .6rem .25rem .3rem;
  border:1px solid var(--line-2);border-radius:30px;background:rgba(255,255,255,.05);margin-left:.4rem}
.userchip img{width:30px;height:30px;border-radius:50%;border:1px solid var(--line-2)}
.userchip .nm{font-family:var(--f-head);font-weight:600;font-size:.95rem;max-width:130px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.badge{font-family:var(--f-head);font-weight:700;text-transform:uppercase;font-size:.66rem;
  letter-spacing:.05em;padding:.12rem .42rem;border-radius:5px;border:1px solid var(--line-2);color:var(--ink-dim)}
.badge.super{background:var(--accent);color:#fff;border-color:var(--accent-deep)}
.badge.admin{background:rgba(226,86,47,.2);color:var(--accent-hot);border-color:var(--accent-deep)}

/* =========================================================================
   BUTTONS — rounded, colorful (community style)
   ====================================================================== */
.btn{--bg:rgba(255,255,255,.08);--bd:var(--line-2);--fg:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;
  font-family:var(--f-head);font-weight:600;letter-spacing:.02em;font-size:.95rem;text-transform:uppercase;
  padding:.6rem 1.15rem;border:1px solid var(--bd);border-radius:var(--radius-sm);
  background:var(--bg);color:var(--fg);transition:filter .12s,transform .05s,background .12s}
.btn:hover{filter:brightness(1.1)}
.btn:active{transform:translateY(1px)}
.btn.primary{--bg:var(--accent);--bd:var(--accent-deep);--fg:#fff;box-shadow:0 8px 20px -10px var(--accent)}
.btn.primary:hover{--bg:var(--accent-hot)}
.btn.ghost{--bg:rgba(255,255,255,.06);--bd:var(--line-2)}
.btn.green{--bg:var(--green);--bd:var(--green-deep);--fg:#fff}
.btn.green:hover{--bg:var(--green-hot)}
.btn.blue{--bg:var(--blue);--bd:var(--blue-deep);--fg:#fff}
.btn.blue:hover{--bg:var(--blue-hot)}
.btn.danger{--bg:#8a2c1b;--bd:#5f1c10;--fg:#ffd9cf}
.btn.danger:hover{--bg:#a5371f}
.btn.steam{--bg:#2a475e;--bd:#16384e;--fg:#cfe6f7}.btn.steam:hover{--fg:#fff}
.btn.discord{--bg:var(--discord);--bd:#3b44a0;--fg:#fff}.btn.discord:hover{--bg:var(--discord-hot)}
.btn.lg{font-size:1.05rem;padding:.78rem 1.5rem;border-radius:10px}
.btn.sm{font-size:.8rem;padding:.4rem .8rem}
.btn.block{display:flex;width:100%}
.btn svg{width:18px;height:18px;flex:none}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* =========================================================================
   HERO — centered
   ====================================================================== */
.hero{position:relative;overflow:hidden;text-align:center}
.hero .container{padding-top:4.5rem;padding-bottom:4rem;position:relative}
.hero .kicker{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.3em;
  color:var(--accent-hot);font-size:.85rem;margin-bottom:1rem;display:flex;align-items:center;
  justify-content:center;gap:.6rem}
.hero .kicker::before,.hero .kicker::after{content:"";width:28px;height:2px;background:var(--accent-hot)}
.hero h1{font-family:var(--f-head);font-weight:800;max-width:18ch;margin:0 auto;line-height:1.05;
  font-size:clamp(2.4rem,6vw,4.2rem);text-shadow:0 3px 18px rgba(0,0,0,.5);text-transform:uppercase}
.hero h1 .hl{color:var(--accent)}
.hero p.lede{font-size:1.1rem;color:var(--ink-dim);max-width:60ch;margin:1.1rem auto 0;
  text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.hero .cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.9rem;justify-content:center}
.stamp{display:none}

/* =========================================================================
   SECTION HEADERS
   ====================================================================== */
.section{padding:2.6rem 0}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.4rem}
.section-head h2{margin:0;display:flex;align-items:center;gap:.6rem}
.section-head h2::before{content:"";width:5px;height:1.1em;background:var(--accent);border-radius:3px}
.section-head .tag{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink-faint);font-size:.8rem}
.section-head .more{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:.85rem;letter-spacing:.04em}

/* =========================================================================
   CARDS
   ====================================================================== */
.grid{display:grid;gap:1.2rem}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .14s,border-color .14s,box-shadow .14s;
  backdrop-filter:blur(8px)}
.card:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:var(--shadow)}
.card .thumb{aspect-ratio:16/9;background:#0c0f12 center/cover no-repeat;position:relative}
.card .thumb.placeholder{background:#11161a;display:grid;place-items:center;color:var(--ink-faint);
  font-family:var(--f-head);font-weight:800;font-size:2rem;
  background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 24px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 24px)}
.card .body{padding:1rem 1.1rem 1.15rem;display:flex;flex-direction:column;flex:1;gap:.55rem}
.card h3{margin:0;font-family:var(--f-head);font-weight:700;font-size:1.2rem}
.card h3 a{color:var(--ink)}.card h3 a:hover{color:var(--accent-hot)}
.card .meta{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;font-family:var(--f-head);
  font-weight:500;font-size:.78rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.03em}
.card .desc{color:var(--ink-dim);font-size:.94rem;flex:1}
.card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:.4rem;gap:.5rem}

.chip{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--f-head);font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;padding:.2rem .55rem;border-radius:6px;
  background:rgba(255,255,255,.07);border:1px solid var(--line-2);color:var(--ink-dim)}
.chip.oxide{color:#d7b3ff;border-color:#5a3f7d}
.chip.carbon{color:#9bd0ff;border-color:#305a72}
.chip.both{color:#a7d98a;border-color:#496b35}
.chip.draft{color:var(--warn);border-color:#6f5722}
.dl-count{font-family:var(--f-head);font-weight:700;color:var(--accent-hot);font-size:.85rem}

/* progress bar (community-card motif) */
.bar{height:8px;border-radius:5px;background:rgba(255,255,255,.1);overflow:hidden}
.bar > span{display:block;height:100%;background:var(--green);border-radius:5px}

/* =========================================================================
   STAT TILES
   ====================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat{padding:1.2rem 1.3rem;text-align:center}
.stat .n{font-family:var(--f-head);font-weight:800;font-size:2.3rem;color:var(--accent-hot);line-height:1}
.stat .l{font-family:var(--f-head);font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink-faint);font-size:.78rem;margin-top:.35rem}

/* =========================================================================
   FORMS
   ====================================================================== */
.field{margin-bottom:1.05rem}
.field label{display:block;font-family:var(--f-head);font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;font-size:.82rem;color:var(--ink-dim);margin-bottom:.35rem}
.input,select,textarea{width:100%;font-family:var(--f-body);font-size:1rem;color:var(--ink);
  background:rgba(0,0,0,.35);border:1px solid var(--line-2);border-radius:var(--radius-sm);
  padding:.6rem .8rem;transition:border-color .12s,box-shadow .12s}
textarea{min-height:140px;resize:vertical;font-family:var(--f-mono);font-size:.9rem;line-height:1.5}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.hint{font-size:.82rem;color:var(--ink-faint);margin-top:.3rem}
.row{display:flex;gap:1rem;flex-wrap:wrap}.row > *{flex:1;min-width:180px}
.check{display:flex;align-items:center;gap:.5rem}.check input{width:auto}

/* =========================================================================
   FLASH
   ====================================================================== */
.flashes{position:fixed;top:88px;right:18px;z-index:80;display:flex;flex-direction:column;gap:.55rem;max-width:360px}
.flash{padding:.7rem .9rem;border-radius:var(--radius-sm);border-left:3px solid var(--ink-faint);
  background:var(--panel-2);border:1px solid var(--line);box-shadow:var(--shadow);font-size:.95rem;
  backdrop-filter:blur(8px);animation:slidein .25s ease}
.flash.success{border-left-color:var(--ok)}.flash.error{border-left-color:var(--err)}.flash.info{border-left-color:var(--steam-acc)}
@keyframes slidein{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* =========================================================================
   TABLES
   ====================================================================== */
.table{width:100%;border-collapse:collapse;font-size:.95rem}
.table th{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;
  text-align:left;color:var(--ink-faint);padding:.6rem .7rem;border-bottom:1px solid var(--line-2)}
.table td{padding:.62rem .7rem;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:hover td{background:rgba(255,255,255,.03)}
.table .actions{display:flex;gap:.4rem;justify-content:flex-end}
.muted{color:var(--ink-faint)}

/* =========================================================================
   ARTICLE
   ====================================================================== */
.article{max-width:800px;margin:0 auto}
.article .cover{border-radius:var(--radius);border:1px solid var(--line);margin-bottom:1.5rem}
.article-meta{display:flex;gap:1rem;align-items:center;color:var(--ink-faint);
  font-family:var(--f-head);font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;margin-bottom:1.5rem}
.prose{font-size:1.05rem;line-height:1.78}
.prose h2,.prose h3{margin-top:1.8rem}
.prose img{border-radius:var(--radius-sm);border:1px solid var(--line);margin:1.2rem 0}
img.emoji,.emoji{width:1.4em;height:1.4em;vertical-align:-0.25em;display:inline-block;
  margin:0 .05em;border:0;border-radius:0;background:none}
.prose ul,.prose ol{padding-left:1.4rem}.prose a{text-decoration:underline;text-underline-offset:3px}
.byline{display:flex;align-items:center;gap:.6rem}
.byline img{width:34px;height:34px;border-radius:50%;border:1px solid var(--line-2)}

/* COMMENTS */
.comment{display:flex;gap:.8rem;padding:1rem 0;border-bottom:1px solid var(--line)}
.comment img{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);flex:none}
.comment .who{font-family:var(--f-head);font-weight:600}
.comment .when{color:var(--ink-faint);font-size:.8rem}

/* FILES */
.filelist{display:flex;flex-direction:column;gap:.6rem}
.filerow{display:flex;align-items:center;gap:1rem;padding:.75rem .9rem;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:var(--radius-sm)}
.filerow .fi{flex:1}.filerow .fn{font-family:var(--f-mono);font-size:.9rem;color:var(--ink)}
.filerow .fm{font-size:.8rem;color:var(--ink-faint);font-family:var(--f-head);text-transform:uppercase;letter-spacing:.03em}
.filerow .fn svg{width:20px;height:20px;vertical-align:-4px;margin-right:.4rem}

/* LOGIN */
.auth-wrap{max-width:450px;margin:4rem auto;text-align:center}
.auth-wrap .panel{padding:2.2rem}
.auth-wrap h1{font-family:var(--f-head);font-weight:800}
.auth-divider{display:flex;align-items:center;gap:.8rem;color:var(--ink-faint);
  font-family:var(--f-head);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;margin:1.2rem 0}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line-2)}

/* =========================================================================
   ADMIN
   ====================================================================== */
.admin{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.sidebar{background:rgba(15,19,22,.9);backdrop-filter:blur(10px);
  border-right:1px solid var(--line);padding:1.1rem 0;position:sticky;top:0;height:100vh;overflow:auto}
.sidebar .logo{font-family:var(--f-head);font-weight:800;font-size:1.05rem;padding:0 1.2rem 1rem;color:var(--ink);
  border-bottom:1px solid var(--line);margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}
.sidebar a{display:flex;align-items:center;gap:.6rem;padding:.58rem 1.2rem;color:var(--ink-dim);
  font-family:var(--f-head);font-weight:600;font-size:.93rem;border-left:3px solid transparent}
.sidebar a:hover{background:rgba(255,255,255,.04);color:var(--ink)}
.sidebar a.active{color:#fff;background:rgba(255,255,255,.05);border-left-color:var(--accent)}
.sidebar .grp{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  font-size:.7rem;color:var(--ink-faint);padding:1rem 1.2rem .3rem}
/* site switcher */
.site-switch{margin:0 .8rem .4rem;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.03)}
.site-switch summary{display:flex;align-items:center;gap:.5rem;cursor:pointer;list-style:none;
  padding:.55rem .75rem;font-family:var(--f-head);font-weight:600;color:var(--ink);font-size:.9rem}
.site-switch summary::-webkit-details-marker{display:none}
.site-switch summary::after{content:"▾";margin-left:auto;color:var(--ink-faint)}
.site-switch[open] summary::after{content:"▴"}
.site-switch .dot{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.site-switch .site-list{display:flex;flex-direction:column;padding:.25rem;border-top:1px solid var(--line)}
.site-switch .site-list a{flex-direction:column;align-items:flex-start;gap:0;padding:.45rem .6rem;border-radius:7px;border-left:0}
.site-switch .site-list a small{color:var(--ink-faint);font-size:.72rem}
.site-switch .site-list a.cur{background:rgba(255,255,255,.06);color:#fff}
.site-switch .site-list a.manage{color:var(--accent);font-size:.82rem;margin-top:.15rem}
.admin-main{padding:1.6rem 2rem;min-width:0}
.admin-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.3rem}
.admin-top h1{margin:0;font-size:1.7rem}
.admin .sidebar .mark{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;font-size:.95rem}

/* =========================================================================
   FOOTER
   ====================================================================== */
.footer{border-top:1px solid var(--line);background:rgba(11,14,16,.8);backdrop-filter:blur(8px);margin-top:3rem}
.footer .container{padding:2.4rem 1.25rem;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}
.footer .brand{font-size:1.05rem}
.footer .cols{display:flex;gap:3rem;flex-wrap:wrap}
.footer h4{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink-faint);font-size:.8rem;margin:0 0 .6rem}
.footer a{display:block;color:var(--ink-dim);padding:.18rem 0;font-size:.95rem}
.footer a:hover{color:var(--accent-hot)}
.footer .legal{width:100%;border-top:1px solid var(--line);padding-top:1rem;color:var(--ink-faint);
  font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

/* PAGER + EMPTY */
.pager{display:flex;gap:.45rem;justify-content:center;margin-top:2rem}
.pager a,.pager span{font-family:var(--f-head);font-weight:600;padding:.45rem .85rem;border:1px solid var(--line-2);
  border-radius:var(--radius-sm);background:rgba(255,255,255,.05);color:var(--ink-dim)}
.pager a:hover{color:#fff;border-color:var(--accent)}
.pager .cur{background:var(--accent);color:#fff;border-color:var(--accent-deep)}
.empty{text-align:center;padding:3rem 1rem;color:var(--ink-faint)}
.empty .big{font-family:var(--f-head);font-weight:800;font-size:1.6rem;color:var(--ink-dim);margin-bottom:.4rem;text-transform:uppercase}

/* =========================================================================
   RESPONSIVE
   ====================================================================== */
@media(max-width:900px){
  .grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .admin{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;display:flex;flex-wrap:wrap;gap:.2rem;padding:.6rem}
  .sidebar .logo,.sidebar .grp{width:100%}
  .sidebar a{border-left:none;border-bottom:3px solid transparent;border-radius:8px}
  .sidebar a.active{border-left:none;border-bottom-color:var(--accent)}
}
@media(max-width:680px){
  .topbar .bar{flex-wrap:wrap;height:auto;padding:10px 14px}
  .nav{position:static;width:100%;flex-direction:column;display:none;margin:.4rem 0 0;flex:0 0 auto}
  .nav.open{display:flex}
  .nav-scroll,.nav-actions{flex-direction:column;width:100%;gap:.2rem}
  .nav a,.nav-actions a{width:100%}
  .nav-toggle{display:block;margin-left:auto}
  .grid.cols-3,.grid.cols-2{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .userchip .nm{display:none}
}

/* ── In-content image placement (posts & pages) ─────────────────────────── */
.prose{overflow:hidden}                 /* contain floated images */
.prose .post-img{max-width:100%;height:auto;border-radius:12px;margin:1.1rem 0;display:block}
.prose .post-img.img-center{margin-left:auto;margin-right:auto}
.prose .post-img.img-full{width:100%}
.prose .post-img.img-left{float:left;margin:.4rem 1.4rem 1rem 0}
.prose .post-img.img-right{float:right;margin:.4rem 0 1rem 1.4rem}
.prose .post-fig{margin:1.2rem 0;max-width:100%}
.prose .post-fig.img-center{margin-left:auto;margin-right:auto}
.prose .post-fig.img-full{width:100%}
.prose .post-fig.img-left{float:left;margin:.4rem 1.4rem 1rem 0}
.prose .post-fig.img-right{float:right;margin:.4rem 0 1rem 1.4rem}
.prose .post-fig img{display:block;width:100%;height:auto;border-radius:12px}
.prose .post-fig figcaption{font-size:.85rem;color:var(--ink-dim);text-align:center;margin-top:.5rem}
@media(max-width:680px){
  .prose .post-img.img-left,.prose .post-img.img-right,
  .prose .post-fig.img-left,.prose .post-fig.img-right{float:none;width:100%!important;margin:1rem 0}
}

/* ── Editor toolbar + media library (admin) ─────────────────────────────── */
.editor-tool{border:1px solid var(--line-2);border-radius:12px 12px 0 0;border-bottom:none;
  background:rgba(255,255,255,.03)}
.editor-bar{display:flex;align-items:center;gap:.35rem;padding:.5rem .6rem;flex-wrap:wrap}
#body-editor{border-top-left-radius:0;border-top-right-radius:0}
.media-panel{padding:.6rem .8rem .9rem;border-top:1px solid var(--line-2)}
.media-opts{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;margin-bottom:.6rem}
.media-opts .input{max-width:260px}
.media-opts .mo{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.media-opts .mo-lbl{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint)}
.media-opts .mo label{display:inline-flex;align-items:center;gap:.25rem;font-size:.9rem}
.media-upload{display:flex;align-items:center;gap:.7rem;margin:.3rem 0}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.5rem;
  max-height:280px;overflow:auto;margin-top:.5rem}
.media-thumb{position:relative;border:1px solid var(--line-2);border-radius:8px;overflow:hidden;
  aspect-ratio:1;background:rgba(0,0,0,.2)}
.media-thumb img{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block}
.media-thumb img:hover{opacity:.85}
.media-del{position:absolute;top:3px;right:3px;width:22px;height:22px;border-radius:50%;border:none;
  background:rgba(0,0,0,.65);color:#fff;font-size:1rem;line-height:1;cursor:pointer}
.media-del:hover{background:var(--accent)}

/* ── Page title image (text-or-image page headers) ──────────────────────── */
.article .page-title-img{max-width:100%;height:auto;display:block;border-radius:12px;margin:0 0 .4rem}

/* ── Download upload progress ───────────────────────────────────────────── */
.dl-progress{margin-top:.9rem}
.dl-bar{height:12px;border-radius:7px;background:rgba(255,255,255,.1);overflow:hidden;border:1px solid var(--line-2)}
.dl-bar > span{display:block;height:100%;width:0;background:var(--accent);transition:width .15s ease}
.dl-progress.err .dl-bar > span{background:#e2562f}
.dl-prog-meta{margin-top:.4rem;font-size:.85rem;color:var(--ink-dim)}
.dl-prog-meta strong{color:var(--ink)}
.dl-progress.err .dl-prog-meta,.dl-progress.err .dl-prog-meta strong{color:#e2562f}

/* ── Contact form (drop-in via [contact-form]) ──────────────────────────── */
.contact-form{margin:1.4rem 0}
.contact-form .cf-form .field{margin-bottom:.9rem}
.contact-form .cf-form label{display:block;margin-bottom:.3rem;font-weight:600}
.contact-form .cf-req{color:var(--accent)}
.cf-hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact-ok{padding:.8rem 1rem;border-radius:10px;margin-bottom:1rem;
  background:rgba(60,180,90,.12);border:1px solid rgba(60,180,90,.4);color:#cfead6}
.contact-err{padding:.8rem 1rem;border-radius:10px;margin-bottom:1rem;
  background:rgba(226,86,47,.12);border:1px solid rgba(226,86,47,.45);color:#f2c4b6}

/* ── Contact form: attached-identity panel ──────────────────────────────── */
.cf-identity{display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;margin-bottom:1rem;
  border:1px solid var(--line-2);border-radius:10px;background:rgba(255,255,255,.03)}
.cf-identity img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.cf-identity.cf-signin{justify-content:space-between}
.cf-id-name{font-size:.95rem}
.cf-id-chips{display:flex;gap:.4rem;align-items:center;margin-top:.25rem;flex-wrap:wrap}
.cf-link{font-size:.82rem;text-decoration:underline;color:var(--accent)}

/* ── Admin: maintenance banner ──────────────────────────────────────────── */
.maint-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.8rem 1.1rem;border-radius:10px;margin:1rem 0;border:1px solid var(--line-2)}
.maint-banner > div{display:flex;flex-direction:column;gap:.15rem}
.maint-banner.off{background:rgba(120,200,140,.06);border-color:rgba(120,200,140,.3)}
.maint-banner.on{background:rgba(226,86,47,.1);border-color:rgba(226,86,47,.55)}
.maint-banner .muted{font-size:.85rem}

/* ── Profile: avatar source picker + admin danger button ────────────────── */
.avatar-src{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.2rem}
.avatar-src .asrc{display:flex;align-items:center;gap:.5rem;font-size:.92rem}
.avatar-src input[type=radio]{margin:0}
.btn.danger{background:#b3361f;color:#fff;border-color:#7d2415}
.btn.danger:hover{background:#c63d23}
.admin-table tbody tr:hover{background:rgba(255,255,255,.02)}
