:root{font-family:Avenir Next,Gill Sans,Trebuchet MS,sans-serif;line-height:1.45;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input{font:inherit}:root{--bg-0: #f7f3ea;--bg-1: #efe6d8;--ink: #1e2b24;--muted: #637269;--card: #fffdfa;--line: #d8cdbd;--brand: #264c39;--brand-strong: #173326;--danger: #9a2f2f}*,*:before,*:after{box-sizing:border-box}#root{min-height:100vh}.page{min-height:100vh;background:radial-gradient(1100px 650px at 4% -10%,rgba(255,255,255,.95),transparent 60%),linear-gradient(155deg,var(--bg-0) 0%,var(--bg-1) 100%);color:var(--ink)}.auth-card{width:min(100%,460px);margin:0 auto;transform:translateY(8vh)}.app-page{padding:1rem}.topbar{max-width:1200px;margin:0 auto 1rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.topbar-sub{margin:.35rem 0 0;color:var(--muted)}.topbar-actions{display:flex;gap:.6rem;flex-wrap:wrap}.mobile-menu-toggle{display:none}.shell-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:300px 1fr;gap:1rem}.panel{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 20px 40px #1d231e1a;padding:1rem}.main-panel{min-height:70vh;position:relative;overflow:hidden}.main-panel:before{content:"";position:absolute;width:540px;height:540px;border-radius:999px;right:-220px;top:-220px;background:radial-gradient(circle,#264c3933,#264c3900);pointer-events:none}.panel-title{margin:0 0 .7rem;font-size:1.35rem}.brand{display:inline-block;font-size:.78rem;letter-spacing:.13em;text-transform:uppercase;color:var(--brand);font-weight:700;background:#264c3914;border:1px solid rgba(38,76,57,.2);border-radius:999px;padding:.3rem .62rem}.brand-wrap{display:inline-flex;align-items:center;gap:.5rem}.brand-logo{width:34px;height:34px;object-fit:contain;border-radius:8px;background:#fff;border:1px solid rgba(38,76,57,.2)}.title{margin:.7rem 0 .25rem;font-size:clamp(1.45rem,4.8vw,1.8rem);line-height:1.15}.subtitle{margin:0;color:var(--muted);font-size:.95rem;line-height:1.35}.form{margin-top:1rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.field{display:block}.field.wide{grid-column:1 / -1}.label{display:block;margin-bottom:.34rem;color:#34413a;font-size:.84rem;font-weight:600}.input{width:100%;border:1px solid var(--line);border-radius:10px;padding:.72rem .78rem;font-size:.97rem;color:#25342c;background:#fff}.textarea{min-height:92px;resize:vertical}.input:focus{outline:none;border-color:#8ea79a;box-shadow:0 0 0 3px #8ea79a33}.btn{border:none;border-radius:11px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-strong) 100%);color:#fff;padding:.76rem .86rem;font-size:.95rem;font-weight:700;cursor:pointer}.btn.secondary{background:#d5e3da;color:#1f3228}.btn:disabled{opacity:.62;cursor:not-allowed}.ghost{border:1px solid var(--line);border-radius:10px;background:#ffffffe6;color:#1e2b24;font-weight:600;padding:.55rem .75rem;cursor:pointer}.link{margin-top:.86rem;background:transparent;border:none;color:var(--brand);font-weight:700;cursor:pointer;font-size:.9rem}.error{margin:.45rem 0;color:var(--danger);font-size:.9rem}.muted{margin:.25rem 0;color:var(--muted);font-size:.9rem}.api{margin-top:.8rem;color:#829187;font-size:.77rem;word-break:break-all}.campaign-item{width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:10px;padding:.65rem;margin-bottom:.5rem;cursor:pointer}.campaign-item span{display:block;color:var(--muted);font-size:.8rem;margin-top:.2rem}.campaign-item-row{display:grid;grid-template-columns:1fr auto;gap:.45rem;margin-bottom:.5rem}.campaign-item-row .campaign-item{margin-bottom:0}.danger-ghost{border:1px solid #d7b8b8;border-radius:10px;background:#fff6f6;color:#8f2f2f;font-weight:600;padding:.4rem .65rem;cursor:pointer}.danger-ghost:disabled{opacity:.6;cursor:not-allowed}.button-row{margin-top:.8rem;display:flex;gap:.65rem;flex-wrap:wrap}.result-card,.turnbox,.log-item{border:1px solid var(--line);border-radius:12px;padding:.8rem;background:#fff;margin-top:.8rem}.character-image{display:block;width:min(100%,360px);aspect-ratio:1 / 1;object-fit:cover;border-radius:12px;border:1px solid var(--line);margin:.55rem 0 .7rem}.stat-grid{margin-top:.6rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.stat{border:1px solid #e2d7c8;border-radius:9px;padding:.45rem;text-align:center}.stat span{display:block;text-transform:capitalize;color:var(--muted);font-size:.75rem}.checklist{margin:.8rem 0 0;padding-left:1rem}.log-list{display:grid;gap:.6rem}.campaign-chat{margin-top:.8rem;display:flex;flex-direction:column;height:min(72vh,760px);border:1px solid var(--line);border-radius:14px;background:#fff}.chat-log{flex:1;overflow-y:auto;padding:.8rem;display:grid;gap:.6rem}.turn-pair{display:grid;gap:.45rem}.player-msg{justify-self:end;width:min(100%,85%);background:#eef4ef}.ai-msg{justify-self:start;width:min(100%,85%);background:#faf7f1}.ai-intro{background:#f6f0e5}.composer{margin:0;border-radius:0 0 14px 14px;border-left:none;border-right:none;border-bottom:none;background:#fffdf9}.composer-head{display:flex;align-items:center;gap:.65rem;margin-bottom:.6rem}.turn-avatar{width:58px;height:58px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}.intro-hero{position:relative;border:1px solid #d8ccb9;border-radius:18px;background:linear-gradient(140deg,#fffdf8,#f8f1e5 45%,#f1e7d7);padding:1.15rem;box-shadow:inset 0 1px #ffffffe6}.kicker{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:700;color:#6f7f75}.hero-title{margin:.35rem 0 .5rem;font-size:clamp(1.8rem,4vw,2.6rem);line-height:1.03;color:#18261f;font-family:Avenir Next,Trebuchet MS,sans-serif}.hero-text{margin:0;max-width:65ch;color:#415147;font-size:1.03rem}.hero-actions{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:1rem}.intro-grid{margin-top:.9rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem}.intro-card{border:1px solid #ded1bf;border-radius:14px;background:#fffefb;padding:.75rem}.intro-card h3{margin:0 0 .3rem;font-size:.98rem}.intro-card p{margin:0;color:#55665b;font-size:.9rem}@media(max-width:960px){.app-page{padding:.75rem}.auth-card{transform:none;margin:.75rem auto}.topbar{flex-wrap:wrap;align-items:center;margin-bottom:.75rem}.mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:88px}.topbar-actions{display:none;width:100%;margin-top:.2rem}.topbar-actions.open{display:grid;grid-template-columns:1fr;gap:.45rem}.topbar-actions .ghost{width:100%;text-align:left}.shell-grid{grid-template-columns:1fr;gap:.75rem}.panel{padding:.85rem;border-radius:14px}.main-panel{min-height:62vh}.form-grid,.intro-grid{grid-template-columns:1fr}.campaign-chat{height:min(74vh,680px)}.chat-log{padding:.65rem}.player-msg,.ai-msg{width:min(100%,96%)}.turn-avatar{width:52px;height:52px}.btn,.ghost{min-height:44px}.button-row{display:grid;grid-template-columns:1fr}.button-row .btn{width:100%}.stat-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.page{background:radial-gradient(700px 420px at 8% -12%,rgba(255,255,255,.95),transparent 60%),linear-gradient(155deg,var(--bg-0) 0%,var(--bg-1) 100%)}.app-page{padding:.55rem}.brand-logo{width:30px;height:30px}.brand{font-size:.72rem;padding:.26rem .55rem}.panel-title{font-size:1.15rem}.campaign-item-row{grid-template-columns:1fr;gap:.35rem}.danger-ghost{width:100%}.intro-hero{padding:.85rem;border-radius:14px}.hero-text{font-size:.95rem}.intro-card{padding:.65rem}.character-image{width:100%}.campaign-chat{height:min(76vh,620px)}.composer .textarea{min-height:78px}.stat-grid{grid-template-columns:1fr}}
