:root{--background:#fff7fb;--card:#fff;--card-soft:#fff1f7;--text:#392d34;--muted:#7f6e78;--primary:#ff7daf;--primary-dark:#d94f86;--accent:#8fd7d2;--border:#f1dbe5;--shadow:0 18px 45px #9d517424}*{box-sizing:border-box}html,body{min-height:100%}body{color:var(--text);background:radial-gradient(circle at 0 0,#ffc4db8c,#0000 34rem),linear-gradient(#fff7fb 0%,#f3fbfa 100%);margin:0;font-family:Hiragino Sans,Yu Gothic UI,Yu Gothic,Meiryo,system-ui,sans-serif}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}.app-shell{flex-direction:column;width:100%;min-width:0;max-width:720px;min-height:100dvh;margin:0 auto;display:flex}.top-bar{z-index:5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);padding:18px 18px 10px;position:sticky;top:0}.brand-row{align-items:center;gap:8px;display:inline-flex}.brand{align-items:center;gap:10px;display:inline-flex}.brand-mark{object-fit:cover;width:38px;height:38px;box-shadow:var(--shadow);border-radius:14px}.brand small{color:var(--muted);font-size:.74rem;display:block}.welcome-help-button{background:var(--card-soft);width:28px;height:28px;color:var(--primary-dark);box-shadow:inset 0 0 0 1px var(--border);border:0;border-radius:999px;justify-content:center;align-items:center;font-size:.92rem;font-weight:900;display:inline-flex}.welcome-help-button:hover,.welcome-help-button:focus-visible{box-shadow:inset 0 0 0 1px var(--primary), 0 0 0 4px #ff7daf24;outline:none}.welcome-help-backdrop{z-index:50;background:#392d3457;place-items:center;padding:14px;display:grid;position:fixed;inset:0}.welcome-help-dialog{width:min(100%,640px);height:min(86dvh,720px);min-height:0;box-shadow:var(--shadow);background:#fffffff5;border:1px solid #ffffffc7;border-radius:28px;grid-template-rows:auto minmax(0,1fr);display:grid;overflow:hidden}.welcome-help-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.welcome-help-header h2{min-width:0;margin:0;font-size:1.05rem}.welcome-help-close-button{background:var(--primary-dark);color:#fff;border:0;border-radius:999px;flex:none;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.35rem;font-weight:900;line-height:1;display:inline-flex;box-shadow:0 8px 18px #d94f863d}.welcome-help-close-button:hover,.welcome-help-close-button:focus-visible{background:var(--primary);outline:none}.welcome-help-content{overscroll-behavior:contain;white-space:pre-wrap;min-height:0;color:var(--text);-webkit-overflow-scrolling:touch;padding:18px 18px 28px;line-height:1.75;overflow:auto}.confirm-backdrop{z-index:60;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#392d3457;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.confirm-dialog{width:min(100%,420px);box-shadow:var(--shadow);background:radial-gradient(circle at 0 0,#ffc4db61,#0000 14rem),#fffffff5;border:1px solid #ffffffc7;border-radius:28px;gap:18px;padding:20px;display:grid}.confirm-dialog-header{gap:8px;display:grid}.confirm-dialog-header h2,.confirm-dialog-header p{margin:0}.confirm-dialog-header h2{font-size:1.15rem;line-height:1.35}.confirm-dialog-actions{justify-content:flex-end;gap:10px;display:flex}.page{flex:1;min-width:0;padding:8px 16px 96px}.bottom-nav{z-index:10;width:min(92vw,680px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffdb;border:1px solid #ffffffc7;border-radius:999px;grid-template-columns:repeat(4,1fr);gap:8px;padding:8px;display:grid;position:fixed;bottom:14px;right:50%;transform:translate(50%)}.bottom-nav a{color:var(--muted);text-align:center;border-radius:999px;padding:10px 6px;font-size:.86rem;font-weight:700}.bottom-nav a:hover{background:var(--card-soft);color:var(--primary-dark)}.hero,.card,.panel{box-shadow:var(--shadow);background:#ffffffd1;border:1px solid #ffffffc7;border-radius:28px}.hero{padding:24px}.hero h1,.section-title{margin:0;line-height:1.25}.hero p,.muted{color:var(--muted);line-height:1.8}.grid,.grid-two{gap:14px;display:grid}.card,.panel{padding:18px}.loading-notice{color:var(--text);background:#fff1f7eb;border:1px solid #ff7daf38;border-radius:20px;align-items:center;gap:12px;padding:14px 16px;display:flex}.loading-notice p{color:var(--muted);margin:4px 0 0;line-height:1.6}.loading-spinner{border:3px solid #ff7daf3d;border-top-color:var(--primary-dark);border-radius:999px;flex:none;width:22px;height:22px;animation:.9s linear infinite loading-spin}@keyframes loading-spin{to{transform:rotate(360deg)}}.toolbar{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.card-header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.home-section-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.home-series-button{width:44px;height:44px;font-size:1.45rem}.home-series-button[aria-expanded=true]{background:var(--primary-dark);color:#fff}.compact-title,.compact-copy{margin:0}.compact-copy{margin-top:6px}.series-play-list{gap:8px;display:grid}.series-play-option{border:1px solid var(--border);text-align:left;background:#fff7fbb8;border-radius:18px;align-items:center;gap:10px;width:100%;padding:12px;display:flex}.series-play-option input{flex:none}.series-play-option span{gap:3px;display:grid}.series-play-option small{color:var(--muted)}.saved-series,.series-file{gap:10px;display:grid}.series-file-card{background:linear-gradient(135deg, #fff, var(--card-soft));width:100%;color:var(--text);text-align:left;box-shadow:var(--shadow);border:1px solid #ffffffc7;border-radius:24px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:16px;display:grid}.series-file-card:hover,.series-file-card:focus-visible{box-shadow:var(--shadow), 0 0 0 4px #ff7daf24;outline:none}.series-file-card[aria-expanded=true]{border-color:#ff7daf6b}.series-file-icon{background:var(--primary);color:#fff;border-radius:14px;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.25rem;font-weight:900;display:inline-flex}.series-file-copy{gap:4px;min-width:0;display:grid}.series-file-copy strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.series-file-copy small,.series-file-chevron{color:var(--muted);font-weight:800}.series-file-content{padding-left:10px}.saved-series-header{justify-content:space-between;align-items:center;gap:10px;padding:0 4px;display:flex}.saved-series-header h3{margin:0;font-size:1rem}.saved-series-header span{color:var(--muted);font-size:.82rem;font-weight:800}.card-actions{justify-content:flex-end;align-items:center;gap:6px;display:inline-flex}.character-card-header{align-items:center}.character-card-controls{flex:none;justify-items:end;gap:6px;display:grid}.character-reorder-actions{padding-right:2px}.character-title,.character-name-row{align-items:center;gap:10px;display:flex}.character-title{flex:1;gap:12px;min-width:0}.character-name-pill{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;padding:8px 12px;font-size:.92rem;overflow:hidden}.character-name-field{flex:1}.character-icon-field{width:68px}.character-icon-picker,.character-avatar{background:var(--card-soft);color:var(--primary-dark);border-radius:999px;justify-content:center;align-items:center;font-weight:900;display:inline-flex;overflow:hidden}.character-icon-picker{cursor:pointer;width:56px;height:56px;box-shadow:inset 0 0 0 1px var(--border);border:0;font-size:1.35rem}.character-icon-picker:hover{border-color:var(--primary);box-shadow:0 0 0 4px #ff7daf1f}.character-avatar{flex:none;width:44px;height:44px;font-size:1.1rem}.character-description{white-space:pre-wrap}.character-icon-picker img,.character-avatar img{object-fit:cover;width:100%;height:100%}.button,.button-secondary,.button-ghost{border:0;border-radius:999px;justify-content:center;align-items:center;min-height:44px;padding:0 18px;font-weight:800;display:inline-flex}.button{background:linear-gradient(135deg, var(--primary), #ffacd0);color:#fff;box-shadow:0 12px 26px #ff7daf42}.button-danger{background:linear-gradient(135deg,#e25566,#ff8f9c);box-shadow:0 12px 26px #e255663d}.button:disabled,.button-secondary:disabled{cursor:not-allowed;filter:grayscale(.5);opacity:.6}.button-secondary{color:#287d76;background:#eaf8f6}.button-ghost{background:var(--card-soft);color:var(--primary-dark)}.button-small{min-height:30px;padding:0 10px;font-size:.78rem}.icon-button{background:var(--card-soft);min-width:32px;height:32px;color:var(--primary-dark);border:0;border-radius:999px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:900;display:inline-flex}.card-actions .icon-button{min-width:auto;padding:0 10px;font-size:.78rem}.saved-play-header{display:flow-root}.saved-play-header-actions{float:right;flex:none;gap:6px;margin-top:-6px;margin-bottom:6px;margin-left:12px;display:inline-flex}.saved-play-details{gap:8px;min-width:0;display:grid}.saved-play-title-link{min-width:0;display:block}.saved-play-title-link h3{margin-top:8px}.saved-play-title-link h3,.saved-play-details p{margin:0}.icon-button:disabled{cursor:not-allowed;opacity:.5}.icon-button-danger{color:#a33b3b;background:#fff4f4}.field{gap:7px;display:grid}.field label{color:var(--muted);font-size:.86rem;font-weight:800}.field .character-icon-picker{color:var(--primary-dark);font-size:1.35rem}.field-label{color:var(--muted);font-size:.86rem;font-weight:800}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.input,.textarea,.select{border:1px solid var(--border);width:100%;color:var(--text);background:#ffffffe6;border-radius:18px;outline:none;padding:13px 14px}.textarea{resize:vertical;min-height:92px}.textarea-large{min-height:250px}.input:focus,.textarea:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #ff7daf24}.status-pill{background:var(--card-soft);color:var(--primary-dark);border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:800;display:inline-flex}.error{color:#a33b3b;background:#fff4f4;border:1px solid #ffd1d1;border-radius:18px;padding:12px 14px;line-height:1.6}.success{color:#287d76;background:#f0fffc;border:1px solid #c7eee8;border-radius:18px;padding:12px 14px;line-height:1.6}.form-mode{margin:0}.chat-list{gap:12px;display:grid}.bubble{background:var(--card);border-radius:24px;padding:13px 15px;box-shadow:0 10px 28px #9d51741a}.bubble:nth-child(4n+1){background:#fff}.bubble:nth-child(4n+2){background:#fff3f8}.bubble:nth-child(4n+3){background:#eefafa}.bubble:nth-child(4n){background:#fff9e8}.bubble-header{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;font-size:.8rem;font-weight:800;display:flex}.bubble p{margin:8px 0 0;line-height:1.65}.cast-card{border:1px solid var(--border);background:#ffffffad;border-radius:22px;gap:12px;padding:14px;display:grid}.color-picker-grid{flex-wrap:wrap;gap:8px;display:flex}.color-swatch{border:2px solid #fffffff2;border-radius:999px;width:34px;height:34px;box-shadow:inset 0 0 0 1px #392d3414,0 6px 14px #9d51741f}.color-swatch:disabled{cursor:not-allowed;opacity:.42}.color-swatch-selected{border-color:var(--primary-dark);box-shadow:0 0 0 3px #ff7daf38,0 8px 18px #9d517429}.chat-page-shell{width:100%;min-width:0;min-height:calc(100dvh - 178px)}.line-chat{width:100%;min-width:0;min-height:calc(100dvh - 178px);box-shadow:var(--shadow);background:#f7c7d7;border-radius:28px;display:grid;overflow:hidden}.line-chat-header{color:#fff;background:#efabc0;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;min-width:0;padding:16px 16px 12px;display:grid}.line-chat-title-row{overscroll-behavior-x:contain;scrollbar-width:thin;-webkit-overflow-scrolling:touch;align-items:center;gap:10px;width:100%;min-width:0;padding-bottom:2px;display:flex;overflow-x:auto}.line-chat-title-copy{width:max-content;max-width:none}.line-chat-title-row strong,.line-chat-title-row small{display:block}.line-chat-title-row strong{white-space:nowrap}.line-chat-title-row small{opacity:.85;font-size:.74rem}.line-chat-icons{gap:14px;font-size:1.45rem;font-weight:800;display:inline-flex}.line-menu-button{color:#fff;background:#ffffff3d;border:0;border-radius:999px;flex:0 0 44px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.45rem;font-weight:900;display:inline-flex}.line-menu-button[aria-expanded=true]{background:#ffffff6b}.line-chat-body{background:linear-gradient(#fff3,#fff7fbb8),radial-gradient(circle at 50% 20%,#ffffffe6,#0000 16rem),#eef4f5;flex-direction:column;align-items:center;gap:10px;min-height:440px;padding:18px 12px 96px;display:flex}.line-chat-details{background:#ffffffe0;border:1px solid #ffffffc7;border-radius:22px;gap:14px;width:100%;padding:14px;display:grid;box-shadow:0 10px 26px #392d341a}.line-detail-section{gap:8px;display:grid}.line-detail-section h3,.line-detail-section p{margin:0}.line-detail-section h3{font-size:.92rem}.line-detail-section p{color:var(--muted);line-height:1.65}.line-cast-list,.line-script-list{gap:10px;display:grid}.line-cast-card{border:1px solid var(--border);background:#fff7fbc7;border-radius:18px;gap:10px;padding:12px;display:grid}.line-cast-card strong{margin-bottom:4px;display:block}.line-script-list{margin:0;padding-left:20px}.line-script-list li{line-height:1.55}.line-script-list span{color:var(--primary-dark);font-size:.78rem;font-weight:900}.line-script-list p{margin-top:2px}.line-chat-date,.line-chat-notice,.line-chat-empty,.line-narration{color:#fff;background:#efabc0b8;border-radius:999px;padding:7px 12px;font-size:.78rem;font-weight:800}.line-chat-notice{text-align:center;border-radius:12px;max-width:92%;line-height:1.55}.line-chat-empty{color:var(--muted);text-align:center;background:#ffffffb8;border-radius:16px}.line-narration{color:#392d348f;text-align:center;white-space:pre-wrap;background:#ffffffad;border-radius:16px;justify-self:center;max-width:min(92%,520px);font-weight:700;line-height:1.6}.line-narration-wrap{justify-items:center;gap:8px;display:grid}.line-narration-button{cursor:pointer;border:0}.line-narration-button:hover,.line-narration-button:focus-visible{box-shadow:0 0 0 4px #ff7daf24}.line-narration-edit-form{width:min(92%,520px)}.line-audience-prompt{color:#6f4a57;background:#fff7fbdb;border:1px solid #ff7daf47}.line-audience-reaction{margin-top:-2px}.line-chat-messages{gap:12px;width:100%;margin-top:8px;display:grid}.line-message{align-items:flex-start;gap:8px;display:flex}.line-avatar{width:36px;height:36px;color:var(--primary-dark);background:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;font-weight:900;display:inline-flex;overflow:hidden;box-shadow:0 6px 14px #392d341a}.line-avatar img{object-fit:cover;width:100%;height:100%}.line-message-content{gap:4px;max-width:min(78%,520px);display:grid}.line-message-name{color:#392d34a8;font-size:.74rem;font-weight:800}.line-bubble{background:var(--bubble-color,white);color:var(--text);white-space:pre-wrap;border-radius:18px;margin:0;padding:10px 13px;line-height:1.65;position:relative;box-shadow:0 8px 18px #392d341a}.line-action-description{color:#392d347a}.line-bubble-button{text-align:left;border:0;width:fit-content;display:block}.line-bubble-button:hover,.line-bubble-button:focus-visible{box-shadow:0 8px 18px #392d341a,0 0 0 4px #ff7daf29}.line-bubble-static{width:fit-content}.line-bubble:before{background:var(--bubble-color,white);clip-path:polygon(0 50%,100% 0,100% 100%);content:"";width:12px;height:12px;position:absolute;top:10px;left:-6px}.line-message-edit-form{border:1px solid var(--border);background:#ffffffd1;border-radius:16px;gap:8px;padding:10px;display:grid}.line-message-edit-form textarea{width:100%;min-height:64px;color:var(--text);resize:vertical;background:#fffc;border:0;border-radius:12px;outline:none;padding:9px 10px}.line-message-edit-actions{justify-content:flex-end;gap:8px;display:flex}.line-chat-composer{background:#f8cad8;justify-content:flex-end;align-items:flex-end;gap:8px;min-width:0;padding:10px 12px;display:flex}.line-audience-composer{grid-template-columns:minmax(0,1fr) auto auto;align-items:end;display:grid}.line-audience-input-label{color:#6f4a57;grid-column:1/-1;font-size:.78rem;font-weight:900}.line-audience-input{width:100%;min-height:48px;color:var(--text);resize:vertical;background:#ffffffb8;border:0;border-radius:18px;outline:none;padding:11px 12px}.line-audience-input:focus{box-shadow:0 0 0 4px #ff7daf29}.line-audience-generate-button{white-space:nowrap;min-height:44px}.line-auto-toggle{color:#6f4a57;background:#ffffff6b;border-radius:999px;align-items:center;gap:8px;height:44px;padding:0 10px 0 12px;font-size:.82rem;font-weight:900;display:inline-flex;position:relative}.line-auto-toggle input{opacity:0;pointer-events:none;position:absolute}.line-auto-toggle-track{background:#6f4a573d;border-radius:999px;width:42px;height:24px;transition:background .18s,box-shadow .18s;position:relative}.line-auto-toggle-track:after{content:"";background:#fff;border-radius:999px;width:18px;height:18px;transition:transform .18s;position:absolute;top:3px;left:3px;box-shadow:0 3px 8px #392d342e}.line-auto-toggle input:checked+.line-auto-toggle-track{background:var(--primary-dark)}.line-auto-toggle input:checked+.line-auto-toggle-track:after{transform:translate(18px)}.line-auto-toggle:has(input:focus-visible){box-shadow:0 0 0 4px #ff7daf2e}.line-auto-toggle:has(input:disabled){cursor:not-allowed;opacity:.52}.line-send-button{color:#6f4a57;background:#ffffff80;border:0;border-radius:999px;flex:none;justify-content:center;align-items:center;min-width:64px;height:44px;font-weight:900;display:inline-flex}.line-send-button:disabled{cursor:not-allowed;opacity:.52}.line-chat-composer-complete{color:#6f4a57;text-align:center;flex-wrap:wrap;justify-content:center;gap:10px;font-weight:800}.line-complete-hint{color:#6f4a57b8;flex-basis:100%;font-size:.78rem}.line-complete-action{color:#6f4a57;background:#ffffffad;border:0;border-radius:999px;justify-content:center;align-items:center;min-height:38px;padding:0 16px;font-weight:900;display:inline-flex;box-shadow:0 8px 18px #392d3414}.line-complete-action:hover,.line-complete-action:focus-visible{background:#fff;outline:none;box-shadow:0 8px 18px #392d3414,0 0 0 4px #ff7daf29}@media (min-width:680px){.grid-two{grid-template-columns:1fr 1fr}}@media (max-width:520px){.welcome-help-backdrop{align-items:end;padding:8px}.welcome-help-dialog{border-radius:24px 24px 18px 18px;width:100%;height:min(92dvh,760px)}.welcome-help-header{padding:14px 14px 12px}.welcome-help-header h2{font-size:1rem}.welcome-help-content{padding:16px 14px 30px;font-size:.94rem;line-height:1.8}}
