*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#faf8f3;--card:#fff;--text:#2C2C2A;--muted:#5F5E5A;--hint:#9A9890;
  --bdr:rgba(44,44,42,0.13);--bdr2:rgba(44,44,42,0.26);
  --amber:#BA7517;--amber-l:#FAEEDA;--amber-m:#FAC775;--amber-xm:#EF9F27;--amber-d:#633806;
  --t0:#E1F5EE;--t1:#9FE1CB;--t2:#5DCAA5;--t3:#1D9E75;--t4:#0F6E56;--t5:#085041;
  --red:#E24B4A;--red-l:#FCEBEB;--red-d:#791F1F;--nav-h:64px;
}
@media(prefers-color-scheme:dark){:root{
  --bg:#1a1814;--card:#252320;--text:#e8e4d8;--muted:#a09a8c;--hint:#666;
  --bdr:rgba(232,228,216,0.10);--bdr2:rgba(232,228,216,0.22);
  --amber-l:#412402;--amber-m:#854F0B;--amber-xm:#BA7517;--amber-d:#FAC775;
  --t0:#04342C;--t1:#085041;--t2:#0F6E56;--t3:#1D9E75;--t4:#5DCAA5;--t5:#9FE1CB;
  --red-l:#501313;--red-d:#F09595;
}}
html,body{height:100%;overflow:hidden}
body{font-family:'Crimson Text',Georgia,serif;background:var(--bg);color:var(--text);
  font-size:16px;line-height:1.5;-webkit-user-select:none;user-select:none;
  touch-action:pan-y;display:flex;flex-direction:column;}

.screen{display:none;flex-direction:column;height:100%;overflow:hidden}
.screen.active{display:flex}

/* ══════════════════════════════
   SHARED ELEMENTS
══════════════════════════════ */
.ornament{font-size:9px;letter-spacing:.28em;color:var(--amber);margin-bottom:.25rem;text-align:center}
.scroll-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.inner{padding:1.25rem 1rem 2rem;max-width:500px;margin:0 auto}
.card-block{background:var(--card);border:1px solid var(--bdr);border-radius:14px;overflow:hidden;margin-bottom:.85rem}
.card-block-pad{padding:1rem}
.section-label{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.12em;color:var(--muted);margin-bottom:.45rem}
.big-title{font-family:'Cinzel',serif;font-size:1.35rem;font-weight:600;line-height:1.2;margin-bottom:.2rem;text-align:center}
.sub-text{font-style:italic;color:var(--muted);font-size:.85rem;text-align:center;margin-bottom:1.25rem}
.primary-btn{width:100%;padding:.7rem;border-radius:10px;background:var(--amber);border:none;
  color:#fff;font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.1em;cursor:pointer;
  margin-top:.5rem;-webkit-tap-highlight-color:transparent;}
.primary-btn:active{opacity:.8}
.ghost-btn{width:100%;padding:.6rem;border-radius:10px;border:1px solid var(--bdr2);
  background:transparent;font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.08em;
  color:var(--muted);cursor:pointer;margin-top:.4rem;-webkit-tap-highlight-color:transparent;}
.ghost-btn:active{opacity:.7}
.error-msg{font-size:.82rem;color:var(--red);font-style:italic;margin-top:.4rem;min-height:1.2rem;text-align:center}

/* ══════════════════════════════
   SETUP SCREEN
══════════════════════════════ */
.setup-step{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:.9rem;margin-bottom:.75rem}
.step-num{font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.1em;color:var(--amber);margin-bottom:.3rem}
.step-text{font-size:.9rem;color:var(--muted);line-height:1.6}
.step-text strong{color:var(--text);font-weight:600}
.step-text code{font-family:monospace;font-size:.82rem;background:var(--amber-l);color:var(--amber-d);padding:1px 5px;border-radius:4px}
.config-ta{width:100%;min-height:110px;font-family:monospace;font-size:.78rem;
  background:var(--card);border:1px solid var(--bdr);border-radius:10px;
  padding:.75rem;color:var(--text);resize:none;outline:none;line-height:1.5;
  -webkit-user-select:text;user-select:text;}
