/* Echoes of Creation — shared UI */
:root{
  --ink:#15120f; --paper:#faf7f1; --card:#ffffff; --line:#e7e0d4;
  --muted:#8a8276; --red:#9E2A2A; --green:#1f8a4c; --amber:#c77d18; --blue:#2563a8;
  --shadow:0 10px 30px -12px rgba(20,15,12,.22);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5;position:relative}
/* transparent painting watermark on every page */
body::before{content:"";position:fixed;inset:0;z-index:-2;
  background:url('assets/works/work-12.jpg') center/cover no-repeat fixed;
  opacity:.10;filter:saturate(1.05)}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 0%, rgba(250,247,241,.55), rgba(250,247,241,.86) 60%, rgba(250,247,241,.95))}
a{color:var(--red)}
.wrap{max-width:780px;margin:0 auto;padding:clamp(1rem,4vw,2.2rem)}
.wrap.wide{max-width:1180px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem clamp(1rem,4vw,2rem);background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand{font-family:var(--serif);font-weight:700;font-size:1.05rem}
.brand small{display:block;font-family:var(--sans);font-weight:400;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.navlinks a{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;color:var(--muted);margin-left:1rem}
.navlinks a:hover{color:var(--ink)}
.modepill{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;padding:.25rem .55rem;border-radius:99px;border:1px solid var(--line);color:var(--muted)}
.modepill.live{color:var(--green);border-color:var(--green)}
h1{font-family:var(--serif);font-size:clamp(1.7rem,5vw,2.5rem);margin:.2rem 0 .1rem}
.lead{color:var(--muted);margin:.2rem 0 1.4rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:clamp(1.1rem,3vw,1.8rem)}
label{display:block;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:.9rem 0 .35rem}
input,select,textarea{width:100%;font:inherit;padding:.8rem .9rem;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--red);outline-offset:1px;border-color:var(--red)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
@media(max-width:560px){.row{grid-template-columns:1fr}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.2rem;border:0;border-radius:10px;background:var(--red);color:#fff;font-weight:700;letter-spacing:.04em;font-size:1rem;cursor:pointer;transition:.2s}
.btn:hover{background:#822121}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{background:#f3eee5}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{position:relative;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;cursor:pointer;user-select:none;font-size:.9rem;display:flex;align-items:center;gap:.5rem;background:#fff}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip .dot{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}
.chip.sel{border-color:var(--red);background:#fbeeee;box-shadow:inset 0 0 0 1px var(--red)}
.chip.full{opacity:.45;cursor:not-allowed}
.chip .cap{font-size:.7rem;color:var(--muted)}
.muted{color:var(--muted)}
.hint{font-size:.78rem;color:var(--muted);margin-top:.3rem}
.grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1rem}
.stat .n{font-family:var(--serif);font-size:2rem;font-weight:700;line-height:1}
.stat .l{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}
table{width:100%;border-collapse:collapse;font-size:.88rem}
th,td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--line);vertical-align:middle}
th{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.avatar{width:40px;height:40px;border-radius:8px;object-fit:cover;background:#eee}
.pill{display:inline-block;font-size:.66rem;padding:.18rem .5rem;border-radius:99px;border:1px solid var(--line);color:var(--muted);margin:1px}
.bigcode{font-family:var(--serif);font-size:2rem;letter-spacing:.18em;font-weight:700;text-align:center}
.center{text-align:center}
.scanbox{position:relative;border-radius:14px;overflow:hidden;background:#000;aspect-ratio:1/1;max-width:420px;margin:0 auto}
#reader{width:100%}
.result{border-radius:14px;padding:1.2rem;margin-top:1rem;text-align:center;border:2px solid}
.result.ok{background:#eaf6ee;border-color:var(--green)}
.result.already{background:#fdf3e3;border-color:var(--amber)}
.result.invalid,.result.not_valid_day{background:#fcebea;border-color:var(--red)}
.result h2{margin:.2rem 0;font-family:var(--serif)}
.result .photo{width:96px;height:96px;border-radius:12px;object-fit:cover;margin:.4rem auto;display:block;border:3px solid #fff;box-shadow:var(--shadow)}
.bandchip{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;padding:.5rem .9rem;border-radius:99px;color:#fff;margin-top:.4rem}
.toolbar{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin:.8rem 0}
.toolbar input[type=search]{max-width:280px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{border:0;background:#fff;padding:.6rem .9rem;cursor:pointer;font:inherit;color:var(--muted)}
.seg button.on{background:var(--ink);color:#fff}
.qrwrap{display:flex;flex-direction:column;align-items:center;gap:.4rem}
canvas.qr{width:240px;height:240px;image-rendering:pixelated}
@media print{ .noprint{display:none!important} body{background:#fff} .card{box-shadow:none;border:1px solid #ccc} }
