:root{--color-bg: #f8fafc;--color-panel: #ffffff;--color-text: #111827;--color-muted: #6b7280;--color-border: #e5e7eb;--color-brand: #2563eb;--color-brand-hover: #1d4ed8;--sidebar-w: 240px;--sidebar-bg: #111827;--sidebar-border: #1f2937;--sidebar-text: #e5e7eb;--sidebar-text-dim: #cbd5e1;--font-sans: system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", "Courier New", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--radius-sm: 8px;--radius-md: 12px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--topbar-h: 56px;--page-max-w: 1000px;--flip-duration: .22s;--flip-ease: cubic-bezier(.25,.8,.25,1);--flip-perspective: 1600px;--z-sidebar: 20;--z-topbar: 10;--z-overlay: 10;--z-bottom: 40;--z-dropdown: 3000;--sidebar-offset: var(--sidebar-w)}.focus-play,.focus-root{min-height:100vh;background:var(--color-bg)}.focus-root{display:grid;place-items:center;padding:16px;padding-top:calc(16px + env(safe-area-inset-top,0px));padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));padding-left:calc(16px + env(safe-area-inset-left,0px));padding-right:calc(16px + env(safe-area-inset-right,0px));min-height:calc(100dvh - var(--topbar-h) - 32px);overflow:hidden;overscroll-behavior:none}@media (max-width: 480px){.play-card-inner{min-height:clamp(260px,72vh,620px)}.icon-btn{width:40px;height:40px}.icon-btn svg{width:20px;height:20px}.play-nav-btn{width:56px;height:56px}.play-nav-btn svg{width:24px;height:24px}.play-card-progress{margin:0 var(--space-3)}.play-md img{max-height:min(420px,44vh)}}@media (min-width: 768px) and (max-width: 1024px){.play-card-inner{min-height:clamp(320px,60vh,640px)}}@media (orientation: landscape) and (max-height: 420px){.play-card-inner{min-height:clamp(220px,66vh,520px)}}@media (max-width: 720px){.play-stage{flex-direction:column;align-items:stretch}.play-side-buttons{flex-direction:row;width:auto}.play-side-buttons .play-side-btn{width:44px;height:44px}}@media (orientation: portrait){.play-side-buttons{display:none!important}}@media (max-aspect-ratio: 3/4){.play-side-buttons{display:none!important}}@media (orientation: landscape) and (max-width: 1024px){.main.focus{--focus-topbar: 0px}.main.focus .topbar{display:none;height:0;padding:0;border-bottom:0}.play-card-shell{padding:var(--space-3)}.play-page-header{display:none}}html{font-size:16px}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}button,input,select,textarea{font:inherit}h1,h2,h3{line-height:1.25;letter-spacing:.02em}code,pre{font-family:var(--font-mono)}body{margin:0;font-family:var(--font-sans);line-height:1.6;letter-spacing:.01em;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;overscroll-behavior-x:none}.layout{display:flex;min-height:100vh;max-width:100%}.layout.closed{--sidebar-offset: 0px}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-text);border-right:1px solid var(--sidebar-border);transform:translate(0);transition:transform .2s ease;z-index:var(--z-sidebar)}.sidebar.closed{transform:translate(-100%)}.brand-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--sidebar-border)}.brand-link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:#fff}.brand{font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-title{font-weight:700}.brand-icon{width:28px;height:28px;display:grid;place-items:center;color:#cbd5e1}.sidebar-close{margin-left:auto;width:32px;height:32px;border-radius:6px;border:none;background:#ffffff0f;color:var(--sidebar-text-dim);cursor:pointer;display:grid;place-items:center;line-height:0;transition:background .15s ease,color .15s ease}.sidebar-close:hover{background:#ffffff1f;color:#fff}.sidebar-close svg{display:block}.menu{display:flex;flex-direction:column;padding:var(--space-2);gap:var(--space-2)}.nav-item{display:block;padding:var(--space-3) var(--space-3);border-radius:var(--radius-sm);text-decoration:none;color:var(--sidebar-text-dim);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item:hover{background:#ffffff0f}.nav-item.active{background:#2563ebe6;color:#fff;font-weight:600}.main{flex:1;margin-left:var(--sidebar-offset);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .2s ease;max-width:100%}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);border-bottom:1px solid var(--color-border);background:var(--color-panel);position:sticky;top:0;z-index:var(--z-topbar)}.icon-btn{font-size:20px;width:32px;height:32px;border-radius:8px;border:1px solid var(--color-border);background:#f9fafb;cursor:pointer;display:grid;place-items:center;line-height:0;transition:background .15s ease,border-color .15s ease}.icon-btn svg{display:block;width:18px;height:18px}.icon-btn:hover{background:#f3f4f6}.content{padding:var(--space-4);flex:1 1 auto;min-height:0}.main.focus .content{padding:0;display:flex;flex-direction:column}.main.focus{overflow:hidden;--focus-topbar: var(--topbar-h);min-height:100dvh}.main.focus .content{overflow:hidden}.main.focus .content .focus-root{height:calc(100dvh - var(--focus-topbar, var(--topbar-h)));min-height:calc(100dvh - var(--focus-topbar, var(--topbar-h)))}.content.focus .focus-root{flex:1 1 auto;min-height:0}.container{max-width:var(--page-max-w);margin:0 auto;width:100%;max-width:min(var(--page-max-w),100%)}.overlay{display:none}@media (max-width: 900px){.layout{--sidebar-offset: 0px}.sidebar{transform:translate(-100%)}.layout.open .sidebar{transform:translate(0)}.overlay{display:none}.layout.open .overlay{display:block;position:fixed;inset:0;background:#0000004d;z-index:var(--z-overlay)}}.home-hero{margin-bottom:var(--space-4)}.home-hero p{margin:0;color:var(--color-muted)}.hero{position:relative;background:radial-gradient(1200px 200px at 0% 0%,#eef2ff,transparent 60%),radial-gradient(800px 180px at 100% 100%,#fff7ed,transparent 50%),var(--color-panel);border:1px solid var(--color-border);border-radius:14px;padding:28px;box-shadow:var(--shadow-md);display:grid;gap:10px}.hero-brand{display:inline-flex;align-items:center;gap:8px;color:#334155}.hero .brand-icon{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#fff;border:1px solid var(--color-border);color:#475569}.hero-brand-name{font-weight:800;letter-spacing:.02em}.hero-title{margin:2px 0 0;font-size:clamp(24px,4vw,36px);font-weight:800}.hero-sub{margin:0;color:var(--color-muted)}.hero-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.hero-cta{padding-inline:16px}.hero-stats{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}.stat-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--color-border);background:#ffffffd9;border-radius:999px;box-shadow:var(--shadow-sm)}.stat-pill .stat{font-size:18px}.pill-icon{width:20px;height:20px;display:grid;place-items:center;color:#475569}.home-cards{margin-top:var(--space-4)}.quick-card{display:grid;grid-template-columns:40px 1fr;align-items:stretch;gap:12px;min-height:160px}.quick-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:radial-gradient(120px 60px at 0% 0%,#eef2ff,transparent 60%),radial-gradient(80px 50px at 100% 100%,#fff7ed,transparent 50%),#fff;border:1px solid var(--color-border);color:#334155}.quick-main{display:grid;grid-template-rows:auto 1fr auto;gap:6px;align-items:start;width:100%;min-width:0}.quick-cta{justify-self:end;align-self:end;margin-top:8px}.recent-card .card-title{margin-bottom:6px}.recent-list li{padding:10px 0}.recent-q{font-weight:600}@media (max-width: 560px){.quick-card{grid-template-columns:1fr;grid-template-rows:auto auto;align-content:start}.quick-icon{width:48px;height:48px}.quick-main{grid-template-rows:auto auto auto}.quick-cta{justify-self:stretch;width:100%;text-align:center;margin-top:12px}}@media (max-width: 560px){.hero-actions{flex-direction:column;align-items:stretch}.hero-actions .btn{width:100%;text-align:center}}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-4);margin-top:var(--space-4)}.cards.home-cards{grid-template-columns:1fr}@media (min-width: 720px){.cards.home-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}.card{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);box-shadow:var(--shadow-sm);transition:transform .05s ease,box-shadow .05s ease}.card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.card-title{font-weight:600;margin:0 0 var(--space-2);font-size:18px}.card-desc{color:var(--color-muted);margin:0 0 var(--space-3)}.page-title,.card-title,.deck-name,.hero-title{word-break:break-word;overflow-wrap:anywhere}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.card2{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-2);position:relative}.card2-inner{position:relative;height:140px;perspective:1000px;cursor:pointer;transform-style:preserve-3d;transition:transform .35s ease;z-index:1}.card2-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:var(--radius-sm);border:1px dashed var(--color-border);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);justify-content:flex-start;align-items:stretch;overflow:hidden}.card2-face.front{background:#f8fafc}.card2-face.back{background:#eef2ff;transform:rotateY(180deg)}.card2-inner.flipped{transform:rotateY(180deg)}.card2-title{font-weight:700;font-size:16px}.card2-ans{font-size:16px;font-weight:600}.card2-actions{display:flex;gap:var(--space-2)}.card2-tags{display:flex;gap:var(--space-2);flex-wrap:wrap}.card2-attach{display:flex;gap:var(--space-2);align-items:center}.card2-content{display:flex;flex-direction:column;gap:var(--space-1);height:100%;overflow:auto;word-break:break-word;overflow-wrap:anywhere}.card2-face pre{max-width:100%;overflow:auto}.card2-face img{max-width:100%;max-height:100%;height:auto;object-fit:contain;display:block;margin:0 auto}.card2-edit{position:absolute;top:8px;right:8px;width:32px;height:32px;display:grid;place-items:center;border:1px solid var(--color-border);border-radius:8px;background:#ffffffe6;color:var(--color-text);box-shadow:var(--shadow-sm);opacity:0;transform:translateY(-2px);transition:opacity .15s ease,transform .15s ease,background .15s ease;text-decoration:none;z-index:var(--z-topbar)}.card2:hover .card2-edit,.card2:focus-within .card2-edit{opacity:1;transform:translateY(0)}.card2-edit:hover{background:#fff}.deck-card{gap:var(--space-2)}.deck-cover{position:relative;border-radius:10px;overflow:hidden;height:140px;border:1px solid var(--color-border)}.deck-cover img{width:100%;height:100%;object-fit:cover;display:block}.deck-cover:after{display:none}.deck-cover-overlay{position:absolute;left:0;right:0;bottom:0;padding:10px;color:#fff;display:grid;gap:4px}.deck-name{font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.4)}.deck-meta{display:flex;align-items:center;gap:6px}.tag{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-pill);background:#f3f4f6;border:1px solid var(--color-border);font-size:12px}.face-chip{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent}.face-chip .dot{width:6px;height:6px;border-radius:999px;display:inline-block}.face-chip.front{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.face-chip.front .dot{background:currentColor}.face-chip.back{background:#f5f3ff;color:#7c3aed;border-color:#ddd6fe}.face-chip.back .dot{background:currentColor}.tag-x{margin-left:var(--space-2);border:none;background:transparent;cursor:pointer}.new-card-tile{position:relative;overflow:hidden;cursor:pointer;border:1px dashed var(--color-border);background:radial-gradient(1200px 200px at 0% 0%,#eef2ff,transparent 60%),radial-gradient(800px 180px at 100% 100%,#fff7ed,transparent 50%),#fff;display:grid;place-items:center;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.new-card-tile:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:#c7d2fe}.new-card-tile:focus-visible{outline:2px solid var(--color-brand);outline-offset:2px}.new-card-tile[aria-disabled=true]{opacity:.7;cursor:default}.new-card-body{display:grid;place-items:center;gap:8px;text-align:center}.new-icon{width:44px;height:44px;border-radius:999px;display:grid;place-items:center;background:radial-gradient(circle at 35% 30%,#2563eb22,transparent 58%),#fff;border:1px solid #dbeafe;color:var(--color-brand)}.new-label{font-weight:700}.new-sub{color:var(--color-muted);font-size:12px}.btn{display:inline-block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);text-decoration:none;border:1px solid #d1d5db;background:#fff;color:var(--color-text);cursor:pointer}.btn:hover{background:#f3f4f6}.btn.primary{border-color:var(--color-brand);background:var(--color-brand);color:#fff}.btn.primary:hover{background:var(--color-brand-hover)}.btn.primary.is-disabled,.btn.primary:disabled{background:#f3f4f6;border-color:var(--color-border);color:#6b7280;cursor:default;opacity:1}.btn.danger{color:#b91c1c;border-color:#fecaca}.list-plain{list-style:none;padding:0;margin:0}.list-plain li{padding:var(--space-2) 0;border-top:1px dashed var(--color-border)}.list-plain li:first-child{border-top:0}.muted{color:var(--color-muted);font-size:12px}.stat{font-size:28px;font-weight:700}.tagpicker{position:relative}.tagpicker input{width:100%;padding:var(--space-2) var(--space-3);border:1px solid #d1d5db;border-radius:var(--radius-sm);background:#fff}.tagpicker.is-open{z-index:var(--z-dropdown)}.tagpicker-list{position:absolute;left:0;right:auto;top:calc(100% + var(--space-1));width:min(280px,100%);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow-md);max-height:240px;overflow:auto;z-index:2}.tagpicker-item{padding:var(--space-2) var(--space-3);display:flex;justify-content:space-between;cursor:pointer}.tagpicker-item:hover,.tagpicker-item.active{background:#eef2ff}.tagpicker-empty{padding:var(--space-3);color:var(--color-muted)}.play-stage{display:flex;gap:var(--space-3);align-items:stretch}.play-card-shell,.play-card-body{flex:1 1 auto;display:flex;flex-direction:column;gap:var(--space-3);min-height:0}.play-card-inner{position:relative;flex:1 1 auto;min-height:clamp(320px,62vh,680px);perspective:var(--flip-perspective);cursor:pointer}.play-card-controls{display:flex;align-items:flex-end;gap:var(--space-2);width:100%}.play-card-progress{flex:1;margin:0 var(--space-4);text-align:center}.play-side-buttons{display:flex;flex-direction:column;gap:var(--space-2);justify-content:flex-start;width:48px;flex-shrink:0}.play-side-btn{width:48px;height:48px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-panel);box-shadow:var(--shadow-sm);color:var(--color-text);display:grid;place-items:center;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.play-side-btn:disabled{opacity:.35;cursor:default}.play-side-btn:not(:disabled):hover{background:#f3f4f6}.play-side-btn-menu{background:var(--color-brand);border-color:transparent;color:#fff;box-shadow:none}.play-nav-btn{width:48px;height:48px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#f9fafb;box-shadow:var(--shadow-sm);display:grid;place-items:center;line-height:0;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}.play-nav-btn svg{width:22px;height:22px}.play-nav-btn:hover{background:#f3f4f6}.play-nav-btn:active{transform:translateY(1px)}.play-side-btn-menu:hover{background:var(--color-brand-hover)}.play-stage-focus{width:min(92vw,900px);max-width:100%;margin:0 auto}.focus-root .play-stage{align-self:stretch;justify-self:center;height:100%}.focus-root .play-card-shell,.focus-root .play-card-body,.focus-root .play-card-inner{min-height:0}.play-rotator{position:relative;height:100%;transform-style:preserve-3d;transition:transform var(--flip-duration) var(--flip-ease)}.play-rotator.flipped{transform:rotateY(180deg)}.play-card-inner.no-anim .play-rotator{transition:none}:root[data-anim=none] .play-rotator{transition:none!important}.play-card-inner.slide-prev-out{transform:translate(var(--slide-dist, 16px)) scale(var(--slide-scale, .995));opacity:0;transition:transform var(--slide-out-duration, .16s) var(--slide-ease, ease),opacity var(--slide-out-duration, .16s) var(--slide-ease, ease)}.play-card-inner.slide-prev-in{transform:translate(calc(var(--slide-dist, 16px) * -1)) scale(var(--slide-scale, .995));opacity:0}.play-card-inner.slide-prev-in-active{transform:translate(0) scale(1);opacity:1;transition:transform var(--slide-in-duration, .18s) var(--slide-ease, ease),opacity var(--slide-in-duration, .18s) var(--slide-ease, ease)}.play-card-inner.slide-next-out{transform:translate(calc(var(--slide-dist, 16px) * -1)) scale(var(--slide-scale, .995));opacity:0;transition:transform var(--slide-out-duration, .16s) var(--slide-ease, ease),opacity var(--slide-out-duration, .16s) var(--slide-ease, ease)}.play-card-inner.slide-next-in{transform:translate(var(--slide-dist, 16px)) scale(var(--slide-scale, .995));opacity:0}.play-card-inner.slide-next-in-active{transform:translate(0) scale(1);opacity:1;transition:transform var(--slide-in-duration, .18s) var(--slide-ease, ease),opacity var(--slide-in-duration, .18s) var(--slide-ease, ease)}.play-card-inner.flipped{transform:rotateY(180deg)}.play-face{position:absolute;inset:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;backface-visibility:hidden;border-radius:var(--radius-md);border:1px dashed var(--color-border);padding:var(--space-4);overflow:auto;overscroll-behavior:contain}.play-face.front{background:#f8fafc}.play-face.back{background:#eef2ff;transform:rotateY(180deg)}.play-q{font-size:clamp(18px,3vw,28px);font-weight:700;text-align:center}.play-ans-label{color:#374151;margin-bottom:6px}.play-ans{font-size:clamp(18px,2.4vw,24px);font-weight:600;text-align:left}.play-face.edit{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;overflow:auto}.edit-card-input{width:100%;flex:1 1 auto;min-height:120px;height:auto;resize:none;border:none;outline:none;background:transparent;font:inherit;line-height:1.6;color:var(--color-text);text-align:left;caret-color:var(--color-brand)}.edit-q{font-size:clamp(18px,3vw,28px);font-weight:400}.edit-a{font-size:clamp(18px,2.4vw,24px);font-weight:400}.edit-card-input::placeholder{color:var(--color-muted)}.play-md{width:100%;height:auto;overflow:visible;text-align:left}.play-q.play-md,.play-ans.play-md{font-size:1rem;font-weight:400;text-align:left}.play-face.edit .play-md{flex:1 1 auto;min-height:0}.md-preview{font-size:1rem;font-weight:400}.edit-page .edit-card-input{font-size:.95rem;line-height:1.5}.edit-page .md-preview{font-size:.95rem}.edit-page .play-md pre{font-size:.9rem}.edit-page .play-md h1{font-size:clamp(18px,2.1vw,24px);font-weight:400}.edit-page .play-md h2{font-size:clamp(16px,1.9vw,20px);font-weight:400}.edit-page .play-md h3{font-size:clamp(14px,1.7vw,18px);font-weight:400}.edit-page .play-md h4{font-size:clamp(13px,1.5vw,16px);font-weight:400}.edit-page .play-md strong,.edit-page .play-md b{font-weight:400}.play-md h1,.play-md h2,.play-md h3,.play-md h4{margin:.2em 0}.play-md h1{font-size:clamp(20px,2.4vw,26px);font-weight:700}.play-md h2{font-size:clamp(18px,2.1vw,22px);font-weight:700}.one-line-center{text-align:center!important;margin-block:auto}.play-md h3{font-size:clamp(16px,1.9vw,20px);font-weight:600}.play-md h4{font-size:clamp(14px,1.7vw,18px);font-weight:600}.play-md p{margin:.2em 0}.play-md ul,.play-md ol{padding-left:1.1em;margin:.3em 0}.play-md code{background:#f3f4f6;padding:0 .2em;border-radius:4px;font-family:var(--font-mono)}.play-md pre code,.play-md .react-syntax-highlighter code{background:transparent;padding:0;border-radius:0}.play-md pre{background:#fff;color:var(--color-text);border:1px solid var(--color-border);padding:10px 12px;border-radius:8px;overflow:auto;font-family:var(--font-mono)}.play-md pre.react-syntax-highlighter{box-shadow:none}.play-md blockquote{border-left:3px solid #e5e7eb;padding-left:.7em;color:#4b5563;margin:.3em 0}.play-md img{max-width:100%;height:auto;max-height:min(360px,32vh);display:block;margin:0 auto}.edit-page{padding-bottom:84px}.card-edit-toolbar{display:grid;gap:var(--space-2);width:100%;grid-template-columns:1fr;align-items:stretch}.card-edit-toolbar-preview{display:inline-flex;align-items:center;gap:6px}.card-edit-toolbar-preview input{margin:0}.card-edit-toolbar .btn{width:100%}.card-edit-toolbar-meta{font-size:.9rem;justify-self:start}@media (max-width: 720px){.card-edit-toolbar-meta{width:100%;text-align:right}}@media (min-width: 721px){.card-edit-toolbar .btn{justify-self:start}}@media (max-width: 600px){.edit-page .card{padding:var(--space-3)}.edit-page .play-card-inner{min-height:clamp(200px,52vh,460px)}.edit-page .play-face{padding:var(--space-3)}.edit-page .card-edit-toolbar{gap:var(--space-2)}}.edit-bottom{position:sticky;bottom:0;z-index:var(--z-bottom, 40);pointer-events:none;background:transparent}.edit-bottom-inner{display:flex;align-items:center;gap:var(--space-3, 12px);padding:var(--space-2, 8px) var(--space-3, 12px);pointer-events:none}.edit-bottom .spacer{flex:1}.edit-bottom-inner button,.edit-bottom-inner .btn,.edit-bottom-inner [role=button]{pointer-events:auto}.muted.warn{color:#b45309}.page-header{display:grid;gap:8px;margin:8px 0 16px}.page-breadcrumb{font-size:14px}.link-back{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-panel);color:var(--color-text);text-decoration:none}.link-back:hover{background:#f3f4f6}.page-header-main{display:flex;align-items:center;gap:12px}.page-title{margin:0;font-size:32px;font-weight:800;letter-spacing:.01em}.page-actions{margin-left:auto}.page-meta{color:var(--color-muted);font-size:12px}@media (max-width: 640px){.page-title{font-size:24px}}@media (prefers-reduced-motion: reduce){.play-rotator,.play-card-inner.slide-prev-out,.play-card-inner.slide-prev-in-active{transition:none}}.deckpicker{position:relative;min-width:280px}.deckpicker-input{position:relative}.deckpicker input{width:100%;padding:var(--space-2) calc(var(--space-3) * 2 + 8px) var(--space-2) var(--space-3);border:1px solid #d1d5db;border-radius:var(--radius-sm);background:#fff}.deckpicker-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;color:#9ca3af}.deckpicker.is-open{z-index:var(--z-dropdown)}.deckpicker-list{position:absolute;left:0;right:auto;top:calc(100% + var(--space-1));width:min(540px,90vw);max-height:320px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow-md);overflow:auto}.deckpicker-empty{padding:var(--space-3);color:var(--color-muted)}.deck-item{padding:var(--space-2) var(--space-3);cursor:pointer}.deck-item:hover,.deck-item.active{background:#eef2ff}.deck-item-main{display:flex;gap:8px;align-items:baseline}.deck-item-name{font-weight:600}.deck-item-meta{display:flex;gap:8px;align-items:center;margin-left:auto}.badge{display:inline-block;min-width:20px;text-align:center;padding:0 6px;border-radius:10px;background:#e5e7eb;font-size:12px}.deck-item-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.play-select-page{display:grid;gap:clamp(24px,4vw,40px);padding:clamp(24px,5vw,48px) var(--space-4) clamp(36px,6vw,56px)}.play-select-hero{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,320px);gap:clamp(18px,5vw,48px);border-radius:24px;padding:clamp(26px,5vw,52px);background:radial-gradient(160% 120% at 20% 0%,rgba(59,130,246,.22),transparent 60%),radial-gradient(120% 140% at 100% 20%,rgba(14,165,233,.18),transparent 72%),linear-gradient(135deg,#f8fafc,#e0f2fe 110%);border:1px solid rgba(37,99,235,.16);box-shadow:0 26px 60px #1e40af1f;overflow:hidden}.play-select-hero-main{position:relative;z-index:1;display:grid;gap:var(--space-3)}.play-select-title{margin:0;font-size:clamp(26px,4vw,36px);letter-spacing:.01em}.play-select-desc{margin:0;color:#0f172ab8;max-width:520px}.play-select-stats{display:flex;flex-wrap:wrap;gap:12px;margin-top:var(--space-2)}.play-select-stat{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-pill);background:#ffffff94;color:#0f172ac7;font-weight:600;box-shadow:0 8px 18px #1e40af14}.play-select-stat.highlight{background:#2563eb1f;color:var(--color-brand)}.play-select-hero-art{position:relative;border-radius:18px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffff6b;min-height:clamp(180px,28vw,280px);overflow:hidden;isolation:isolate}.play-select-orb{position:absolute;width:clamp(120px,30vw,240px);aspect-ratio:1;border-radius:50%;filter:blur(.5px);opacity:.75}.play-select-orb.orb-a{top:-20%;left:-10%;background:radial-gradient(circle,rgba(59,130,246,.7),transparent 70%)}.play-select-orb.orb-b{bottom:-18%;right:-8%;background:radial-gradient(circle,rgba(236,72,153,.55),transparent 68%)}.play-select-grid{position:absolute;inset:14%;border-radius:14px;background:linear-gradient(90deg,rgba(148,163,184,.25) 1px,transparent 1px) 0 0 / 38px 38px,linear-gradient(0deg,rgba(148,163,184,.25) 1px,transparent 1px) 0 0 / 38px 38px;mix-blend-mode:screen;opacity:.9}.play-select-controls{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;justify-content:space-between}.play-select-search{display:flex;flex-direction:column;gap:6px}.search-field{display:flex;align-items:center;gap:var(--space-2);width:min(520px,100%);padding:10px 14px;border-radius:var(--radius-md);border:1px solid rgba(37,99,235,.18);background:var(--color-panel);box-shadow:0 16px 30px #0f172a14;color:var(--color-muted)}.search-field svg{color:var(--color-brand)}.search-field input{flex:1;border:none;background:transparent;font-size:15px;color:var(--color-text);outline:none}.search-clear{width:24px;height:24px;border-radius:999px;border:none;background:#0f172a14;color:var(--color-muted);cursor:pointer;display:grid;place-items:center;transition:background .2s ease,color .2s ease}.search-clear:hover{background:#2563eb2e;color:var(--color-brand)}.search-hint{font-size:12px;color:var(--color-muted)}.deck-grid-section{display:grid}.deck-grid{display:grid;gap:clamp(16px,3vw,24px);grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.deck-card{position:relative;display:flex;flex-direction:column;gap:var(--space-3);padding:clamp(20px,3vw,26px);border-radius:20px;border:none;background:transparent;cursor:pointer;color:#f8fafc;text-align:left;overflow:hidden;isolation:isolate;transition:transform .25s ease,box-shadow .25s ease}.deck-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,hsl(var(--deck-hue) 88% 64%),hsl(calc(var(--deck-hue) + 46) 82% 56%));transition:transform .3s ease,opacity .3s ease}.deck-card:after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at 70% 10%,rgba(255,255,255,.55),transparent 60%);opacity:.7;mix-blend-mode:screen;transition:opacity .3s ease}.deck-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px #0f172a3d}.deck-card:hover:before{transform:scale(1.03)}.deck-card:hover:after{opacity:.92}.deck-card.is-active{box-shadow:0 0 0 3px #3b82f699,0 18px 36px #0f172a38;transform:translateY(-4px)}.deck-card:focus-visible{outline:3px solid rgba(37,99,235,.9);outline-offset:3px}.deck-card.is-active:before{opacity:1}.deck-card.is-active:after{opacity:.95}.deck-card>*{position:relative;z-index:1}.deck-card-pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-pill);font-size:12px;letter-spacing:.08em;background:#0f172a52;text-transform:uppercase}.deck-card-title{margin:0;font-size:clamp(20px,2.6vw,24px);line-height:1.3}.deck-card-tags{display:flex;flex-wrap:wrap;gap:8px;min-height:28px}.deck-card-tag{padding:4px 10px;border-radius:var(--radius-pill);background:#ffffff47;font-size:13px;color:#f8fafc}.deck-card-tag.muted{background:#0f172a33}.deck-card-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.deck-card-count{font-size:14px;color:#f8fafceb}.deck-card-count strong{font-size:20px}.deck-card-cta{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:14px}.deck-card-cta svg{width:16px;height:16px}.deck-card-skeleton{height:clamp(200px,26vw,240px);border-radius:20px}.deck-empty{text-align:center;padding:clamp(32px,6vw,48px);border-radius:18px;border:1px dashed rgba(148,163,184,.5);background:#ffffffd1;display:grid;gap:var(--space-3);justify-items:center}.deck-empty h2{margin:0}.deck-empty p{margin:0;color:var(--color-muted)}.deck-empty .btn.ghost{border:1px solid rgba(37,99,235,.26);border-radius:var(--radius-pill)}.deck-empty .btn.ghost:hover{background:#2563eb14}@media (max-width: 960px){.play-select-page{padding:28px var(--space-3) 44px}.play-select-hero{grid-template-columns:1fr}.play-select-hero-art{order:-1;min-height:clamp(160px,40vw,220px)}.play-select-controls{gap:var(--space-3);align-items:flex-start}}@media (max-width: 520px){.play-select-page{padding:24px var(--space-2) 36px}.play-select-stats{gap:8px}.play-select-stat{padding:6px 10px;font-size:13px}.search-field{width:100%}.deck-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.deck-card{padding:18px}}.taglist{display:grid}.tagrow{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:10px 12px;border-top:1px dashed var(--color-border)}.tagrow:first-child{border-top:none}.tagrow:hover{background:#f9fafb}.tagname{color:var(--color-text);text-decoration:none;font-weight:600}.tagname:hover{text-decoration:underline}.tagname-input{padding:6px 8px;border:1px solid #d1d5db;border-radius:var(--radius-sm);min-width:220px}.row-actions{display:flex;gap:8px;justify-content:flex-end}.btn.ghost{border:none;background:transparent;color:var(--color-brand);padding:6px 8px}.btn.ghost:hover{background:#eff6ff}.btn.ghost.danger{color:#b91c1c}.settings-grid{display:grid;grid-template-columns:repeat(3,minmax(260px,1fr));grid-template-areas:"prev ftb next";column-gap:var(--space-4);row-gap:32px;align-items:stretch;margin-top:16px;margin-bottom:24px}.settings-grid+.card{margin-top:16px}.settings-prev{grid-area:prev}.settings-ftb{grid-area:ftb}.settings-next{grid-area:next}.settings-grid .btn{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;justify-content:center;align-items:center;min-height:36px}@media (max-width: 760px){.settings-grid{grid-template-columns:1fr;grid-template-areas:"prev" "ftb" "next"}}.toast{position:fixed;top:calc(var(--topbar-h) + 12px + env(safe-area-inset-top,0px));right:calc(12px + env(safe-area-inset-right,0px));display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid transparent;box-shadow:var(--shadow-md);z-index:var(--z-dropdown);font-weight:600;animation:toast-in .18s ease both}.toast-icon{width:18px;height:18px;display:grid;place-items:center}.toast-msg{line-height:1}.toast-close{margin-left:4px;padding:4px;border:none;background:transparent;color:inherit;border-radius:6px;cursor:pointer}.toast-close:hover{background:#0000000a}.toast-success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.toast-error{background:#fef2f2;border-color:#fecaca;color:#7f1d1d}.toast-info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}@keyframes toast-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.spin{animation:spin360 .9s linear infinite;display:inline-block}@keyframes spin360{to{transform:rotate(360deg)}}.skeleton{background:#e5e7eb;border-radius:var(--radius-sm)}.skeleton.shimmer{position:relative;overflow:hidden}.skeleton.shimmer:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);transform:translate(-100%);animation:shimmer 1.2s linear infinite}@keyframes shimmer{to{transform:translate(100%)}}@media (prefers-reduced-motion: reduce){.skeleton.shimmer:after{animation:none}}