.config-ta:focus{border-color:var(--amber)}
.config-ta::placeholder{color:var(--hint)}

/* ══════════════════════════════
   LOGIN SCREEN
══════════════════════════════ */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.who-tile{background:var(--card);border:1.5px solid var(--bdr);border-radius:14px;
  padding:.9rem .65rem;text-align:center;cursor:pointer;
  transition:transform .1s;-webkit-tap-highlight-color:transparent;
  display:flex;flex-direction:column;align-items:center;gap:.35rem;}
.who-tile:active{transform:scale(.97)}
.who-tile.dm-tile{grid-column:1/-1}
.tile-avatar{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:15px;font-weight:600;margin:0 auto}
.tile-name{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.04em;color:var(--text);line-height:1.3}
.tile-sub{font-size:.74rem;color:var(--muted);font-style:italic}
.tile-status{font-size:.68rem;color:var(--hint)}
.sync-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;
  color:var(--t3);font-style:italic;margin-bottom:.75rem;justify-content:center;width:100%}
.sync-dot{width:7px;height:7px;border-radius:50%;background:var(--t3);
  animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.sync-dot.offline{background:var(--red);animation:none}

/* ══════════════════════════════
   PIN SCREEN
══════════════════════════════ */
.pin-avatar{width:64px;height:64px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:20px;font-weight:600;margin:0 auto .75rem}
.pin-dots{display:flex;justify-content:center;gap:.65rem;margin-bottom:1.5rem}
.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--bdr2);background:transparent;transition:all .1s}
.pin-dot.filled{border-color:var(--amber);background:var(--amber)}
.pin-dot.error-dot{border-color:var(--red);background:var(--red)}
.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-width:260px;margin:0 auto}
.pin-key{height:58px;border-radius:12px;border:1px solid var(--bdr2);background:var(--card);
  font-family:'Cinzel',serif;font-size:1.2rem;cursor:pointer;color:var(--text);
  display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;transition:transform .08s;}
.pin-key:active{background:var(--amber-l);transform:scale(.94)}
.pin-key.del{font-size:.9rem;color:var(--muted)}
.pin-key.empty-key{border:none;background:transparent;cursor:default}
.set-pin-prompt{background:var(--card);border:1px solid var(--bdr);border-radius:14px;padding:1rem;margin-bottom:1rem}
.set-pin-prompt p{font-size:.88rem;color:var(--muted);margin-bottom:.65rem}
.prompt-row{display:flex;gap:.5rem}
.prompt-btn{flex:1;padding:.55rem;border-radius:9px;border:1px solid var(--bdr2);
  background:transparent;cursor:pointer;font-family:'Cinzel',serif;
  font-size:.62rem;letter-spacing:.07em;color:var(--text);
  -webkit-tap-highlight-color:transparent;}
.prompt-btn.go{background:var(--amber);border-color:var(--amber);color:#fff}

/* ══════════════════════════════
   MAIN APP — HEADER & NAV
══════════════════════════════ */
.app-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;
  padding:.6rem .9rem;border-bottom:1px solid var(--bdr2);background:var(--card);}
.app-header-mid{flex:1;text-align:center}
.app-header h2{font-family:'Cinzel',serif;font-size:.92rem;font-weight:600;line-height:1.1}
.app-header p{font-size:.72rem;color:var(--muted);font-style:italic}
.hdr-btn{background:transparent;border:1px solid var(--bdr);border-radius:8px;
  padding:.3rem .55rem;font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:.07em;
  color:var(--muted);cursor:pointer;white-space:nowrap;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;}
.hdr-side{width:60px;display:flex;justify-content:flex-end}

.app-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
  padding-bottom:calc(var(--nav-h) + .5rem)}
