/* ===== Peak Puzzle ===== */

/* --- Tokens --- */
:root{
  --bg:#f6f4ee;
  --surface:#ffffff;
  --ink:#17140f;
  --ink-soft:#574f44;
  --ink-faint:#8d867a;
  --rule:rgba(23,20,15,.14);
  --rule-strong:rgba(23,20,15,.34);
  --accent:#e8743b;
  --accent-2:#2f6f5b;
  --tile-sudoku:#e0683a;
  --tile-words:#2f6f5b;
  --tile-cross:#c39a32;
  --tile-kakuro:#6f5aa6;
  --radius:10px;
  --font-display:"Newsreader", Georgia, "Times New Roman", serif;
  --font-ui:"Libre Franklin", system-ui, sans-serif;
}

/* --- Reset --- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--bg); color:var(--ink); font-family:var(--font-ui); -webkit-font-smoothing:antialiased; line-height:1.55}
a{color:inherit; text-decoration:none}
.wrap{max-width:1000px; margin:0 auto; padding:0 28px}

/* --- Header --- */
.site-head{border-bottom:1px solid var(--rule); background:var(--bg)}
.site-head .wrap{display:flex; align-items:center; justify-content:space-between; padding:18px 28px}
.brand{display:flex; align-items:baseline; gap:9px}
.peak{width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:17px solid var(--accent)}
.brand .name{font-family:var(--font-display); font-weight:600; font-size:26px; line-height:1; letter-spacing:-.01em; white-space:nowrap}
.nav{display:flex; align-items:center; gap:4px}
.nav a{font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft);
  padding:8px 13px; border-radius:7px; transition:color .15s, background .15s}
.nav a:hover, .nav a.on{color:var(--ink); background:rgba(23,20,15,.05)}

/* --- Footer --- */
.site-foot{border-top:1px solid var(--rule); padding:26px 0 46px; margin-top:48px}
.site-foot .wrap{display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap}
.site-foot .brand .name{font-size:19px}
.site-foot .copy{font-size:12.5px; color:var(--ink-faint); letter-spacing:.01em}
.foot-links{display:flex; gap:8px}
.foot-links a{font-size:11.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); padding:6px 10px; border-radius:6px}
.foot-links a:hover{color:var(--accent)}

/* ===== Landing — Hero ===== */
.hero{text-align:center; padding:54px 0 30px; border-bottom:1px solid var(--rule)}
.dateline{font-size:12px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:20px}
.dateline .sep{color:var(--accent); margin:0 9px}
.hero h1{font-family:var(--font-display); font-weight:500; letter-spacing:-.015em; line-height:1.04;
  font-size:clamp(38px, 6.4vw, 60px); margin:0 auto 18px; max-width:14ch}
.hero h1 em{font-style:italic; color:var(--accent)}
.hero p{max-width:520px; margin:0 auto; font-size:18px; color:var(--ink-soft); font-family:var(--font-display); font-weight:380}

/* ===== Landing — Games grid ===== */
.games{padding:40px 0 64px}
.games-head{display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:24px}
.games-head .label{font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft)}
.games-head .sub{color:var(--ink-faint); font-size:13.5px; letter-spacing:.02em}
.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.tile{display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--rule);
  border-radius:var(--radius); overflow:hidden; transition:border-color .18s ease, box-shadow .18s ease;
  position:relative; cursor:pointer}
