:root{--bg: #0a0a0f;--bg-card: #12121a;--bg-elevated: #1a1a26;--border: #2a2a3a;--text: #f0f0f5;--text-muted: #8888a0;--accent: #a855f7;--accent-hover: #9333ea;--success: #22c55e;--warning: #f59e0b;--radius: 12px;--font: "Segoe UI", "Hiragino Sans", "Noto Sans JP", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;line-height:1.5}#root{min-height:100dvh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:640px;margin:0 auto}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.25rem}.logo-icon{font-size:1.5rem}.back-link{color:var(--text-muted);font-size:.875rem}.back-link:hover{color:var(--text)}.main{flex:1;padding:1.25rem}.footer{padding:1rem;text-align:center;color:var(--text-muted);font-size:.75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem;align-items:center}.footer-stats{opacity:.85;font-variant-numeric:tabular-nums}.page{display:flex;flex-direction:column;gap:1.5rem}.page-title{font-size:1.5rem;font-weight:700}.page-desc{color:var(--text-muted);font-size:.9375rem}.hero{text-align:center;padding:1rem 0 .5rem}.hero-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent),#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{color:var(--text-muted);margin-top:.5rem;font-size:.9375rem;line-height:1.6;white-space:pre-line}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.label{font-size:.8125rem;color:var(--text-muted);font-weight:500}.input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;color:var(--text);font-size:1rem;width:100%}.input:focus{outline:2px solid var(--accent);outline-offset:-1px}.input-row{display:flex;gap:.5rem}.input-row .input{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.75rem 1.25rem;border-radius:8px;font-size:.9375rem;font-weight:600;transition:background .15s,transform .1s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-large{width:100%;padding:1rem;font-size:1rem}.btn-play{background:var(--accent);color:#fff;padding:.625rem 1.5rem;border-radius:999px;font-size:1rem}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.mode-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1rem;display:flex;flex-direction:column;gap:.375rem;transition:border-color .15s,transform .1s}.mode-card:hover{border-color:var(--accent);transform:translateY(-2px)}.mode-card:nth-child(5){grid-column:1 / -1}.mode-icon{font-size:1.75rem}.mode-card h2{font-size:1rem;font-weight:700}.mode-card p{font-size:.8125rem;color:var(--text-muted)}.section{display:flex;flex-direction:column;gap:.75rem}.section-title{font-size:1rem;font-weight:600;color:var(--text-muted)}.song-list{display:flex;flex-direction:column;gap:.5rem}.song-list-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;transition:border-color .15s}.song-list-item:hover{border-color:var(--accent)}.song-list-info{display:flex;flex-direction:column;gap:.25rem}.song-list-title{font-weight:600}.song-list-meta{font-size:.8125rem;color:var(--text-muted)}.badge{font-size:.6875rem;font-weight:700;padding:.25rem .625rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.badge--open{background:#a855f733;color:var(--accent)}.badge--complete{background:#22c55e33;color:var(--success)}.badge--daily{background:#f59e0b33;color:var(--warning)}.badge--virtual{background:#8888a033;color:var(--text-muted)}.badge--continue{background:#f243;color:#f68}.link-more{color:var(--accent);font-size:.875rem;text-align:center}.bpm-control{display:flex;align-items:center;gap:1rem}.bpm-control input[type=range]{flex:1;accent-color:var(--accent)}.bpm-value{font-size:1.5rem;font-weight:700;min-width:3rem;text-align:center}.loop-picker{display:flex;flex-direction:column;gap:1.25rem}.loop-picker-guide{font-size:.9375rem;color:var(--warning);background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:.75rem 1rem;margin:0}.loop-picker-empty{text-align:center;padding:2rem;color:var(--text-muted)}.loop-category-title{font-size:.8125rem;color:var(--text-muted);margin-bottom:.5rem;font-weight:600}.loop-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem}.loop-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.375rem;min-height:5rem;padding:.875rem .5rem;background:var(--bg-card);border:3px solid var(--border);border-radius:var(--radius);position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:border-color .15s,background .15s,transform .1s}.loop-card-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.loop-card:active:not(.loop-card--disabled){transform:scale(.96)}.loop-card:hover:not(.loop-card--disabled){border-color:var(--loop-color, var(--accent));background:var(--bg-elevated)}.loop-card--selected{border-color:var(--accent);background:#a855f726;box-shadow:0 0 0 2px #a855f74d}.loop-card--disabled{opacity:.3;cursor:not-allowed}.loop-card-icon{font-size:2rem;line-height:1}.loop-card-name{font-size:.8125rem;font-weight:600;text-align:center;line-height:1.3}.loop-card-check{position:absolute;top:6px;right:8px;font-size:1rem;color:var(--accent);font-weight:800}.transport{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.transport-hint{width:100%;font-size:.8125rem;color:var(--warning);margin:0}.transport-bpm,.transport-layers{font-size:.8125rem;color:var(--text-muted)}.layer-stack{display:flex;flex-direction:column;gap:.5rem}.layer-slot{display:flex;align-items:center;gap:.75rem;background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--layer-color, var(--accent));border-radius:var(--radius);padding:.875rem 1rem}.layer-slot--empty{border-left-color:var(--border);opacity:.7;text-align:left;width:100%}.layer-slot--next{border-left-color:var(--accent);border-style:dashed;opacity:1;background:#a855f714;cursor:pointer}.layer-slot--next:hover{background:#a855f726}.layer-slot--empty:disabled{cursor:default}.layer-slot--virtual{border-style:dashed}.layer-index{font-size:.75rem;font-weight:700;color:var(--text-muted);min-width:1.25rem}.layer-icon{font-size:1.25rem}.layer-icon--label{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;height:1.75rem;padding:0 .35rem;border-radius:6px;font-size:.625rem;font-weight:800;color:#fff;letter-spacing:.02em}.layer-info{flex:1;min-width:0}.layer-delete-btn{flex-shrink:0;width:2rem;height:2rem;border:1px solid var(--border);border-radius:8px;background:#ef44441f;color:#f87171;font-size:1.125rem;line-height:1;cursor:pointer;transition:background .15s,border-color .15s}.layer-delete-btn:hover{background:#ef444438;border-color:#f87171}.editor-toolbar{background:#16162a;border:2px solid rgba(168,85,247,.35);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.editor-toolbar-label{font-weight:700;font-size:.875rem;margin:0 0 .75rem}.editor-target-hint{margin:.75rem 0 0;padding:.5rem .75rem;border-radius:8px;background:#38bdf81f;border:1px solid rgba(56,189,248,.35);color:#7dd3fc;font-size:.8125rem;font-weight:700}.editor-extend-hint{margin-top:.5rem;color:#fbbf24}.editor-pads-section{background:#12121a;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.editor-mode-locked{font-size:.8125rem;color:var(--accent);margin:.5rem 0 0;font-weight:600}.editor-bpm-inline{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.editor-bpm-inline .bpm-control{margin-top:.375rem}.editor-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.editor-publish-bar{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;background:#4ade8014;border:1px solid rgba(74,222,128,.3);border-radius:var(--radius)}.section-target-picker{margin-top:.75rem}.section-target-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.375rem}.section-target-btn{padding:.5rem .75rem;border:2px solid #4a4a6a;border-radius:8px;background:#1e1e32;color:#f4f4f8;font-size:.75rem;font-weight:700;cursor:pointer}.section-target-btn--active{border-color:#38bdf8;background:#38bdf82e}.section-target-btn:disabled{opacity:.7;cursor:default}.editor-pick-mode-hint{text-align:center;margin-top:.5rem}text-align: center; margin-top: .5rem; } .add-mode-picker--compact .add-mode-grid{gap:.5rem}.add-mode-picker--compact .add-mode-card{padding:.875rem .5rem}.add-mode-picker--compact .add-mode-desc{display:block;font-size:.6875rem;font-weight:600;color:#a5b4fc}.layer-name{font-weight:600;font-size:.9375rem}.layer-meta{font-size:.75rem;color:var(--text-muted)}.layer-empty-text{font-size:.875rem;color:var(--text-muted)}.collab-list{display:flex;flex-direction:column;gap:.75rem}.collab-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color .15s}.collab-card:hover{border-color:var(--accent)}.collab-card-header{display:flex;align-items:center;gap:.75rem}.collab-icon{font-size:2rem}.collab-icon--label{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:10px;font-size:.75rem;font-weight:800;color:#fff;flex-shrink:0}.collab-card-header h3{font-size:1rem}.collab-card-header p{font-size:.8125rem;color:var(--text-muted)}.collab-layers{display:flex;gap:.375rem}.collab-layer-chip{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:8px;font-size:1rem}.collab-layer-chip--empty{border:1px dashed var(--border);color:var(--text-muted);font-size:.875rem}.collab-cta{color:var(--accent);font-size:.875rem;font-weight:600}.collab-card-actions{display:flex;gap:1rem;flex-wrap:wrap}.collab-cta--muted{color:var(--text-muted);font-weight:500}.empty-state{text-align:center;padding:3rem 1rem;display:flex;flex-direction:column;gap:1rem;align-items:center;color:var(--text-muted)}.selected-preview{display:flex;align-items:center;gap:.75rem;background:var(--bg-elevated);border-radius:var(--radius);padding:1rem;font-weight:600;font-size:1rem}.selected-preview--active{background:#a855f726;border:2px solid var(--accent)}.selected-preview-icon{font-size:1.75rem}.selected-preview-hint{color:var(--text-muted);font-size:.9375rem;margin:0 0 .75rem}.add-confirm{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.message-box{border-radius:var(--radius);padding:.875rem 1rem;font-size:1rem;font-weight:600}.message-box--ok{background:#22c55e26;border:2px solid var(--success);color:#86efac}.message-box--warn{background:#f59e0b26;border:2px solid var(--warning);color:#fcd34d}.song-editor{display:flex;flex-direction:column;gap:1.5rem}.continue-section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.continue-progress{font-size:.8125rem;color:var(--text-muted);font-weight:600}.continue-progress-play{color:var(--accent);font-weight:500}.continue-banner{background:linear-gradient(135deg,#ff22441f,#a855f71f);border:1px dashed var(--accent);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.continue-banner-title{font-weight:700;font-size:1rem}.continue-banner-desc{font-size:.875rem;color:var(--text-muted)}.btn-sm{align-self:flex-start;padding:.5rem .875rem;font-size:.8125rem}.inline-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.song-list-item--continue{border-color:#ff224440}.hint--compact{text-align:left;margin-bottom:1rem}.alert-box{background:#ef444426;border:1px solid rgba(239,68,68,.4);color:#fca5a5;border-radius:var(--radius);padding:.875rem 1rem;font-size:.9375rem}.song-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.song-badges{display:flex;gap:.375rem}.song-actions{display:flex;flex-wrap:wrap;gap:.5rem}.share-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.share-code{display:flex;flex-direction:column;gap:.25rem}.share-label{font-size:.75rem;color:var(--text-muted)}.share-value{font-size:1.5rem;font-weight:800;letter-spacing:.15em;color:var(--accent)}.share-actions{display:flex;gap:.5rem}.share-actions .btn{flex:1}.hint{font-size:.8125rem;color:var(--text-muted);text-align:center}@media(max-width:400px){.loop-grid{grid-template-columns:repeat(2,1fr)}.mode-grid{grid-template-columns:1fr}.mode-card:nth-child(5){grid-column:auto}}.drum-pad-machine{display:flex;flex-direction:column;gap:.75rem}.pad-guide{font-size:.875rem;color:var(--text-muted);margin:0;text-align:center}.pad-empty{text-align:center;color:var(--text-muted);padding:2rem}.pad-grid{display:grid;gap:.625rem}.drum-pad{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;min-height:5.5rem;padding:.75rem .5rem;border:none;border-radius:14px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:linear-gradient(145deg,var(--pad-color),var(--pad-dark));box-shadow:0 4px 0 var(--pad-dark),0 6px 12px #0006,inset 0 1px #ffffff40;transition:transform .08s,box-shadow .08s,filter .08s}.drum-pad:active,.drum-pad--lit{transform:translateY(3px);box-shadow:0 1px 0 var(--pad-dark),0 2px 6px #0000004d,inset 0 2px 6px #0000004d;filter:brightness(1.2)}.drum-pad--selected{outline:3px solid white;outline-offset:2px}.drum-pad--active{filter:brightness(1.15)}.drum-pad-label{font-size:1rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);letter-spacing:.05em}.drum-pad-name{font-size:.6875rem;color:#ffffffd9;font-weight:600}.drum-pad-check{position:absolute;top:6px;right:8px;font-size:.875rem;color:#fff;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.5)}.drum-pad-badge{position:absolute;top:6px;left:8px;font-size:.5625rem;font-weight:800;background:#0006;color:#4ade80;padding:.125rem .375rem;border-radius:4px}.btn-add-pad{margin-top:1rem}.pad-sequencer{background:#0d0d14;border:1px solid var(--border);border-radius:var(--radius);padding:.875rem;overflow-x:auto}.seq-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.seq-hint{font-size:.75rem;color:var(--accent);margin:0;font-weight:600}.seq-steps-label-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.seq-label{font-size:.625rem;font-weight:800;color:var(--text-muted);letter-spacing:.1em;min-width:3.5rem}.seq-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.25rem}.seq-steps-label{display:flex;gap:3px;flex:1;min-width:min-content}.seq-num{flex:0 0 14px;width:14px;text-align:center;font-size:.5625rem;color:var(--text-muted)}.seq-num--bar{border-left:1px solid var(--border);padding-left:2px;margin-left:1px;color:var(--accent);font-weight:700;font-size:.5rem}.seq-num--now{color:var(--accent);font-weight:800}.seq-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem}.seq-pad-name{font-size:.625rem;font-weight:800;min-width:3.5rem;letter-spacing:.05em}.seq-steps{display:flex;gap:3px;flex:1;min-width:min-content}.seq-step--bar{border-left:1px solid rgba(168,85,247,.45);margin-left:1px}.seq-step{flex:0 0 14px;width:14px;height:22px;border-radius:3px;background:#1a1a26;border:1px solid #2a2a3a;transition:background .05s,transform .05s;cursor:pointer;padding:0}.seq-step:active{transform:scale(.9)}.seq-step--on{opacity:.85}.seq-step--now{box-shadow:0 0 0 2px #fff;transform:scaleY(1.2)}.active-pads{display:flex;flex-direction:column;gap:.5rem}.active-pads-label{font-size:.6875rem;font-weight:800;color:var(--text-muted);letter-spacing:.08em}.active-pads-row{display:flex;flex-wrap:wrap;gap:.375rem}.active-pad-chip{font-size:.6875rem;font-weight:800;color:#fff;padding:.375rem .625rem;border-radius:6px;letter-spacing:.05em;text-shadow:0 1px 2px rgba(0,0,0,.4)}.active-pad-chip--empty{background:transparent;border:2px dashed var(--accent);color:var(--accent);cursor:pointer}.section-title--long{margin-top:1.25rem;color:#b8f}.section-subtitle{font-size:.9375rem;font-weight:700;margin:1rem 0 .5rem;color:var(--text-muted)}.pad-group+.pad-group{margin-top:.75rem}.pad-long-hint{font-size:.8125rem;color:var(--accent);margin:-.25rem 0 .75rem;font-weight:600}.drum-pad--long{box-shadow:0 4px 0 var(--pad-dark),0 6px 12px #0006,inset 0 1px #ffffff40,0 0 12px #bb88ff4d}.header-nav{display:flex;align-items:center;gap:.75rem}.lang-switcher{display:flex;align-items:center;gap:.35rem}.lang-switcher-label{font-size:.6875rem;opacity:.65}.lang-switcher-select{font-size:.75rem;padding:.2rem .35rem;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#00000059;color:inherit}.hero-subtitle{white-space:pre-line}.header-link{font-size:.8125rem;font-weight:600;color:var(--text-muted)}.header-link--active{color:var(--accent)}.header-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a;transition:color .15s,border-color .15s,background .15s}.header-icon-btn-svg{width:1.125rem;height:1.125rem}.header-icon-btn:hover{color:var(--text);border-color:#ffffff40}.header-icon-btn--active{color:var(--accent);border-color:var(--accent);background:#bb88ff1f}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--border);flex-shrink:0}.avatar--sm{width:1.75rem;height:1.75rem;font-size:.875rem}.avatar--md{width:2.25rem;height:2.25rem;font-size:1.125rem}.avatar--lg{width:2.75rem;height:2.75rem;font-size:1.375rem}.profile-card .label--sub{margin-top:.5rem}.avatar-picker{display:flex;flex-wrap:wrap;gap:.375rem}.avatar-picker-btn{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--border);font-size:1.125rem;transition:border-color .15s,transform .1s}.avatar-picker-btn--active{border-color:var(--accent);transform:scale(1.08)}.profile-preview{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9375rem}.profile-preview--locked{margin-bottom:.75rem}.profile-locked-name{font-size:1.0625rem}.mode-card--timeline{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.375rem;background:linear-gradient(135deg,#22c55e1f,#a855f71f);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:.5rem;transition:border-color .15s}.mode-card--timeline:hover{border-color:var(--success)}.alert-box--info{background:#3b82f61f;border-color:#3b82f659;color:#93c5fd}.song-continue-cta{text-align:center}.collab-layer-chip-wrap{display:flex;flex-direction:column;align-items:center;gap:.125rem}.feed-list{display:flex;flex-direction:column;gap:1.25rem}.feed-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.feed-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.feed-card-title-row{display:flex;gap:.75rem;align-items:center}.feed-card-title{font-size:1.125rem;font-weight:700}.feed-card-meta{font-size:.8125rem;color:var(--text-muted)}.feed-card-time{font-size:.75rem;color:var(--text-muted);flex-shrink:0}.feed-contributors{display:flex;flex-direction:column;gap:.375rem}.feed-card-credits{font-size:.875rem;color:var(--text);margin-top:.35rem;line-height:1.5}.song-credits{font-size:.9375rem;color:var(--text-muted);margin-top:-.75rem}.publish-card{display:flex;flex-direction:column;gap:.75rem}.profile-card--simple{gap:.75rem}.profile-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.my-profile-name{font-size:1.125rem;font-weight:700}.my-song-list{display:flex;flex-direction:column;gap:1rem}.my-song-card{display:flex;flex-direction:column;gap:.75rem}.my-song-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.my-song-title{font-size:1.0625rem;font-weight:700}.my-song-meta,.my-song-credits{font-size:.8125rem;color:var(--text-muted)}.my-song-credits{margin-top:.25rem;color:var(--text)}.feed-contributor{display:flex;align-items:center;gap:.5rem;font-size:.8125rem}.feed-contributor-part{font-weight:700;color:var(--accent);min-width:3rem}.feed-contributor-pad{font-weight:800;font-size:.6875rem}.feed-contributor-name{color:var(--text-muted)}.feed-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.reaction-bar{display:flex;flex-direction:column;gap:.625rem;padding:.75rem;background:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border)}.reaction-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-card);border:2px solid var(--border);border-radius:999px;color:var(--text);font-weight:700;font-size:1rem;transition:border-color .15s,background .15s,transform .1s;align-self:flex-start}.reaction-btn:hover:not(:disabled){border-color:#f43f5e;transform:scale(1.02)}.reaction-btn--active{border-color:#f43f5e;background:#f43f5e26;box-shadow:0 0 12px #f43f5e40}.reaction-btn:disabled{opacity:.5;cursor:not-allowed}.reaction-btn-icon{font-size:1.25rem;line-height:1}.reaction-btn-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.75rem;height:1.75rem;padding:0 .375rem;background:#f43f5e;color:#fff;border-radius:999px;font-size:.9375rem;font-weight:800}.reaction-btn--active .reaction-btn-count{background:#fb7185}.reaction-hint{font-size:.8125rem;color:var(--text-muted);margin:0}.reaction-faces{display:flex;flex-direction:column;gap:.5rem}.reaction-faces-label{font-size:.8125rem;font-weight:700;color:#fb7185}.reaction-avatar-row{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center}.reaction-more{font-size:.75rem;font-weight:700;color:var(--text-muted);padding:.25rem .5rem;background:var(--bg-card);border-radius:999px}.reaction-name-list{list-style:none;display:flex;flex-wrap:wrap;gap:.375rem .75rem;max-height:120px;overflow-y:auto}.reaction-name-list li{display:flex;align-items:center;gap:.25rem;font-size:.8125rem}.reaction-name-emoji{font-size:1rem;line-height:1}.reaction-name-text{color:var(--text-muted)}.comment-thread{border-top:1px solid var(--border);padding-top:1rem;display:flex;flex-direction:column;gap:.75rem}.comment-thread-title{font-size:.9375rem;font-weight:700}.comment-list{list-style:none;display:flex;flex-direction:column;gap:.75rem;max-height:240px;overflow-y:auto}.comment-item{display:flex;gap:.625rem;align-items:flex-start}.comment-body{flex:1;min-width:0}.comment-author{font-size:.75rem;font-weight:700;color:var(--accent)}.comment-text{font-size:.875rem;margin-top:.125rem;word-break:break-word}.comment-empty{font-size:.875rem;color:var(--text-muted)}.comment-form{display:flex;gap:.5rem;align-items:center}.comment-input{flex:1;min-width:0}.add-mode-picker{margin-bottom:.5rem}.add-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.add-mode-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.375rem;padding:1rem .75rem;background:#1e1e32;border:2px solid #4a4a6a;border-radius:var(--radius);color:#f4f4f8;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.add-mode-card:hover:not(:disabled){border-color:#8b8bb8;background:#252540}.add-mode-card:disabled{opacity:.45;cursor:not-allowed}.add-mode-card--layer.add-mode-card--active{border-color:#38bdf8;background:#38bdf82e;box-shadow:0 0 0 1px #38bdf8,0 4px 16px #38bdf833}.add-mode-card--extend.add-mode-card--active{border-color:#4ade80;background:#4ade8026;box-shadow:0 0 0 1px #4ade80,0 4px 16px #4ade802e}.add-mode-card--active .add-mode-title{color:#fff}.add-mode-card--active .add-mode-desc{color:#d4d4e8}.add-mode-icon{font-size:1.5rem}.add-mode-title{font-weight:700;font-size:.8125rem}.add-mode-desc{font-size:.75rem;color:var(--text-muted);line-height:1.4}.layer-section-group{margin-bottom:.75rem}.layer-section-title{font-size:.75rem;font-weight:700;color:var(--accent);margin-bottom:.375rem;letter-spacing:.05em}.seq-section{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.seq-section--active{background:#a855f70f;border-radius:var(--radius);padding:.5rem;margin-left:-.5rem;margin-right:-.5rem}.seq-section-label{font-size:.6875rem;font-weight:700;color:var(--text-muted);margin-bottom:.375rem}.seq-section-bars{color:var(--accent);font-weight:600}.footer-nav{display:flex;flex-wrap:wrap;gap:.75rem 1rem;justify-content:center;margin-bottom:.5rem}.footer-nav a{color:var(--text-muted);font-size:.75rem;text-decoration:none}.footer-nav a:hover{color:var(--accent)}.pro-pricing-card{text-align:center}.pro-billing-form{text-align:left;margin:1rem 0;padding:1rem;border:1px solid var(--border);border-radius:var(--radius);background:#ffffff05;display:flex;flex-direction:column;gap:.375rem}.pro-billing-form .input{margin-bottom:.5rem}.pro-price{margin-bottom:1rem}.pro-price-amount{font-size:2.5rem;font-weight:800;color:var(--accent)}.pro-price-period{display:block;font-size:.875rem;color:var(--text-muted)}.pro-features{text-align:left;margin:0 0 1rem;padding-left:1.25rem;line-height:1.7}.legal-content section+section{margin-top:1.25rem}.legal-content h2{font-size:1rem;margin-bottom:.5rem}.legal-content p{font-size:.875rem;line-height:1.7;color:var(--text-muted)}.legal-list{margin:0 0 1rem;padding-left:1.25rem;line-height:1.7;font-size:.875rem}.legal-links-inline{display:flex;flex-wrap:wrap;gap:.75rem 1rem;margin-bottom:.75rem}.legal-links-inline a{color:var(--accent);font-size:.8125rem}.tokushoho-table{width:100%;border-collapse:collapse;font-size:.875rem}.tokushoho-table th,.tokushoho-table td{border:1px solid var(--border);padding:.625rem .75rem;vertical-align:top;text-align:left}.tokushoho-table th{width:38%;background:#ffffff08;color:var(--text-muted);font-weight:600}.legal-updated{font-size:.8125rem}