.bottom-nav{flex-shrink:0;height:var(--nav-h);display:flex;align-items:stretch;
  background:var(--card);border-top:1px solid var(--bdr2);z-index:50;}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;background:transparent;border:none;cursor:pointer;font-family:'Cinzel',serif;
  font-size:.52rem;letter-spacing:.07em;color:var(--muted);
  -webkit-tap-highlight-color:transparent;padding:.5rem 0;}
.nav-btn svg{width:26px;height:26px;stroke:currentColor;stroke-width:1.5;fill:none;
  stroke-linecap:round;stroke-linejoin:round}
.nav-btn.active{color:var(--amber)}
.panel{display:none}.panel.active{display:block;min-height:0;}

/* ══════════════════════════════
   FILL PANEL (My Times)
══════════════════════════════ */
.fill-panel{padding:.75rem}
.player-card{background:var(--card);border:1px solid var(--bdr);border-radius:12px;
  padding:.85rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.85rem;}
.p-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:14px;font-weight:600;flex-shrink:0}
.p-info{flex:1;min-width:0}
.p-name-input{font-family:'Crimson Text',serif;font-size:1.05rem;font-weight:600;border:none;
  border-bottom:1px solid var(--bdr);background:transparent;color:var(--text);
  width:100%;padding:1px 0;outline:none;-webkit-user-select:text;user-select:text;}
.p-name-input:focus{border-bottom-color:var(--amber)}
.p-name-input::placeholder{color:var(--hint);font-style:italic;font-weight:400}
.p-class-select{font-family:'Crimson Text',serif;font-size:.84rem;border:none;background:transparent;
  color:var(--muted);cursor:pointer;outline:none;padding:0;width:100%;margin-top:2px}
.dm-badge{display:inline-block;font-family:'Cinzel',serif;font-size:.52rem;letter-spacing:.1em;
  padding:2px 7px;border-radius:10px;background:var(--amber-l);color:var(--amber-d);margin-top:2px}
.p-slotcount{font-size:.75rem;color:var(--muted);font-style:italic;flex-shrink:0;text-align:right}

.month-nav{display:flex;align-items:center;justify-content:space-between;padding:.3rem 0;margin-bottom:.4rem}
.month-label{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.05em}
.m-arrow{background:transparent;border:1px solid var(--bdr2);border-radius:8px;
  width:48px;height:48px;cursor:pointer;color:var(--muted);font-size:1.4rem;
  display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;}
.m-arrow:active{background:var(--amber-l)}

.grid-wrap{border:1px solid var(--bdr);border-radius:12px;overflow:hidden;display:flex;}
.time-col{flex-shrink:0;width:38px;overflow:hidden;border-right:1px solid var(--bdr);background:var(--card);}
.grid-scroll{flex:1;overflow-x:auto;overflow-y:auto;max-height:calc(100dvh - 280px);-webkit-overflow-scrolling:touch;}
.drag-grid{display:grid;touch-action:none;}
.g-corner{font-family:'Cinzel',serif;font-size:.5rem;color:var(--hint);text-align:right;
  padding:.4rem .4rem .3rem 0;border-bottom:1px solid var(--bdr);
  background:var(--card);height:38px;box-sizing:border-box;display:flex;align-items:center;justify-content:flex-end;}
.g-dh{font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:.04em;color:var(--muted);
  text-align:center;padding:.4rem .1rem .3rem;border-bottom:1px solid var(--bdr);
  background:var(--card);line-height:1.3;position:sticky;top:0;z-index:11;}
.g-dh.today-col{color:var(--amber)}
.g-time{font-size:.64rem;color:var(--hint);text-align:right;padding:.15rem .4rem 0 0;
  background:var(--card);height:40px;box-sizing:border-box;display:flex;align-items:center;justify-content:flex-end;
  border-bottom:1px solid var(--bdr);}