.tile:hover{border-color:var(--rule-strong); box-shadow:0 14px 30px -22px rgba(23,20,15,.5)}
.accent-bar{height:5px; width:100%}
.media{position:relative; height:140px; background:#efeae0}
.media image-slot{display:block; width:100%; height:100%}
.media img{display:block; width:100%; height:100%; object-fit:cover; object-position:top}
.media .ph{display:flex; align-items:center; justify-content:center; width:100%; height:100%;
  color:#b4ac9e; font-size:11px; font-family:ui-monospace,monospace; text-align:center; padding:0 14px}
.media .badge{position:absolute; top:9px; left:9px; z-index:3; font-size:10.5px; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:#fff; background:rgba(23,20,15,.62); backdrop-filter:blur(3px);
  border-radius:100px; padding:4px 11px; pointer-events:none}
.tile-info{padding:14px 16px 16px; display:flex; flex-direction:column; gap:8px; flex:1}
.tile-title{display:flex; align-items:center; gap:8px}
.tile-title h3{font-family:var(--font-display); font-weight:500; font-size:20px; letter-spacing:-.01em; line-height:1.05; margin:0; white-space:nowrap}
.tile-info p{margin:0; color:var(--ink-soft); font-size:14.5px; flex:1}
.tile-foot{display:flex; align-items:center; justify-content:space-between; gap:8px}
.url-hint{font-size:12px; color:var(--ink-faint); letter-spacing:.01em}
.url-hint b{color:var(--ink-soft); font-weight:600}

/* ===== Landing — Play button ===== */
.play{display:inline-flex; align-items:center; gap:8px; font-family:var(--font-ui); font-weight:600; font-size:12px;
  letter-spacing:.01em; color:var(--ink); background:transparent;
  border:1.5px solid var(--ink); border-radius:100px; padding:7px 14px; cursor:pointer;
  transition:background .16s ease, color .16s ease}
.play::after{content:''; position:absolute; inset:0; z-index:1}
.tile:hover .play{background:var(--ink); color:var(--surface)}
.play:focus-visible{outline:2px solid var(--accent); outline-offset:2px}

/* ===== Landing — Coming soon ===== */
.soon{grid-column:1 / -1; display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  border-top:1px solid var(--rule); margin-top:8px; padding-top:22px; color:var(--ink-soft); font-size:14px}
.soon .lab{font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint)}
.soon .pip{display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-size:16px}
.soon .sw{width:14px; height:14px; border-radius:4px; display:inline-block}

/* ===== Editorial — Page intro ===== */
.pagehead{text-align:center; padding:52px 0 30px; border-bottom:1px solid var(--rule)}
.eyebrow{font-size:12px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:16px}
.pagehead h1{font-family:var(--font-display); font-weight:500; letter-spacing:-.015em; line-height:1.05;
  font-size:clamp(34px,5.4vw,52px); margin:0 auto 14px; max-width:16ch}
.pagehead h1 em{font-style:italic; color:var(--accent)}
.pagehead .lead{max-width:480px; margin:0 auto; font-size:17px; color:var(--ink-soft);
  font-family:var(--font-display); font-weight:380}

/* ===== Editorial — Buttons ===== */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-ui);
  font-weight:600; font-size:13.5px; letter-spacing:.01em; cursor:pointer; border-radius:100px; white-space:nowrap;
  padding:11px 22px; border:1.5px solid var(--ink); transition:background .16s, color .16s, border-color .16s}
