:root{--ink:#24313a;--muted:#7c756c;--paper:#fbf4e8;--paper-deep:#e9dfcf;--panel:#fffaf0;--line:#cfc0a8;--rose:#c96f67;--blue:#6e95a3;--green:#5f8d78;--ochre:#d7a65f;--lilac:#b7a6bd;--shadow:0 18px 36px #463a2c1a;color:var(--ink);background:var(--paper-deep);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;width:100%;min-height:100%;overflow-x:hidden}body{width:100%;min-width:0;max-width:100%;min-height:100dvh;margin:0;overflow-x:hidden}button,input,select{font:inherit}button,a{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}#root{width:100%;max-width:100%;min-height:100dvh;overflow-x:clip}.app-shell{background:radial-gradient(circle at 18px 18px, #24313a0a 1.5px, transparent 1.5px), linear-gradient(180deg, #fffaf0e0, #fffaf033), var(--paper-deep);background-size:34px 34px,auto;flex-direction:column;width:100%;max-width:100%;min-height:100dvh;display:flex;overflow-x:clip}.top-bar{z-index:5;padding:calc(16px + env(safe-area-inset-top,0px)) 20px 13px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fbf4e8db;border-bottom:1px solid #24313a29;justify-content:space-between;align-items:center;gap:12px;display:flex;position:sticky;top:0}.brand{letter-spacing:0;align-items:center;gap:8px;font-family:Georgia,Times New Roman,serif;font-size:1.28rem;font-weight:700;display:inline-flex}.logo-mark{width:30px;height:30px;color:var(--ink)}.logo-mark path,.logo-mark circle{fill:none;stroke:currentColor;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.logo-mark .logo-fill-a{fill:#a7c1bfb8}.logo-mark .logo-fill-b{fill:#eecb8aad}.tagline,.eyebrow,.label,.muted{color:var(--muted)}.tagline,.eyebrow,.label{letter-spacing:.11em;text-transform:uppercase;font-size:.78rem;font-weight:700}.app-main{flex-direction:column;flex:1;width:min(100%,560px);max-width:560px;margin:0 auto;display:flex;overflow-x:clip}.home-screen,.screen,.room-screen,.reveal-screen{flex-direction:column;flex:1;width:100%;min-width:0;max-width:100%;padding:24px 18px 32px;display:flex;overflow-x:clip}.home-screen{align-items:stretch;min-height:calc(100dvh - 58px)}.play-screen{justify-content:flex-start;gap:22px}.screen-heading,.room-hero{margin-bottom:20px}h1,h2,p{margin:0}h1{letter-spacing:0;max-width:11ch;margin-top:8px;font-family:Georgia,Times New Roman,serif;font-size:2.8rem;font-weight:700;line-height:.96}h2{letter-spacing:0;font-size:1.2rem;line-height:1.1}.lede{max-width:32ch;margin:14px 0 24px;font-size:1rem;line-height:1.5}.mini-corpse{aspect-ratio:4/5;border:2px solid var(--ink);width:min(68vw,238px);box-shadow:var(--shadow);background:var(--panel);perspective:900px;border-radius:6px;margin:0 auto 28px;position:relative;overflow:visible;transform:rotate(-1.5deg)}.fold-panel{height:33.333%;transform-style:preserve-3d;z-index:2;border-bottom:1px dashed #24313a57;animation:28s ease-in-out infinite paper-unfold;position:relative}.fold-top{transform-origin:bottom;background:#eecb8a;animation-name:paper-unfold-top}.fold-middle{transform-origin:50%;background:#a7c1bf;animation-name:paper-unfold-middle}.fold-bottom{transform-origin:top;background:#d8a09a;border-bottom:0;animation-name:paper-unfold-bottom}.fold-panel span{border:2px solid var(--ink);display:block;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.fold-top span{background:#fbf4e8;border-radius:50%;width:34px;height:18px}.fold-middle span{border-width:2px 0 0;width:58px;height:2px;transform:translate(-50%,-50%)rotate(-8deg)}.fold-bottom span{background:#f4d6a0;border-radius:0 0 14px 14px;width:24px;height:34px}.mini-reveal{opacity:0;z-index:1;background:#fffaf0;width:100%;height:100%;padding:16px;animation:28s ease-in-out infinite reveal-drawing-one;position:absolute;inset:0}.mini-reveal-two{animation-name:reveal-drawing-two}.mini-reveal-three{animation-name:reveal-drawing-three}.mini-reveal path,.mini-reveal circle{fill:none;stroke:var(--ink);stroke-width:2.6px;stroke-linecap:round;stroke-linejoin:round}.mini-reveal .reveal-fish{fill:#a7c1bf57}.mini-reveal .reveal-tail{fill:#d8a09a40}.mini-reveal .reveal-body{fill:#eecb8a47}.mini-reveal .reveal-flower-body{fill:#a7c1bf4d}.mini-reveal .reveal-house-body{fill:#d8a09a47}.mini-reveal .reveal-moon{fill:#b7a6bd57}.mini-reveal .reveal-house{fill:#d7a65f4d}@keyframes paper-unfold-top{0%,4%,20%,24%,40%,44%,60%,64%,80%,84%,to{opacity:1;transform:rotateX(0)translateY(0)}8%,15%,28%,35%,48%,55%,68%,75%,88%,95%{opacity:.52;transform:rotateX(-82deg)translateY(8px)}}@keyframes paper-unfold-middle{0%,4%,20%,24%,40%,44%,60%,64%,80%,84%,to{opacity:1;transform:scaleY(1)}8%,15%,28%,35%,48%,55%,68%,75%,88%,95%{opacity:.2;transform:scaleY(.18)}}@keyframes paper-unfold-bottom{0%,4%,20%,24%,40%,44%,60%,64%,80%,84%,to{opacity:1;transform:rotateX(0)translateY(0)}8%,15%,28%,35%,48%,55%,68%,75%,88%,95%{opacity:.52;transform:rotateX(82deg)translateY(-8px)}}@keyframes reveal-drawing-one{0%,5%,18%,to{opacity:0}8%,15%{opacity:1}}@keyframes reveal-drawing-two{0%,45%,58%,to{opacity:0}48%,55%{opacity:1}}@keyframes reveal-drawing-three{0%,85%,98%,to{opacity:0}88%,95%{opacity:1}}.primary-action,.secondary-action,.ghost-button,.text-button,.icon-button{cursor:pointer;letter-spacing:.01em;border:0;border-radius:6px;justify-content:center;align-items:center;min-height:48px;font-weight:800;display:inline-flex}.primary-action{color:#fffaf0;background:var(--ink);width:100%;padding:14px 18px;box-shadow:0 10px 22px #24313a26}.secondary-action{width:100%;color:var(--ink);border:1px solid var(--line);background:#fffaf0bd;margin-top:10px;padding:14px 18px}.home-actions{width:100%}.play-hero{border:1px solid var(--line);min-height:232px;box-shadow:var(--shadow);background:linear-gradient(135deg,#a7c1bf80,#0000 46%),#fffaf0c7;border-radius:8px;grid-template-columns:1fr 116px;gap:14px;padding:20px 16px 18px;display:grid;position:relative;overflow:hidden}.play-hero-copy{z-index:2;flex-direction:column;gap:10px;max-width:16rem;display:flex;position:relative}.play-hero-copy h1{max-width:7ch;margin:0;font-size:2.55rem}.play-hero-copy .muted{max-width:20ch;font-size:.96rem;line-height:1.35}.play-hero .mini-corpse{align-self:start;width:112px;margin:0;transform:rotate(2deg)}.start-orb{z-index:3;border:2px solid var(--ink);color:#fffaf0;background:var(--ink);border-radius:42% 48% 38% 52%;flex-direction:column;justify-content:center;align-items:center;width:112px;height:100px;font-weight:900;line-height:1.05;display:inline-flex;position:absolute;bottom:14px;right:14px;transform:rotate(-2deg);box-shadow:0 14px 28px #24313a2e}.start-orb span:last-child{font-size:.86rem}.compact{width:auto;min-height:40px;margin:0;padding:10px 14px}.ghost-button{min-height:40px;color:var(--ink);border:1px solid var(--line);background:#efe5d6;padding:0 13px}.text-button{min-height:36px;color:var(--blue);box-shadow:none;background:0 0;justify-content:flex-start;padding:0;font-size:.9rem}.icon-button{border:1px solid var(--line);width:44px;min-height:44px;color:var(--ink);box-shadow:none;background:#fffaf0bd;flex:none;padding:0;font-size:1.35rem;line-height:1}.screen-heading{align-items:flex-start;gap:12px;display:flex}.screen-heading>div{min-width:0}.bottom-icon-button{align-self:center;margin-top:4px}.reset-button{color:#9a3412;justify-content:center;align-self:center;margin-top:10px}.reset-panel{flex-direction:column;align-items:center;gap:4px;padding:10px 0 0;display:flex}.reset-error{text-align:center;max-width:32ch}button:disabled{cursor:wait;opacity:.58}.form-card,.panel,.drawing-panel,.join-panel,.status-panel{border:1px solid var(--line);width:100%;box-shadow:var(--shadow);background:#fffaf0d1;border-radius:6px;padding:16px}.form-card,.join-form,.room-screen,.reveal-screen{gap:14px}.join-panel,.status-panel{flex-direction:column;gap:12px;display:flex}.field{color:var(--muted);flex-direction:column;gap:7px;font-size:.86rem;font-weight:700;display:flex}.field input,.field select,.copy-row input{border:1px solid var(--line);width:100%;min-width:0;min-height:48px;color:var(--ink);background:#fffaf0;border-radius:6px;padding:0 13px}.field input:focus,.field select:focus,.copy-row input:focus{border-color:var(--blue);outline:3px solid #6e95a32e}.error-text,.notice{color:#b42318;font-weight:700}.warning-text{color:#9a3412;margin-top:10px;font-size:.9rem;font-weight:700;line-height:1.35}.room-code{color:var(--ink);margin-top:2px;font-size:.92rem;font-weight:800}.room-hero{justify-content:space-between;align-items:flex-start;gap:12px;min-width:0;display:flex}.room-hero>div{min-width:0}.room-actions{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.room-hero h1{max-width:9ch;font-size:2.25rem}.copy-row{align-items:center;gap:8px;margin-top:8px;display:flex}.copy-row input{flex:auto;width:auto}.copy-row .ghost-button{flex:none}.invite-more-panel{box-shadow:none;background:#fffaf085}.invite-more-panel summary{cursor:pointer;justify-content:space-between;align-items:center;gap:12px;font-weight:900;list-style:none;display:flex}.invite-more-panel summary::-webkit-details-marker{display:none}.invite-more-panel summary:after{content:"+";color:var(--muted);font-size:1.25rem;line-height:1}.invite-more-panel[open] summary:after{content:"-"}.invite-more-panel summary small{color:var(--muted);font-size:.76rem;font-weight:800}.invite-more-panel[open]{flex-direction:column;gap:10px;display:flex}.invite-more-panel .share-action{margin-top:0}.invite-text-link{justify-content:center;align-self:center}.share-action{margin-top:10px}.section-title{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.section-title>span{color:#fff;background:var(--blue);border-radius:999px;justify-content:center;align-items:center;min-width:38px;min-height:32px;font-size:.8rem;font-weight:800;display:inline-flex}.artist-list,.avatar-row,.swatches,.tool-row{align-items:center;gap:9px;display:flex}.artist-list{flex-wrap:wrap}.artist-pill{border:1px solid var(--line);background:#fffaf0;border-radius:999px;align-items:center;gap:8px;min-height:34px;padding:0 11px;font-size:.9rem;font-weight:700;display:inline-flex}.artist-pill span{border-radius:999px;width:10px;height:10px}.artist-pill em{color:#fff;background:var(--green);border-radius:999px;margin-left:2px;padding:2px 7px;font-size:.72rem;font-style:normal}.you-row{align-items:center;gap:10px;display:flex}.you-row span{border-radius:999px;width:18px;height:18px;box-shadow:0 0 0 2px #fff,0 0 0 3px #18151f24}.avatar-choice,.swatch{cursor:pointer;border:2px solid #fff;border-radius:999px;width:36px;height:36px;box-shadow:0 0 0 1px #18151f29}.avatar-choice.selected,.swatch.selected{box-shadow:0 0 0 3px var(--blue)}.drawing-panel{flex-direction:column;gap:12px;padding:12px;display:flex}.drawing-focus{justify-content:center;min-height:auto}.waiting-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:210px;display:flex}.waiting-creature{aspect-ratio:11/9;width:min(64vw,230px);margin-bottom:4px}.waiting-creature svg{width:100%;height:100%;display:block;overflow:visible}.waiting-creature path,.waiting-creature circle{fill:none;stroke:var(--ink);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.waiting-creature .fish-head path:first-child{fill:#a7c1bf61}.waiting-creature .fold-body path:first-child{fill:#eecb8a57}.waiting-creature .tail-fin path:first-child,.waiting-creature .tail-fin path:nth-child(2){fill:#d8a09a40}.waiting-creature .creature-bob{transform-origin:110px 92px;animation:2.8s ease-in-out infinite creature-bob}.waiting-creature .tail-fin{transform-origin:88px 99px;animation:1.4s ease-in-out infinite tail-flick}.waiting-creature .lion-feet{transform-origin:126px 145px;animation:1.4s ease-in-out infinite paw-tap}.waiting-creature .waiting-dots circle{fill:var(--ink);stroke:none;animation:1.8s ease-in-out infinite dot-drift}.waiting-creature .waiting-dots circle:nth-child(2){animation-delay:.18s}.waiting-creature .waiting-dots circle:nth-child(3){animation-delay:.36s}.waiting-creature .ground-line{stroke:#24313a52;stroke-width:2px}@keyframes creature-bob{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-5px)rotate(1deg)}}@keyframes tail-flick{0%,to{transform:rotate(-3deg)}50%{transform:rotate(7deg)}}@keyframes paw-tap{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}@keyframes dot-drift{0%,to{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-5px)}}@media (prefers-reduced-motion:reduce){.fold-panel,.mini-reveal{animation:none}.mini-reveal{opacity:.18}.waiting-creature .creature-bob,.waiting-creature .tail-fin,.waiting-creature .lion-feet,.waiting-creature .waiting-dots circle,.reveal-art,.reveal-cover,.reveal-crease{animation:none}.reveal-cover,.reveal-crease{opacity:0}}.draw-wrap{flex-direction:column;gap:12px;display:flex}.immersive-draw-wrap{flex-direction:column-reverse;flex:1;gap:10px;min-height:0}.materials-panel{flex-direction:column;gap:9px;display:flex}.immersive-materials{padding-bottom:env(safe-area-inset-bottom,0px);flex:none}.material-tabs{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.material-tab{border:1px solid var(--line);min-height:42px;color:var(--ink);background:#fffaf0bd;border-radius:6px;font-size:.78rem;font-weight:800}.material-tab.selected{color:#fffaf0;background:var(--ink)}.watercolor-palette{border:1px solid var(--line);background:#fffaf09e;border-radius:6px;grid-template-columns:repeat(5,1fr);gap:7px;padding:8px;display:grid}.paint{border:2px solid #fffaf0eb;border-radius:999px 999px 999px 12px;height:34px;box-shadow:0 0 0 1px #24313a2e}.paint.selected{box-shadow:0 0 0 3px var(--blue)}.size-tabs{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.size-tab{border:1px solid var(--line);min-height:38px;color:var(--ink);text-transform:capitalize;background:#fffaf0ad;border-radius:6px;justify-content:center;align-items:center;gap:7px;font-size:.78rem;font-weight:800;display:inline-flex}.size-tab.selected{border-color:var(--ink);background:#a7c1bf6b}.size-dot{background:var(--ink);border-radius:999px;display:block}.size-dot.fine{width:5px;height:5px}.size-dot.medium{width:8px;height:8px}.size-dot.bold{width:12px;height:12px}.tool-row{flex-wrap:wrap;justify-content:space-between;gap:8px;display:flex}.zoom-hint{min-height:40px;color:var(--muted);align-items:center;margin-right:auto;font-size:.78rem;font-weight:800;display:inline-flex}.solo-test-toggle{color:var(--muted);align-items:center;gap:9px;margin:12px 0;font-size:.92rem;font-weight:800;display:flex}.solo-test-toggle input{width:20px;height:20px;accent-color:var(--ink)}.brush-size{min-width:106px;color:var(--muted);align-items:center;gap:8px;font-size:.82rem;font-weight:800;display:flex}.brush-size input{width:74px;accent-color:var(--ink)}.drawing-surface,.reveal-art{border:2px solid var(--ink);touch-action:none;-webkit-user-select:none;user-select:none;background:radial-gradient(circle at 20% 18%,#d7c6a538,#0000 12%),radial-gradient(circle at 74% 76%,#a7c1bf29,#0000 14%),#fff8ec;border-radius:6px;width:100%;display:block;box-shadow:inset 0 0 0 1px #ffffff94,0 16px 28px #463a2c1a}.drawing-preview{aspect-ratio:1;border:2px solid var(--ink);pointer-events:none;background:radial-gradient(circle at 20% 18%,#d7c6a538,#0000 12%),radial-gradient(circle at 74% 76%,#a7c1bf29,#0000 14%),#fff8ec;border-radius:6px;align-self:center;width:min(100%,240px);display:block;box-shadow:inset 0 0 0 1px #ffffff94,0 12px 22px #463a2c14}.immersive-drawing-surface{flex:1;height:100%;min-height:0;max-height:none}.drawing-table{z-index:30;width:auto;max-width:100svw;height:100dvh;padding:calc(14px + env(safe-area-inset-top,0px)) 12px calc(12px + env(safe-area-inset-bottom,0px));background:radial-gradient(circle at 16px 16px,#24313a0a 1.5px,#0000 1.5px) 0 0/34px 34px,linear-gradient(#fffaf0,#e9dfcf);flex-direction:column;gap:10px;display:flex;position:fixed;inset:0;overflow:hidden}.drawing-table-header{flex:none;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.drawing-table-header h2{margin-top:2px;font-family:Georgia,Times New Roman,serif;font-size:1.4rem}.drawing-table>.primary-action{flex:none}.gallery-screen{gap:14px}.gallery-list{flex-direction:column;gap:10px;display:flex}.gallery-item{border:1px solid var(--line);min-height:58px;box-shadow:var(--shadow);background:#fffaf0d1;border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:0 14px;font-weight:800;display:flex}.gallery-item small{color:var(--muted);white-space:nowrap;font-size:.78rem}.empty-gallery{flex-direction:column;gap:12px;display:flex}.active-games{flex-direction:column;gap:18px;width:100%;margin-top:0;display:flex}.active-games-heading{border-top:1px solid var(--line);justify-content:space-between;align-items:end;gap:14px;padding-top:18px;display:flex}.active-games-heading h2{font-family:Georgia,Times New Roman,serif;font-size:1.45rem}.caught-up{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:6px 0 2px;display:flex}.caught-up strong{font-family:Georgia,Times New Roman,serif;font-size:1.45rem}.caught-up span{color:var(--muted);font-size:.95rem}.game-group{flex-direction:column;gap:8px;display:flex}.game-group-title,.game-card{justify-content:space-between;align-items:center;gap:12px;display:flex}.game-group-title{color:var(--muted);font-family:Georgia,Times New Roman,serif;font-size:1.45rem;font-weight:700}.game-group-title small,.fold-count{border:1px solid var(--line);min-width:32px;color:var(--muted);text-align:center;background:#fffaf0a3;border-radius:999px;padding:3px 8px;font-size:.72rem;font-weight:800}.game-list{flex-direction:column;gap:8px;display:flex}.game-card{border:1px solid var(--line);min-height:74px;color:var(--ink);box-shadow:var(--shadow);background:linear-gradient(90deg,#d675681f,#0000 42%),#fffaf0d1;border-radius:8px;padding:13px 14px}.game-card-featured{background:linear-gradient(90deg,#5f8d782e,#0000 46%),#fffaf0e6;border-color:#5f8d787a}.game-card span:first-child{flex-direction:column;gap:4px;min-width:0;display:flex}.game-card strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.game-card small{color:var(--muted);font-size:.78rem;font-weight:700}.game-empty{padding:3px 0 6px;font-size:.86rem}.gallery-shortcut{justify-content:center;align-self:center}.drawing-surface{aspect-ratio:1}.reveal-screen{align-items:stretch}.reveal-stage{perspective:900px}.reveal-art{aspect-ratio:1/3;transform-origin:top;max-height:68svh;animation:.82s ease-out both reveal-paper-arrive}.revealed-drawing{opacity:1}.reveal-cover{transform-box:fill-box;transform-origin:top;filter:drop-shadow(0 1.5px 1px #4a3a2914);animation:.9s cubic-bezier(.18,.84,.22,1) both reveal-cover-unfold}.reveal-crease{fill:none;stroke:#a7865d38;stroke-width:.36px;stroke-linecap:round;opacity:0;animation:.9s ease-out both reveal-crease-soften}@keyframes reveal-paper-arrive{0%{opacity:0;transform:translateY(18px)rotateX(10deg)}to{opacity:1;transform:translateY(0)rotateX(0)}}@keyframes reveal-cover-unfold{0%{opacity:1;transform:scaleY(1)}58%{opacity:.9;transform:scaleY(.12)}to{opacity:0;transform:scaleY(.02)}}@keyframes reveal-crease-soften{0%{opacity:0}45%{opacity:.28}to{opacity:0}}@media (width>=520px){.home-screen,.screen,.room-screen,.reveal-screen{padding-inline:24px}h1{font-size:3.15rem}}