.g-slot{height:40px;cursor:pointer;border-left:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.g-slot[data-past="1"]{opacity:.28;cursor:not-allowed}
.grid-hint{font-size:.75rem;color:var(--muted);font-style:italic;margin-top:.45rem;text-align:center}

/* Joystick (floating d-pad over grid) */
.joystick-wrap{position:fixed;z-index:100;right:18px;bottom:calc(var(--nav-h) + 18px);
  display:none;touch-action:none;}
.joystick-wrap.visible{display:block}
.joystick-base{width:90px;height:90px;border-radius:50%;
  background:var(--card);border:1.5px solid var(--bdr2);
  box-shadow:0 2px 12px rgba(0,0,0,.18);
  position:relative;display:flex;align-items:center;justify-content:center;}
.joystick-thumb{width:38px;height:38px;border-radius:50%;
  background:var(--amber);opacity:.85;
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  box-shadow:0 1px 4px rgba(0,0,0,.25);
  transition:transform .05s,opacity .1s;pointer-events:none;}
.joystick-wrap.active .joystick-thumb{opacity:1}

/* Color picker */
.color-pick-wrap{position:relative;margin-top:.5rem;display:inline-block;}
.color-pick-btn{display:flex;align-items:center;gap:6px;padding:.3rem .55rem;
  border:1px solid var(--bdr2);border-radius:8px;background:var(--card);
  cursor:pointer;font-family:'Crimson Text',serif;font-size:.85rem;color:var(--muted);
  -webkit-tap-highlight-color:transparent;}
.color-pick-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
.color-pick-arrow{font-size:.6rem;opacity:.6;}
.color-pick-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;
  background:var(--card);border:1px solid var(--bdr2);border-radius:10px;
  box-shadow:0 4px 18px rgba(0,0,0,.35);padding:.4rem;
  display:none;flex-wrap:wrap;gap:5px;width:180px;z-index:200;top:calc(100% + 6px);bottom:auto;}
.color-pick-menu.open{display:flex;}
.swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;
  -webkit-tap-highlight-color:transparent;padding:0;flex-shrink:0;transition:transform .1s;}
.swatch:active{transform:scale(.88)}
.swatch-active{border-color:var(--text);box-shadow:0 0 0 2px var(--text);}
.swatch-taken{opacity:.22;cursor:not-allowed;}
.saving-indicator{font-size:.72rem;color:var(--t3);font-style:italic;text-align:center;
  margin-top:.25rem;min-height:1rem;transition:opacity .3s}

/* ══════════════════════════════
   OVERVIEW PANEL
══════════════════════════════ */
.ov-panel{padding:.5rem;display:flex;flex-direction:column;align-items:center;}
.ov-cal-wrap{width:100%;box-sizing:border-box;}
.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;width:100%;}
.mc-dow{font-family:'Cinzel',serif;font-size:min(2.8vw,.78rem);letter-spacing:.03em;color:var(--muted);
  text-align:center;padding:.4rem 0}