.btn-primary{background:var(--ink); color:#fff}
.btn-primary:hover{background:var(--accent); border-color:var(--accent)}
.btn-outline{background:transparent; color:var(--ink)}
.btn-outline:hover{background:var(--ink); color:#fff}
.btn-sm{padding:7px 15px; font-size:12.5px}
.btn:disabled{opacity:.5; cursor:default}

/* ===== Editorial — Forms ===== */
.field{margin-bottom:18px}
.field label{display:block; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:8px}
.control{width:100%; font-family:var(--font-ui); font-size:15px; color:var(--ink); background:var(--surface);
  border:1px solid var(--rule-strong); border-radius:9px; padding:11px 13px; transition:border-color .15s, box-shadow .15s}
.control::placeholder{color:#b3ac9f}
textarea.control{min-height:120px; resize:vertical; line-height:1.5}
.control:focus{outline:none; border-color:var(--ink); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent)}
select.control{appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23574f44' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px}
.row-2{display:grid; grid-template-columns:1fr 1fr; gap:16px}

/* ===== Tags ===== */
.tag{font-family:var(--font-ui); font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:3px 10px; border-radius:100px; border:1px solid var(--rule-strong); color:var(--ink-soft)}
.tag.logic{color:var(--tile-sudoku); border-color:color-mix(in srgb, var(--tile-sudoku) 45%, transparent)}
.tag.family{color:var(--tile-words); border-color:color-mix(in srgb, var(--tile-words) 45%, transparent)}

/* ===== Admin layout ===== */
.admin{display:grid; grid-template-columns:232px 1fr; min-height:100vh}

/* Sidebar */
.sidebar{border-right:1px solid var(--rule); background:#f1eee6; padding:20px 16px;
  position:sticky; top:0; height:100vh; display:flex; flex-direction:column}
.side-brand{display:flex; align-items:baseline; gap:9px; flex-wrap:wrap; padding:9px 8px 10px; border-bottom:1px solid var(--rule); margin-bottom:14px}
.side-brand .name{font-family:var(--font-display); font-weight:600; font-size:20px; line-height:1; white-space:nowrap}
.side-brand .pill{align-self:center; font-family:var(--font-ui); font-size:9.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-faint); border:1px solid var(--rule-strong); border-radius:100px; padding:2px 8px}
.side-nav{display:flex; flex-direction:column; gap:3px}
.side-nav .item{display:flex; align-items:center; gap:11px; padding:10px 11px; border-radius:9px; cursor:pointer;
  font-size:13.5px; font-weight:600; color:var(--ink-soft); transition:background .14s, color .14s}
.side-nav .item:hover{background:rgba(23,20,15,.05)}
.side-nav .item.on{background:var(--ink); color:#fff}
.side-nav .item .ico{width:15px;height:15px;border:1.8px solid currentColor;border-radius:4px; flex:0 0 auto}
.side-nav .item .count{margin-left:auto; font-size:11px; font-weight:700; background:var(--accent); color:#fff;
  border-radius:100px; padding:1px 8px; min-width:20px; text-align:center}
.side-nav .item.on .count{background:#fff; color:var(--ink)}
.side-foot{margin-top:auto; font-size:11px; color:var(--ink-faint); padding:12px 8px 4px; border-top:1px solid var(--rule)}

/* Main */
.main-head{display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:22px 32px; border-bottom:1px solid var(--rule); background:var(--bg); position:sticky; top:0; z-index:5}
.main-head h1{font-family:var(--font-display); font-weight:500; font-size:30px; margin:0; letter-spacing:-.01em}
.main-head .count{color:var(--ink-faint); font-size:15px; font-family:var(--font-display)}
.main-body{padding:24px 32px 60px}
.view{display:none}
.view.on{display:block}

/* Games table */
.gt{width:100%; border-collapse:collapse; font-size:14px}
.gt th{text-align:left; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint);
  font-weight:700; padding:10px 12px; border-bottom:1px solid var(--rule-strong)}
.gt td{padding:12px; border-bottom:1px solid var(--rule); vertical-align:middle}
.gt tr.row{cursor:default}
.gt tr.row.dragging{opacity:.4}
.gt tr.row.drop-target td{box-shadow:inset 0 2px 0 var(--accent)}
.grip{color:var(--ink-faint); cursor:grab; font-size:15px; letter-spacing:-2px; user-select:none}
.grip:active{cursor:grabbing}
.thumb{width:54px; height:40px; border-radius:6px; border:1px solid var(--rule); object-fit:cover; object-position:top; background:#efeae0; display:block}
.thumb.ph{display:flex; align-items:center; justify-content:center; color:#b4ac9e; font-size:9px;
  font-family:ui-monospace,monospace; text-align:center; line-height:1.1}
.gname{font-family:var(--font-display); font-weight:500; font-size:18px}
.sub-cell{font-size:13px; color:var(--ink-faint)}
.sub-cell b{color:var(--accent-2); font-weight:600}
.actions{display:flex; gap:7px; justify-content:flex-end}
.ibtn{width:32px;height:32px; border:1px solid var(--rule-strong); border-radius:8px; background:var(--surface);
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer; font-size:14px; transition:background .14s, border-color .14s}
.ibtn:hover{background:#f1ece3; border-color:var(--ink)}
.ibtn.danger:hover{background:#fbecea; border-color:#c0392b; color:#c0392b}
.empty{padding:50px; text-align:center; color:var(--ink-faint); font-family:var(--font-display); font-size:18px}

/* Drawer */
.scrim{position:fixed; inset:0; background:rgba(23,20,15,.34); opacity:0; pointer-events:none;
  transition:opacity .2s ease; z-index:40}
.scrim.open{opacity:1; pointer-events:auto}
.drawer{position:fixed; top:0; right:0; height:100vh; width:440px; max-width:92vw; background:var(--surface);
  border-left:1px solid var(--rule); box-shadow:-24px 0 60px -30px rgba(23,20,15,.5);
  transform:translateX(100%); transition:transform .24s cubic-bezier(.3,.7,.3,1); z-index:50;
  display:flex; flex-direction:column}
.drawer.open{transform:none}
.drawer-head{display:flex; align-items:center; justify-content:space-between; padding:20px 24px; border-bottom:1px solid var(--rule)}
.drawer-head h2{font-family:var(--font-display); font-weight:500; font-size:24px; margin:0}
.drawer-body{padding:22px 24px; overflow-y:auto; flex:1}
.drawer-foot{display:flex; align-items:center; gap:10px; padding:18px 24px; border-top:1px solid var(--rule)}
.drawer-foot .spacer{flex:1}
.x{width:34px;height:34px;border:1px solid var(--rule-strong);border-radius:8px;background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;font-size:17px;color:var(--ink-soft)}
.x:hover{background:#f1ece3}

/* Subdomain compound input */
.subwrap{display:flex; align-items:stretch; border:1px solid var(--rule-strong); border-radius:9px; overflow:hidden; transition:border-color .15s, box-shadow .15s}
.subwrap:focus-within{border-color:var(--ink); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent)}
.subwrap input{border:none; outline:none; flex:1; padding:11px 12px; font-family:var(--font-ui); font-size:15px; color:var(--accent-2); font-weight:600; min-width:0; background:var(--surface)}
.subwrap .suffix{display:flex; align-items:center; padding:0 13px; background:#f1ece3; color:var(--ink-faint); font-size:13px; border-left:1px solid var(--rule)}

/* Screenshot uploader */
.uploader{border:1.5px dashed var(--rule-strong); border-radius:10px; padding:14px; display:flex; align-items:center; gap:14px}
.uploader .prev{width:84px;height:62px;border-radius:7px;border:1px solid var(--rule);object-fit:cover;background:#efeae0; flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;color:#b4ac9e;font-size:10px;font-family:ui-monospace,monospace;text-align:center}
.uploader .up-txt{font-size:12.5px; color:var(--ink-faint); line-height:1.4}
.uploader .up-txt b{color:var(--ink-soft)}

/* Swatches */
.swatches{display:flex; gap:9px; flex-wrap:wrap}
.swatch{width:32px; height:32px; border-radius:8px; cursor:pointer; padding:0; border:2px solid transparent;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.14); position:relative; transition:transform .1s}
.swatch:hover{transform:translateY(-1px)}
.swatch.sel{border-color:var(--ink)}
.swatch.sel::after{content:'✓'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:14px; font-weight:700; text-shadow:0 1px 2px rgba(0,0,0,.4)}
.field-hint{font-size:11.5px; color:var(--ink-faint); margin:8px 0 0; font-style:italic}
.cdot{display:inline-block; width:11px; height:11px; border-radius:50%; margin-right:10px;
  vertical-align:middle; box-shadow:0 0 0 1px rgba(0,0,0,.14)}

/* Inbox */
.inbox{display:grid; grid-template-columns:minmax(0,1fr); gap:0; max-width:760px}
.msg{display:grid; grid-template-columns:14px 1fr auto; gap:13px; align-items:start; padding:16px 6px;
  border-bottom:1px solid var(--rule); cursor:pointer; transition:background .12s}
.msg:hover{background:rgba(23,20,15,.025)}
.msg .udot{width:9px;height:9px;border-radius:50%;background:var(--accent);margin-top:6px}
.msg.read .udot{background:transparent;border:1.5px solid var(--rule-strong)}
.msg .from{font-weight:600; font-size:14.5px}
.msg.read .from{font-weight:500; color:var(--ink-soft)}
.msg .snippet{font-size:13.5px; color:var(--ink-faint); margin-top:3px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:46ch}
.msg .meta{display:flex; flex-direction:column; align-items:flex-end; gap:6px}
.msg .when{font-size:12px; color:var(--ink-faint)}
.msg-detail{padding:4px 6px 10px}
.msg-detail .back{font-size:12.5px; font-weight:600; color:var(--ink-soft); cursor:pointer; display:inline-flex; gap:6px; align-items:center; margin-bottom:18px}
.msg-detail h3{font-family:var(--font-display); font-weight:500; font-size:24px; margin:0 0 4px}
.msg-detail .addr{font-size:13.5px; color:var(--ink-faint); margin-bottom:18px}
.msg-detail .addr a{color:var(--accent-2)}
.msg-detail .body{font-size:16px; color:var(--ink); line-height:1.6; font-family:var(--font-display); max-width:60ch;
  border-left:2px solid var(--rule-strong); padding-left:18px; margin-bottom:22px; white-space:pre-wrap}

/* ===== Responsive ===== */
@media (max-width:900px){ .grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:720px){ .grid{grid-template-columns:1fr} }

@media (max-width:640px){
  .wrap{padding:0 18px}
  .site-head .wrap{padding:15px 18px}
  .brand .name{font-size:22px}
  .nav{gap:2px}
  .nav a{padding:7px 9px; letter-spacing:.08em}

  .hero{padding:34px 0 24px}
  .hero h1{font-size:clamp(29px,8.4vw,40px); max-width:18ch}
  .hero p{font-size:16px}
  .dateline{margin-bottom:16px}
  .games{padding:30px 0 46px}
  .games-head{margin-bottom:18px}
  .media{height:160px}
  .tile-foot{flex-wrap:wrap; gap:10px 14px}
  .soon{flex-direction:column; align-items:flex-start; gap:10px}

  .pagehead{padding:36px 0 24px}
  .pagehead h1{font-size:clamp(29px,8vw,42px)}
  .pagehead .lead{font-size:16px}

  .site-foot{padding:24px 0 38px; margin-top:34px}
  .site-foot .wrap{flex-direction:column; align-items:flex-start; gap:12px}
}

@media (max-width:560px){ .row-2{grid-template-columns:1fr} }

@media (max-width:380px){
  .games-head{flex-direction:column; align-items:flex-start; gap:4px}
  .tile-title h3{white-space:normal}
}