.mc-day{aspect-ratio:1;border-radius:8px;border:1px solid transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:0;}
.mc-dn{font-family:'Crimson Text',serif;font-size:min(4.5vw,1.5rem);line-height:1}
.mc-pips{display:flex;gap:2px;justify-content:center;flex-wrap:wrap;min-height:8px}
.mc-pip{width:min(2vw,9px);height:min(2vw,9px);border-radius:50%;flex-shrink:0}
.mc-day.past{opacity:.35}
.mc-day.mc-some{border-color:var(--amber-m)}
.mc-day.mc-full{border-color:var(--t3);background:var(--t0)}
.mc-day.mc-today{outline:2px solid var(--amber-xm);outline-offset:-1px}
.ov-legend{display:grid;grid-template-columns:1fr 1fr;gap:.45rem .6rem;margin-top:.75rem;margin-bottom:.85rem;width:100%;padding:0 .25rem}
.ov-li{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted);font-style:italic}
.ov-lp{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.best-card{background:var(--t0);border:1px solid var(--t1);border-radius:10px;
  padding:.65rem .9rem;margin-bottom:.5rem;display:flex;align-items:flex-start;gap:.55rem;}
.gcal-btn{margin-top:.45rem;display:inline-flex;align-items:center;gap:5px;
  font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:.06em;
  padding:.3rem .6rem;border-radius:6px;border:1px solid var(--bdr2);
  background:transparent;color:var(--muted);cursor:pointer;text-decoration:none;
  -webkit-tap-highlight-color:transparent;}
.gcal-btn:hover,.gcal-btn:active{background:var(--amber-l);color:var(--amber);border-color:var(--amber);}
.gcal-btn svg{width:12px;height:12px;flex-shrink:0;}
.best-medal{font-size:.95rem;flex-shrink:0;margin-top:1px}
.best-name{font-family:'Cinzel',serif;font-size:.7rem;color:var(--t5)}
.best-detail{font-size:.8rem;color:var(--muted);font-style:italic;margin-top:2px;line-height:1.4}

/* ══════════════════════════════
   SETTINGS PANEL (DM-only Party)
══════════════════════════════ */
.settings-panel{padding:.75rem}
.s-row{display:flex;align-items:center;padding:.8rem .9rem;gap:.75rem;border-bottom:1px solid var(--bdr)}
.s-row:last-child{border-bottom:none}
.s-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:13px;font-weight:600;flex-shrink:0}
.s-info{flex:1;min-width:0}
.s-name{font-family:'Crimson Text',serif;font-size:.95rem;font-weight:600;color:var(--text)}
.s-sub{font-size:.78rem;color:var(--muted);font-style:italic}
.s-dm-tag{font-family:'Cinzel',serif;font-size:.5rem;letter-spacing:.08em;
  background:var(--amber-l);color:var(--amber-d);padding:1px 6px;border-radius:8px;margin-right:4px}
.s-actions{display:flex;flex-direction:column;gap:4px;align-items:flex-end;flex-shrink:0}
.s-btn{background:transparent;border:1px solid var(--bdr2);border-radius:7px;
  padding:3px 8px;font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:.05em;
  color:var(--muted);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;}
.s-btn.danger:active{border-color:var(--red);color:var(--red)}
.reconfigure-btn{width:100%;padding:.55rem;border-radius:10px;border:1px solid var(--bdr2);
  background:transparent;font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.07em;
  color:var(--muted);cursor:pointer;margin-top:.5rem;}
.reconfigure-btn:active{border-color:var(--red);color:var(--red)}

/* ══════════════════════════════
   NOTES PANEL
══════════════════════════════ */
.notes-panel{padding:.75rem}
.notes-ta{width:100%;font-family:'Crimson Text',serif;font-size:1rem;background:var(--card);
  border:1px solid var(--bdr);border-radius:12px;padding:.9rem;color:var(--text);
  resize:none;outline:none;line-height:1.6;min-height:200px;
  -webkit-user-select:text;user-select:text;
  height:calc(100dvh - var(--nav-h) - 170px);}
.notes-ta:focus{border-color:var(--amber)}
.save-btn{width:100%;margin-top:.65rem;padding:.7rem;border-radius:10px;
  background:var(--amber);border:none;color:#fff;font-family:'Cinzel',serif;
  font-size:.7rem;letter-spacing:.1em;cursor:pointer;}
.saved-flash{text-align:center;font-size:.8rem;color:var(--t3);font-style:italic;margin-top:.4rem;min-height:1.2rem}

/* ══════════════════════════════
   MISC
══════════════════════════════ */
.no-data{text-align:center;color:var(--muted);font-style:italic;padding:2rem 1rem;font-size:.9rem}
.loading-overlay{display:flex;align-items:center;justify-content:center;flex:1;
  font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.08em;color:var(--muted)}
