@import url('https://fonts.googleapis.com/css2?family=Inter:wght@500;600;700;800;900&display=swap');

:root{--bg:#070b12;--bg2:#0b111b;--panel:#111722;--panel2:#171e2b;--panel3:#1d2533;--text:#f5f7fb;--muted:#99a5b8;--muted2:#687386;--line:rgba(180,195,220,.14);--line2:rgba(180,195,220,.24);--violet:#7b68ee;--violet2:#9d8cff;--cyan:#4fe8ff;--cyan2:#21cce8;--danger:#ff5d7c;--ok:#51e7a5;--shadow:0 26px 80px rgba(0,0,0,.55);--r-lg:22px;--r-md:14px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*{box-sizing:border-box}html{background:var(--bg);scroll-behavior:smooth}body{margin:0;min-height:100dvh;color:var(--text);background:radial-gradient(circle at 18% 0,rgba(123,104,238,.12),transparent 24rem),radial-gradient(circle at 92% 20%,rgba(79,232,255,.08),transparent 22rem),linear-gradient(135deg,#05070d,#0a1018 48%,#060910);letter-spacing:-.01em}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.026) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.026) 1px,transparent 1px);background-size:40px 40px;opacity:.65;mask-image:linear-gradient(to bottom,black 0 70%,transparent)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}

.topbar{position:sticky;top:0;z-index:30;min-height:64px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:12px clamp(18px,4vw,54px);background:rgba(7,11,18,.86);border-bottom:1px solid var(--line);backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:10px;color:#dce3ef;font-size:13px;font-weight:800;letter-spacing:.05em}.brand strong{color:#fff}.brand-mark{display:grid;place-items:center;width:30px;height:30px;border-radius:11px;background:linear-gradient(135deg,#252d3d,#10151f);border:1px solid var(--line2);box-shadow:inset 0 0 20px rgba(123,104,238,.18)}.topbar nav{display:flex;gap:6px;justify-content:center}.topbar nav a{min-height:40px;display:grid;place-items:center;padding:0 14px;border-radius:999px;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.topbar nav a:hover,.topbar nav a:focus-visible{outline:0;color:#fff;background:rgba(255,255,255,.06)}.top-actions{display:flex;justify-content:flex-end;gap:8px}.avatar-dot,.gear-dot{width:31px;height:31px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#a99cff,#4f3ec9);box-shadow:0 0 18px rgba(123,104,238,.4);font-size:12px;font-weight:900}.gear-dot{background:#101722;border:1px solid var(--line2);box-shadow:none;color:var(--muted)}

.app-shell{width:min(1280px,calc(100% - 44px));margin:0 auto;padding:22px 0 64px}.screen-title{margin:0 0 9px;font-size:16px;font-weight:900;text-transform:uppercase;letter-spacing:.055em}.app-window{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,rgba(22,29,41,.96),rgba(10,14,22,.98));box-shadow:var(--shadow)}.app-window:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:42px 42px;pointer-events:none}.window-head{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 26px;border-bottom:1px solid var(--line)}.window-head h1{margin:0;font-size:24px;letter-spacing:-.035em}.window-head h1 span{color:var(--muted)}.inline-head{padding:20px 22px}.eyebrow{margin:0 0 7px;color:#dbe4f4;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.head-pills{display:flex;gap:8px;flex-wrap:wrap}.head-pills span{padding:7px 10px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:11px;font-weight:800;background:rgba(255,255,255,.035)}

.editor-board{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:24px;padding:42px clamp(20px,7vw,110px) 54px}.side-stack{display:grid;gap:18px}.panel{border:1px solid var(--line2);border-radius:var(--r-md);background:linear-gradient(180deg,rgba(38,45,60,.76),rgba(22,28,40,.86));box-shadow:0 18px 48px rgba(0,0,0,.36);padding:18px}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-head.compact h2{font-size:16px}.panel h2{margin:0;font-size:21px;letter-spacing:-.03em}label{display:block;margin:14px 0 7px;color:#d9e1ef;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.055em}input:not([type=file]),textarea,select{width:100%;border:1px solid rgba(203,214,232,.14);border-radius:10px;background:rgba(8,11,18,.72);color:var(--text);padding:13px 14px;outline:0;transition:.16s ease}textarea{min-height:320px;resize:vertical;line-height:1.55}input::placeholder,textarea::placeholder{color:#697589}input:focus,textarea:focus,select:focus{border-color:rgba(79,232,255,.55);box-shadow:0 0 0 4px rgba(79,232,255,.08)}

.btn,.icon-btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line2);border-radius:999px;background:rgba(255,255,255,.055);color:#e8edf7;padding:0 16px;font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;transition:.16s ease}.btn:hover,.icon-btn:hover,.btn:focus-visible,.icon-btn:focus-visible{outline:0;transform:translateY(-1px);border-color:rgba(255,255,255,.34);background:rgba(255,255,255,.09)}.btn.primary{border:0;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet2));box-shadow:0 12px 30px rgba(123,104,238,.32)}.btn.cyan{border:0;color:#021016;background:linear-gradient(135deg,var(--cyan),var(--cyan2));box-shadow:0 12px 28px rgba(79,232,255,.18)}.btn.danger{color:#ffcbd5;border-color:rgba(255,93,124,.34);background:rgba(255,93,124,.1)}.btn.full{width:100%}.btn.tiny{min-height:28px;padding:0 10px;font-size:10px}.icon-btn{width:42px;padding:0;border-radius:50%;background:rgba(123,104,238,.22);color:#dcd6ff}.button-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.drop-zone{display:grid;place-items:center;text-align:center;gap:8px;min-height:142px;margin:8px 0 14px;border:1px dashed rgba(210,220,238,.22);border-radius:13px;background:rgba(255,255,255,.035);cursor:pointer}.drop-zone input{display:none}.upload-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;border:1px solid var(--line2);color:var(--muted)}.drop-zone small,.empty-line{color:var(--muted);font-size:12px}.status-dot{width:9px;height:9px;border-radius:50%;background:var(--cyan);box-shadow:0 0 14px var(--cyan)}.kebab{color:var(--muted)}.recent-list{display:grid;gap:2px}.recent-item{display:grid;grid-template-columns:20px 1fr auto;gap:8px;align-items:center;padding:9px 8px;border-radius:8px;color:#dfe6f3;font-size:12px}.recent-item:hover{background:rgba(255,255,255,.055)}.recent-item time{color:var(--muted2);font-size:11px}.doc-icon{color:var(--muted)}

.split-window{display:grid;grid-template-columns:240px minmax(0,1fr);min-height:640px}.sidebar{position:relative;z-index:1;padding:22px 16px;border-right:1px solid var(--line);background:rgba(19,25,36,.72)}.sidebar-brand{margin:0 0 24px;padding:0 8px;color:#fff;font-size:13px;font-weight:900}.side-link{display:flex;align-items:center;gap:10px;min-height:38px;margin-bottom:7px;padding:0 11px;border-radius:7px;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.side-link.active,.side-link:hover{color:#fff;background:rgba(255,255,255,.08)}.sidebar-logout{margin-top:26px}.content-pane{position:relative;z-index:1;padding-bottom:20px}.meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:18px 22px}.meta-card,.stat{border:1px solid var(--line2);border-radius:12px;background:rgba(255,255,255,.045);padding:16px}.meta-card span,.stat span{display:block;color:var(--muted);font-size:11px;font-weight:900;text-transform:uppercase}.meta-card strong{display:block;margin-top:8px}.script-preview{margin:0 22px 18px;max-height:48dvh;overflow:auto;border:1px solid var(--line);border-radius:13px;background:rgba(5,7,12,.62);padding:20px;color:#e9eef8;line-height:1.65}.sticky-actions{padding:0 22px 18px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:0 22px 18px}.stat strong{display:block;margin-top:8px;font-size:32px}.stat em{color:var(--ok);font-style:normal}.filter-bar{display:grid;grid-template-columns:1fr 170px;gap:12px;margin:0 22px 14px}.admin-list{display:grid;gap:8px;padding:0 22px 18px}.admin-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.04);padding:10px}.admin-row.expired{opacity:.64}.admin-edit-form{display:grid;grid-template-columns:minmax(180px,1fr) 100px 130px;gap:10px;align-items:center}.admin-edit-form input{font-weight:800}.admin-edit-form textarea{grid-column:1/-1;min-height:58px;font-size:12px}.row-user,.row-date{color:var(--muted);font-size:12px}.row-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.inline-form{display:inline-flex;margin:0}

.prompter-page{display:grid;grid-template-columns:310px minmax(0,1fr);gap:18px;height:calc(100dvh - 64px);padding:18px clamp(14px,3vw,30px)}.prompt-control-panel{display:flex;flex-direction:column;gap:18px;padding:22px;border:1px solid var(--line2);border-radius:8px;background:linear-gradient(180deg,rgba(24,31,44,.95),rgba(12,17,26,.98));box-shadow:var(--shadow)}.prompt-control-panel h1{margin:0;font-size:30px;line-height:1;letter-spacing:-.045em}.control-hint{color:var(--muted);line-height:1.45}.prompt-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px}.control-range{display:grid;gap:10px;color:#dce5f7;font-size:12px;font-weight:900;text-transform:uppercase}.control-range input{width:100%;accent-color:var(--violet)}.prompt-status{margin-top:auto;color:var(--muted);font-size:12px}.prompt-status span{display:inline-block;width:8px;height:8px;margin-right:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 12px var(--ok)}.prompt-stage{height:100%;overflow-y:scroll;scrollbar-gutter:stable;padding:18vh clamp(24px,6vw,90px) 60vh;border:1px solid var(--line);border-radius:8px;background:radial-gradient(circle at 50% 100%,rgba(123,104,238,.08),transparent 28rem),#07080d;box-shadow:inset 0 -1px 0 rgba(255,255,255,.04),var(--shadow);cursor:grab}.prompt-stage:focus{outline:3px solid rgba(79,232,255,.24);outline-offset:3px}.prompt-stage:active,.prompt-stage.middle-scroll-active{cursor:grabbing}.prompt-stage::-webkit-scrollbar{width:14px}.prompt-stage::-webkit-scrollbar-track{background:rgba(255,255,255,.055)}.prompt-stage::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--violet),var(--cyan));border-radius:999px;border:3px solid #07080d}.prompt-output{max-width:980px;margin:0 auto;color:#fff;font-weight:650;line-height:1.55;letter-spacing:-.015em;text-align:center;text-shadow:0 2px 18px rgba(0,0,0,.72);cursor:text}.prompt-output:focus{outline:2px solid rgba(79,232,255,.28);outline-offset:14px;border-radius:8px}.prompt-stage #prompt-output{position:static;left:auto;top:auto;width:auto;min-height:40vh;margin:0 auto;transform:none;font:650 58px/1.55 Inter,ui-sans-serif,system-ui,sans-serif;white-space:pre-wrap;tab-size:4}.mirrored .prompt-output,.mirrored .prompt-stage #prompt-output{transform:scaleX(-1)}.is-playing .prompt-control-panel{border-color:rgba(79,232,255,.4)}

.login-shell{min-height:calc(100dvh - 64px);display:grid;place-items:center;padding:28px}.login-card{width:min(460px,100%);position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--violet),var(--cyan))}.login-card h1{margin:0;font-size:34px}.form-error{padding:12px 14px;border-radius:10px;border:1px solid rgba(255,93,124,.34);background:rgba(255,93,124,.12);color:#ffd9e0;font-weight:800}

@media(max-width:980px){.topbar{grid-template-columns:1fr}.topbar nav{justify-content:flex-start;overflow:auto}.top-actions{display:none}.editor-board,.split-window,.prompter-page{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--line)}.meta-grid,.stats-grid{grid-template-columns:1fr}.filter-bar,.admin-edit-form,.admin-row{grid-template-columns:1fr}.row-actions{justify-content:flex-start}.prompt-stage{height:72dvh}.prompt-control-panel{position:sticky;top:74px;z-index:5}}@media(max-width:620px){.app-shell{width:min(100% - 20px,1280px);padding-top:14px}.screen-title{font-size:14px}.window-head,.editor-board{padding:18px}.button-row .btn{width:100%}.prompt-buttons{grid-template-columns:1fr}.prompt-stage #prompt-output{font-size:42px}.prompt-stage{padding-inline:18px}.recent-item{grid-template-columns:20px 1fr}.recent-item time{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition:none!important;animation:none!important;scroll-behavior:auto!important}}


/* Prompt page: pure black stage + compact hideable controls */
body:has(.prompter-page){background:#000;}
body:has(.prompter-page)::before{display:none;}
.prompter-page{grid-template-columns:220px minmax(0,1fr);gap:10px;background:#000;padding:10px;height:calc(100dvh - 64px);}
.prompt-control-panel{padding:12px;gap:10px;border-radius:8px;background:#080a0f;border-color:rgba(255,255,255,.12);box-shadow:0 14px 38px rgba(0,0,0,.75);}
.prompt-control-panel h1{font-size:18px;line-height:1.1;}
.prompt-control-panel .eyebrow{font-size:9px;margin-bottom:4px;}
.prompt-control-panel .control-hint{font-size:11px;line-height:1.3;margin:0;}
.prompt-buttons{gap:6px;}
.prompt-buttons .btn{min-height:34px;padding:0 9px;font-size:10px;}
.prompt-control-topline{margin:-2px 0 0;}
.control-range{gap:6px;font-size:10px;}
.prompt-status{font-size:10px;}
.prompt-stage{background:#000;border-color:rgba(255,255,255,.08);border-radius:0;box-shadow:none;padding:16vh clamp(18px,6vw,90px) 62vh;}
.prompt-stage:focus{outline-color:rgba(255,255,255,.18);}
.controls-hidden .prompter-page{grid-template-columns:1fr;}
.controls-hidden .prompt-control-panel{position:fixed;top:76px;left:10px;z-index:40;width:120px;padding:8px;background:rgba(8,10,15,.82);backdrop-filter:blur(10px);}
.controls-hidden .prompt-control-panel > *:not(.prompt-control-topline):not(.dock-reminder){display:none;}
.dock-reminder{display:none;}
.controls-hidden .dock-reminder{display:block;position:absolute;left:64px;top:50%;transform:translateY(-50%);width:max-content;max-width:190px;padding:9px 12px;border:1px solid rgba(157,140,255,.35);border-radius:999px;background:rgba(18,20,32,.94);color:#f4f1ff;font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;pointer-events:none;box-shadow:0 12px 34px rgba(0,0,0,.5),0 0 24px rgba(157,140,255,.22);animation:dockHintPulse 2.8s ease-in-out infinite;}
.controls-hidden .prompt-control-topline .btn{min-height:32px;font-size:9px;padding:0 8px;}
.controls-hidden .prompt-stage{grid-column:1/-1;}
@media(max-width:980px){.prompter-page{grid-template-columns:1fr;height:auto;min-height:calc(100dvh - 64px);}.prompt-control-panel{position:sticky;top:74px;}.controls-hidden .prompt-control-panel{position:fixed;}}


/* Editable shared script */
.editable-script{cursor:text;}
.editable-script:focus{outline:2px solid rgba(79,232,255,.32);outline-offset:4px;border-color:rgba(79,232,255,.42);}


/* Transparent prompt controls + text spacing selector */
body:has(.prompter-page) .prompt-control-panel{background:rgba(0,0,0,.18);border-color:rgba(255,255,255,.10);box-shadow:none;backdrop-filter:blur(8px);}
body:has(.prompter-page) .prompt-control-panel input,body:has(.prompter-page) .prompt-control-panel select{background:rgba(0,0,0,.28);}
.controls-hidden .prompt-control-panel{background:rgba(0,0,0,.16);}


/* Full editor homepage + working drag/drop visual state */
.home-shell .editor-board{grid-template-columns:1fr;max-width:1080px;margin:0 auto;padding-inline:clamp(18px,5vw,70px);}
.home-shell .paste-panel textarea{min-height:52dvh;font-size:17px;line-height:1.65;}
.home-shell .side-stack{grid-template-columns:1fr;}
.home-shell .upload-panel{max-width:720px;width:100%;margin:0 auto;}
.drop-zone.is-dragging{border-color:rgba(79,232,255,.8);background:rgba(79,232,255,.10);box-shadow:0 0 0 4px rgba(79,232,255,.08),0 18px 46px rgba(79,232,255,.12);}
.drop-zone.is-dragging .upload-icon{border-color:rgba(79,232,255,.7);color:var(--cyan);}


/* Full-page home/editor redesign — no boxed app-window */
.home-page-redesign{width:min(1500px,calc(100% - 42px));margin:0 auto;padding:28px 0 56px;}
.home-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:22px;margin:10px 0 22px;padding:0 4px;}
.home-hero h1{margin:0;font-size:clamp(42px,7vw,86px);line-height:.88;letter-spacing:-.075em;}
.home-hero h1 span{color:#778296;}
.hero-subtitle{max-width:620px;margin:16px 0 0;color:var(--muted);font-size:16px;line-height:1.55;}
.full-editor-layout{display:grid;grid-template-rows:minmax(0,1fr) auto;gap:18px;min-height:calc(100dvh - 190px);}
.editor-surface{display:flex;flex-direction:column;min-height:calc(100dvh - 330px);border:1px solid rgba(180,195,220,.13);border-radius:18px;background:linear-gradient(180deg,rgba(17,22,32,.72),rgba(7,10,16,.78));box-shadow:0 22px 70px rgba(0,0,0,.42);padding:18px;backdrop-filter:blur(10px);}
.editor-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(180,195,220,.12);}
.editor-toolbar h2{margin:0;font-size:22px;letter-spacing:-.04em;}
.toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.toolbar-actions .btn[form="paste-script-form"],.toolbar-actions .upload-file-btn,.toolbar-actions .btn[data-action="open-prompt-page"]{width:190px;min-width:190px;height:42px;min-height:42px;margin:0;padding:0;border:1px solid rgba(180,195,220,.24);border-radius:999px;line-height:1;white-space:nowrap;}
.toolbar-actions .btn[form="paste-script-form"]{border-color:rgba(180,195,220,.24);}
.toolbar-actions .btn[data-action="open-prompt-page"]{border-color:transparent;}
.editor-surface textarea{flex:1;min-height:520px;border:0;border-radius:13px;background:#030406;color:#f7f8fb;padding:24px;font-size:18px;line-height:1.7;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),inset 0 24px 80px rgba(0,0,0,.45);}
.editor-surface textarea:focus{box-shadow:inset 0 0 0 1px rgba(79,232,255,.42),0 0 0 4px rgba(79,232,255,.08);}
.upload-strip{display:grid;grid-template-columns:minmax(180px,.7fr) minmax(180px,.75fr) minmax(260px,1.2fr) auto;gap:14px;align-items:center;border:1px solid rgba(180,195,220,.12);border-radius:16px;background:rgba(14,19,29,.58);padding:14px;backdrop-filter:blur(10px);}
.upload-copy h2{margin:0;font-size:17px;}
.upload-strip .drop-zone{min-height:76px;margin:0;grid-template-columns:auto 1fr;justify-items:start;text-align:left;padding:12px 14px;}
.upload-strip .drop-zone small{grid-column:2;}
.upload-strip .upload-icon{grid-row:1 / span 2;}
.upload-strip .btn{white-space:nowrap;}
@media(max-width:980px){.home-hero{align-items:flex-start;flex-direction:column}.upload-strip{grid-template-columns:1fr}.upload-strip .drop-zone{grid-template-columns:auto 1fr}.editor-toolbar{align-items:flex-start;flex-direction:column}.toolbar-actions,.toolbar-actions .btn{width:100%}.home-page-redesign{width:min(100% - 22px,1500px)}.editor-surface textarea{min-height:58dvh}}


/* Clean title + top-right hamburger menu */
.topbar{grid-template-columns:1fr auto;}
.topbar > nav,.top-actions{display:none!important;}
.brand{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:650;letter-spacing:.01em;text-transform:none;}
.brand span:last-child{font-weight:650;color:#e8edf5;}
.menu-wrap{position:relative;justify-self:end;}
.menu-wrap summary{list-style:none;}
.menu-wrap summary::-webkit-details-marker{display:none;}
.hamburger{width:42px;height:42px;border:1px solid var(--line2);border-radius:12px;background:rgba(255,255,255,.055);display:grid;place-content:center;gap:5px;cursor:pointer;}
.hamburger span{display:block;width:18px;height:2px;border-radius:999px;background:#e8edf5;}
.menu-panel{position:absolute;right:0;top:50px;z-index:80;min-width:190px;padding:8px;border:1px solid var(--line2);border-radius:14px;background:rgba(8,11,18,.92);box-shadow:0 22px 60px rgba(0,0,0,.5);backdrop-filter:blur(16px);}
.menu-panel a{display:block;padding:12px 13px;border-radius:10px;color:#dfe6f2;font-size:13px;font-weight:750;}
.menu-panel a:hover{background:rgba(255,255,255,.075);color:#fff;}
.plain-app-title{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important;font-size:clamp(34px,5vw,58px)!important;line-height:1!important;letter-spacing:-.035em!important;font-weight:750!important;}
@media(max-width:980px){.topbar{grid-template-columns:1fr auto}.menu-panel{right:0}.brand{font-size:12px}}


/* Integrated upload inside paste editor */
.inline-upload-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;margin:0 0 14px;}
.editor-drop-zone{min-height:92px;margin:0;grid-template-columns:auto 1fr;justify-items:start;text-align:left;padding:14px 16px;background:rgba(255,255,255,.028);}
.editor-drop-zone small{grid-column:2;color:var(--muted);}
.editor-drop-zone .upload-icon{grid-row:1 / span 2;}
.editor-text-form{display:flex;flex:1;min-height:0;}
.editor-text-form textarea{height:auto;}
@media(max-width:720px){.inline-upload-form{grid-template-columns:1fr}.inline-upload-form .btn{width:100%}}


/* Unified paste + upload editor */
.full-editor-layout{grid-template-rows:1fr;}
.unified-editor{gap:14px;}
.inline-upload-zone{display:grid;grid-template-columns:minmax(260px,1fr) auto;gap:12px;align-items:stretch;margin:0 0 4px;}
.inline-upload-zone .drop-zone{min-height:84px;margin:0;display:grid;grid-template-columns:auto 1fr;justify-items:start;text-align:left;padding:13px 15px;}
.inline-upload-zone .drop-zone small{grid-column:2;}
.inline-upload-zone .upload-icon{grid-row:1 / span 2;}
.inline-upload-zone .btn{height:84px;min-width:132px;border-radius:14px;}
.paste-script-form{display:flex;flex:1;min-height:0;}
.paste-script-form textarea{width:100%;}
.upload-strip{display:none!important;}
@media(max-width:760px){.inline-upload-zone{grid-template-columns:1fr}.inline-upload-zone .btn{height:46px;width:100%}}


/* File upload now lives beside Share; drag/drop target is the editor itself */
.upload-hidden-form{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;}
.upload-hidden-form input[type="file"]{position:absolute;left:-9999px;}
.upload-file-btn{white-space:nowrap;}
.editor-surface.is-dragging textarea,.editor-drop-zone.is-dragging{border-color:rgba(79,232,255,.8)!important;box-shadow:0 0 0 4px rgba(79,232,255,.08),inset 0 0 0 1px rgba(79,232,255,.35)!important;background:rgba(8,20,28,.88)!important;}
.script-preview.is-dragging{border-color:rgba(79,232,255,.8)!important;box-shadow:0 0 0 4px rgba(79,232,255,.08),inset 0 0 0 1px rgba(79,232,255,.35)!important;background:rgba(8,20,28,.88)!important;}
@media(max-width:700px){.toolbar-actions{gap:8px}.upload-file-btn{width:100%;}}

.brand-logo-mark{width:32px;height:32px;object-fit:contain;display:block;filter:drop-shadow(0 0 14px rgba(123,104,238,.25));}
.app-footer-note{width:min(100% - 28px,1500px);margin:10px auto 18px;color:rgba(153,165,184,.72);font-size:11px;font-weight:700;letter-spacing:.02em;text-align:center;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;}
.footer-wordmark{width:190px;max-height:32px;object-fit:contain;opacity:.72;filter:grayscale(.05);}

.compact-actions{margin:0;justify-content:flex-end;}
.compact-actions .btn{height:42px;min-height:42px;margin:0;}
.editable-script:empty::before{content:attr(data-placeholder);color:#697589;}
.quiet-head{justify-content:flex-end;min-height:72px;padding:14px 22px;background:rgba(6,9,15,.28);}
.quiet-head-spacer{flex:1;min-width:24px;}
.quiet-head .compact-actions{margin-left:auto;}
.quiet-head .compact-actions .btn,.quiet-head .compact-actions .upload-file-btn{height:40px;min-height:40px;padding:0 18px;}
.share-shell .screen-title,.share-shell .sidebar-brand,.share-shell .side-link[href="/admin"]{display:none!important;}
.share-shell{width:calc(100% - 44px);max-width:none;height:calc(100dvh - 80px);padding:16px 0 12px;}
.share-shell .split-window{height:100%;min-height:0;}
.share-shell .content-pane{display:flex;flex-direction:column;min-height:0;padding-bottom:0;}
.share-shell .window-head{flex:0 0 auto;}
.share-shell .script-preview{flex:1 1 auto;min-height:0;max-height:none;margin:18px 22px 10px;font-size:18px;line-height:1.75;position:relative;}
.share-shell .editable-script:empty::before{display:block;content:attr(data-placeholder) "\A\A Drop TXT, MD, RTF, or DOCX anywhere inside this editor.";white-space:pre-wrap;color:#778399;letter-spacing:.08em;}
.share-shell .sticky-actions{display:none!important;}
.compact-meta{flex:0 0 auto;display:flex;align-items:center;justify-content:flex-end;gap:10px;margin:0 22px 14px;color:rgba(153,165,184,.7);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;}
.compact-meta span{padding:6px 9px;border:1px solid rgba(180,195,220,.12);border-radius:999px;background:rgba(255,255,255,.03);}
.compact-meta strong{margin-left:4px;color:#d7deeb;font-size:11px;text-transform:none;letter-spacing:0;}
.sidebar{display:flex;flex-direction:column;min-height:0;}
.sidebar-history{margin-top:auto;min-height:0;max-height:46%;overflow:auto;overflow-x:hidden;border-top:1px solid rgba(180,195,220,.12);padding-top:12px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(157,140,255,.34) transparent;}
.sidebar-history::-webkit-scrollbar{width:6px;height:0;}
.sidebar-history::-webkit-scrollbar-track{background:transparent;}
.sidebar-history::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,rgba(157,140,255,.48),rgba(79,232,255,.30));}
.sidebar-history::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(157,140,255,.70),rgba(79,232,255,.48));}
.history-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:0 0 8px;}
.sidebar-history p{margin:0;color:var(--muted2);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;}
.history-clear{min-height:24px;border:1px solid rgba(255,93,124,.28);border-radius:999px;background:rgba(255,93,124,.08);color:#ffcbd5;padding:0 8px;font-size:9px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;}
.history-clear:hover,.history-clear:focus-visible{outline:0;background:rgba(255,93,124,.15);border-color:rgba(255,93,124,.46);}
.history-item{display:block;padding:8px 9px;margin-bottom:6px;border:1px solid transparent;border-radius:9px;color:#dfe6f3;background:rgba(255,255,255,.025);}
.history-item:hover,.history-item.active{border-color:rgba(180,195,220,.18);background:rgba(255,255,255,.07);}
.history-item strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;}
.history-item span,.history-empty{display:block;margin-top:3px;color:var(--muted2);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
body:has(.share-shell) .app-footer-note{display:none;}

.modal-open{overflow:hidden;}
.confirm-modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:22px;}
.confirm-modal[hidden]{display:none!important;}
.confirm-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.68);backdrop-filter:blur(8px);}
.confirm-card{position:relative;z-index:1;width:min(440px,100%);border:1px solid rgba(255,93,124,.28);border-radius:20px;background:linear-gradient(180deg,rgba(24,28,38,.98),rgba(8,10,16,.98));box-shadow:0 32px 90px rgba(0,0,0,.62);padding:22px;}
.confirm-card h2{margin:0 0 10px;font-size:28px;letter-spacing:-.04em;}
.confirm-card p:not(.eyebrow){margin:0;color:#c9d2df;line-height:1.55;}
.confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;}
.confirm-actions .btn{height:40px;min-height:40px;}
@media(max-width:520px){.confirm-actions{flex-direction:column}.confirm-actions .btn{width:100%}}
@media(max-width:760px){.quiet-head{align-items:stretch}.quiet-head-spacer{display:none}.quiet-head .compact-actions{width:100%;display:grid;grid-template-columns:1fr;}.quiet-head .compact-actions .btn,.quiet-head .compact-actions .upload-file-btn{width:100%;}}

body.is-speed-previewing .prompt-status{color:#cfd8ff;}
body.is-speed-previewing .prompt-status span{background:var(--violet2);box-shadow:0 0 16px var(--violet2);}
body.is-speed-previewing .prompt-status::after{content:" · Previewing speed";color:var(--violet2);font-weight:900;}

/* Compact teleprompter controls */
body:has(.prompter-page) .prompter-page{grid-template-columns:220px minmax(0,1fr);gap:12px;padding:12px;}
body:has(.prompter-page) .prompt-control-panel{display:grid;grid-template-columns:1fr 1fr;align-content:start;gap:8px;padding:10px;overflow:auto;border-radius:16px;background:linear-gradient(180deg,rgba(12,14,20,.76),rgba(0,0,0,.34));border-color:rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.035);}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,body:has(.prompter-page) .prompt-control-panel > .prompt-buttons,body:has(.prompter-page) .prompt-control-panel > .reset-controls,body:has(.prompter-page) .prompt-control-panel > .control-range:has(select){grid-column:1/-1;}
body:has(.prompter-page) .prompt-control-panel > div:nth-child(3){display:none;}
body:has(.prompter-page) .prompt-control-panel h1{display:none;}
body:has(.prompter-page) .prompt-control-topline{margin:0;}
body:has(.prompter-page) .prompt-control-topline .btn{min-height:30px;border-radius:12px;font-size:9px;color:rgba(232,237,247,.78);background:rgba(255,255,255,.04);}
body:has(.prompter-page) .prompt-buttons{grid-template-columns:1fr 1fr;gap:6px;}
body:has(.prompter-page) .prompt-buttons .start-button{grid-column:1/-1;min-height:44px;font-size:15px;border-radius:14px;box-shadow:0 10px 22px rgba(123,104,238,.24),inset 0 1px 0 rgba(255,255,255,.16);}
body:has(.prompter-page) .prompt-buttons .btn{min-height:32px;border-radius:12px;font-size:10px;}
body:has(.prompter-page) .control-range{gap:4px;margin:4px 0 0;font-size:8px;color:rgba(216,225,239,.68);letter-spacing:.08em;}
body:has(.prompter-page) .control-range input{height:22px;}
body:has(.prompter-page) .control-range:nth-of-type(5),body:has(.prompter-page) .control-range:nth-of-type(6){padding:6px 7px;border:1px solid rgba(255,255,255,.06);border-radius:10px;background:rgba(255,255,255,.025);}
body:has(.prompter-page) .reset-controls{min-height:30px;margin-top:2px;border-radius:12px;font-size:9px;background:rgba(255,255,255,.04);}
body:has(.prompter-page) .control-range select{min-height:32px;padding:6px 9px;border-radius:10px;}
body:has(.prompter-page) .prompt-stage{border-color:rgba(255,255,255,.055);}
@media(max-width:980px){body:has(.prompter-page) .prompter-page{grid-template-columns:1fr}.prompt-buttons{grid-template-columns:1fr 1fr}.prompt-buttons .start-button{grid-column:1/-1;}}

/* Smooth hide/show controls + full-reach sliders */
body:has(.prompter-page) .prompter-page{transition:grid-template-columns .32s ease,gap .32s ease;}
body:has(.prompter-page) .prompt-control-panel{transform-origin:left center;transition:opacity .22s ease,transform .32s cubic-bezier(.2,.8,.2,1),width .32s ease,padding .32s ease,background .22s ease;}
.controls-hidden .prompt-control-panel{animation:controlDockIn .28s ease both;}
.controls-hidden .prompt-stage{animation:stageBreatheIn .32s ease both;}
@keyframes controlDockIn{from{opacity:0;transform:translateX(-16px) scale(.94)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes stageBreatheIn{from{opacity:.92;transform:scale(.992)}to{opacity:1;transform:scale(1)}}
body:has(.prompter-page) .control-range input[type="range"]{width:100%;min-width:0;margin:0;padding:0;-webkit-appearance:none;appearance:none;background:transparent;cursor:pointer;}
body:has(.prompter-page) .control-range input[type="range"]::-webkit-slider-runnable-track{height:6px;border-radius:999px;background:linear-gradient(90deg,var(--violet),rgba(255,255,255,.9));}
body:has(.prompter-page) .control-range input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;margin-top:-5px;border:0;border-radius:50%;background:var(--violet2);box-shadow:0 0 0 2px rgba(0,0,0,.8),0 0 18px rgba(157,140,255,.55);}
body:has(.prompter-page) .control-range input[type="range"]::-moz-range-track{height:6px;border-radius:999px;background:linear-gradient(90deg,var(--violet),rgba(255,255,255,.9));}
body:has(.prompter-page) .control-range input[type="range"]::-moz-range-thumb{width:16px;height:16px;border:0;border-radius:50%;background:var(--violet2);box-shadow:0 0 0 2px rgba(0,0,0,.8),0 0 18px rgba(157,140,255,.55);}

/* Mac-style hover dock for controls */
body:has(.prompter-page) .prompter-page{grid-template-columns:280px minmax(0,1fr);}
.controls-hidden .prompter-page{grid-template-columns:1fr;}
.controls-hidden .prompt-stage{grid-column:1/-1;}
.controls-hidden .prompt-control-panel{position:fixed;top:74px;bottom:22px;left:10px;z-index:60;width:66px;min-height:0;height:auto;max-height:none;padding:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:22px;background:linear-gradient(180deg,rgba(12,14,20,.32),rgba(0,0,0,.24));border-color:rgba(255,255,255,.10);box-shadow:0 18px 45px rgba(0,0,0,.30);backdrop-filter:blur(16px);transform:none;}
.controls-hidden .prompt-control-panel::after{content:"";position:absolute;inset:-12px -24px -12px -10px;z-index:-1;border-radius:28px;}
.controls-hidden .prompt-control-panel > *:not(.prompt-control-topline):not(.dock-reminder){display:none;}
.dock-reminder{display:none;}
.controls-hidden.show-dock-hint .dock-reminder{display:block;position:absolute;left:74px;top:50%;transform:translateY(-50%);width:max-content;max-width:220px;padding:10px 13px;border:1px solid rgba(157,140,255,.38);border-radius:999px;background:rgba(18,20,32,.96);color:#f4f1ff;font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;pointer-events:none;box-shadow:0 12px 34px rgba(0,0,0,.5),0 0 24px rgba(157,140,255,.22);animation:dockHintPulse 2.8s ease-in-out infinite;}
.controls-hidden .prompt-control-panel .prompt-control-topline{width:48px;}
.controls-hidden .prompt-control-panel .prompt-control-topline .btn{min-height:160px;width:100%;padding:0 4px;writing-mode:vertical-rl;text-orientation:mixed;border-radius:18px;font-size:10px;background:rgba(255,255,255,.075);}
body.controls-hidden .prompt-control-panel:hover,body.controls-hidden .prompt-control-panel:focus-within{top:74px;bottom:22px;width:320px;min-height:0;height:auto;padding:14px;display:grid;grid-template-columns:1fr 1fr;align-content:start;gap:10px;overflow-y:auto;overflow-x:hidden;transform:none;background:linear-gradient(180deg,rgba(12,14,20,.94),rgba(0,0,0,.72));border-color:rgba(255,255,255,.16);box-shadow:0 22px 60px rgba(0,0,0,.54),0 0 32px rgba(157,140,255,.13);scrollbar-width:thin;scrollbar-color:rgba(157,140,255,.42) transparent;}
body.controls-hidden .prompt-control-panel:hover::after,body.controls-hidden .prompt-control-panel:focus-within::after{inset:0;}
body.controls-hidden .prompt-control-panel:hover > *,body.controls-hidden .prompt-control-panel:focus-within > *{display:block!important;}
body.controls-hidden .prompt-control-panel:hover .dock-reminder,body.controls-hidden .prompt-control-panel:focus-within .dock-reminder{display:none!important;}
body.controls-hidden .prompt-control-panel:hover > .prompt-control-topline,body.controls-hidden .prompt-control-panel:hover > .prompt-buttons,body.controls-hidden .prompt-control-panel:hover > .reset-controls,body.controls-hidden .prompt-control-panel:hover > .control-range:has(select),body.controls-hidden .prompt-control-panel:focus-within > .prompt-control-topline,body.controls-hidden .prompt-control-panel:focus-within > .prompt-buttons,body.controls-hidden .prompt-control-panel:focus-within > .reset-controls,body.controls-hidden .prompt-control-panel:focus-within > .control-range:has(select){grid-column:1/-1;}
body.controls-hidden .prompt-control-panel:hover > div:nth-child(3),body.controls-hidden .prompt-control-panel:focus-within > div:nth-child(3){display:none!important;}
body.controls-hidden .prompt-control-panel:hover .prompt-control-topline,body.controls-hidden .prompt-control-panel:focus-within .prompt-control-topline{width:100%;}
body.controls-hidden .prompt-control-panel:hover .prompt-control-topline .btn,body.controls-hidden .prompt-control-panel:focus-within .prompt-control-topline .btn{min-height:34px;width:100%;writing-mode:horizontal-tb;padding:0 10px;}
@keyframes dockHintPulse{0%,100%{opacity:.64;transform:translateY(-50%) translateX(0)}50%{opacity:1;transform:translateY(-50%) translateX(5px)}}
.dock-reminder-global{display:none;}
.controls-hidden.show-dock-hint .dock-reminder-global{display:block;position:fixed;left:92px;top:50%;z-index:70;transform:translateY(-50%);padding:10px 13px;border:1px solid rgba(157,140,255,.42);border-radius:999px;background:rgba(18,20,32,.96);color:#f7f4ff;font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;box-shadow:0 14px 36px rgba(0,0,0,.55),0 0 26px rgba(157,140,255,.24);pointer-events:none;animation:dockHintPulse 2.8s ease-in-out infinite;}
body.controls-hidden .prompt-control-panel:hover ~ .dock-reminder-global,body.controls-hidden .prompt-control-panel:focus-within ~ .dock-reminder-global{display:none;}

/* JS-stabilized dock open state: avoids hover jump/flicker */
body.controls-hidden.controls-dock-open .prompt-control-panel{top:74px;bottom:22px;width:320px;min-height:0;height:auto;padding:14px;display:grid;grid-template-columns:1fr 1fr;align-content:start;gap:10px;overflow-y:auto;overflow-x:hidden;transform:none;background:linear-gradient(180deg,rgba(12,14,20,.94),rgba(0,0,0,.72));border-color:rgba(255,255,255,.16);box-shadow:0 22px 60px rgba(0,0,0,.54),0 0 32px rgba(157,140,255,.13);scrollbar-width:thin;scrollbar-color:rgba(157,140,255,.42) transparent;}
body.controls-hidden.controls-dock-open .prompt-control-panel::after{inset:0;}
body.controls-hidden.controls-dock-open .prompt-control-panel > *{display:block!important;}
body.controls-hidden.controls-dock-open .prompt-control-panel .dock-reminder{display:none!important;}
body.controls-hidden.controls-dock-open .prompt-control-panel > .prompt-control-topline,
body.controls-hidden.controls-dock-open .prompt-control-panel > .prompt-buttons,
body.controls-hidden.controls-dock-open .prompt-control-panel > .reset-controls,
body.controls-hidden.controls-dock-open .prompt-control-panel > .control-range:has(select){grid-column:1/-1;}
body.controls-hidden.controls-dock-open .prompt-control-panel > div:nth-child(3){display:none!important;}
body.controls-hidden.controls-dock-open .prompt-control-panel .prompt-control-topline{width:100%;}
body.controls-hidden.controls-dock-open .prompt-control-panel .prompt-control-topline .btn{min-height:34px;width:100%;writing-mode:horizontal-tb;padding:0 10px;}
body.controls-hidden.controls-dock-open .dock-reminder-global{display:none;}

/* Dock scrollbar cleanup */
.controls-hidden .prompt-control-panel::-webkit-scrollbar{width:0;height:0;}
body.controls-hidden .prompt-control-panel:hover::-webkit-scrollbar,
body.controls-hidden.controls-dock-open .prompt-control-panel::-webkit-scrollbar{width:6px;height:0;}
body.controls-hidden .prompt-control-panel:hover::-webkit-scrollbar-track,
body.controls-hidden.controls-dock-open .prompt-control-panel::-webkit-scrollbar-track{background:transparent;}
body.controls-hidden .prompt-control-panel:hover::-webkit-scrollbar-thumb,
body.controls-hidden.controls-dock-open .prompt-control-panel::-webkit-scrollbar-thumb{background:rgba(157,140,255,.36);border-radius:999px;}

/* Prompt dock hint is temporary only, never during playback */
body.is-playing .dock-reminder,
body.is-playing .dock-reminder-global{display:none!important;}

/* Clean teleprompter reading mode */
body:has(.prompter-page) .topbar{display:none;}
body:has(.prompter-page) main{padding-top:0;}
body:has(.prompter-page) .prompter-page{min-height:100dvh;height:100dvh;}
body:has(.prompter-page) .prompt-stage{position:relative;isolation:isolate;}
body:has(.prompter-page) .prompt-watermark-logo{position:fixed;top:26px;left:50%;transform:translateX(-50%);width:min(170px,18vw);height:auto;opacity:.115;filter:grayscale(1) brightness(1.35) contrast(.9);pointer-events:none;z-index:-1;}
body:has(.prompter-page) .prompt-output{position:relative;z-index:1;}
body:has(.prompter-page).controls-hidden .prompt-control-panel{top:22px;bottom:22px;}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel{top:22px;bottom:22px;}
body:has(.prompter-page).controls-hidden.show-dock-hint .dock-reminder-global{top:50%;}

/* Teleprompter dock/sidebar polish */
body:has(.prompter-page) .prompt-control-panel{border-radius:24px;background:linear-gradient(180deg,rgba(13,15,22,.80),rgba(3,4,7,.54));border:1px solid rgba(255,255,255,.105);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 24px 70px rgba(0,0,0,.36);}
body:has(.prompter-page) .prompt-control-title{grid-column:1/-1;display:flex!important;align-items:center;gap:8px;min-height:24px;color:rgba(255,255,255,.68);font-size:10px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;}
body:has(.prompter-page) .control-dot{width:8px;height:8px;border-radius:999px;background:linear-gradient(135deg,#9d8cff,#61e7ff);box-shadow:0 0 18px rgba(157,140,255,.7);}
body:has(.prompter-page) .prompt-buttons{gap:8px;}
body:has(.prompter-page) .prompt-buttons .btn{border-radius:14px;}
body:has(.prompter-page) .prompt-buttons .start-button{min-height:52px;border-radius:18px;box-shadow:0 14px 34px rgba(157,140,255,.26);}
body:has(.prompter-page) .control-range{border:1px solid rgba(255,255,255,.06);border-radius:16px;background:rgba(255,255,255,.035);padding:9px 10px;color:rgba(255,255,255,.72);font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;}
body:has(.prompter-page) .control-range input[type="range"]{margin-top:7px;}
body:has(.prompter-page) .reset-controls{border-radius:14px;}
body:has(.prompter-page) .dock-reminder{display:none!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel{width:54px;left:12px;border-radius:999px;background:linear-gradient(180deg,rgba(18,20,28,.42),rgba(0,0,0,.24));border-color:rgba(255,255,255,.12);box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 20px 55px rgba(0,0,0,.32);}
body:has(.prompter-page).controls-hidden .prompt-control-panel > *:not(.prompt-control-topline){display:none!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel .prompt-control-topline{width:38px;}
body:has(.prompter-page).controls-hidden .prompt-control-panel .prompt-control-topline .btn{min-height:146px;border-radius:999px;background:linear-gradient(180deg,rgba(157,140,255,.16),rgba(97,231,255,.08));border-color:rgba(255,255,255,.11);color:rgba(255,255,255,.78);}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within{width:340px;border-radius:24px;background:linear-gradient(180deg,rgba(13,15,22,.96),rgba(0,0,0,.78));}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel > *:not(.dock-reminder),
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover > *:not(.dock-reminder),
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within > *:not(.dock-reminder){display:block!important;}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-title,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-control-title,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-control-title{display:flex!important;}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-control-topline,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-control-topline,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-control-topline{width:100%;}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-control-topline .btn,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-control-topline .btn,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-control-topline .btn{min-height:34px;border-radius:14px;writing-mode:horizontal-tb;}

/* During playback, Start collapses first; hover still opens controls so Stop/Pause remain reachable. */
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within){width:54px!important;left:12px!important;top:22px!important;bottom:22px!important;padding:0!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;border-radius:999px!important;background:linear-gradient(180deg,rgba(18,20,28,.42),rgba(0,0,0,.24))!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 20px 55px rgba(0,0,0,.32)!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) > *:not(.prompt-control-topline){display:none!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) .prompt-control-topline{display:block!important;width:38px!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) .prompt-control-topline .btn{min-height:146px!important;width:100%!important;border-radius:999px!important;writing-mode:vertical-rl!important;}
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel{width:54px!important;left:12px!important;top:22px!important;bottom:22px!important;padding:0!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;border-radius:999px!important;}
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel > *:not(.prompt-control-topline){display:none!important;}
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel .prompt-control-topline{display:block!important;width:38px!important;}
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel .prompt-control-topline .btn{min-height:146px!important;width:100%!important;border-radius:999px!important;writing-mode:vertical-rl!important;}
body:has(.prompter-page).is-playing.controls-hidden .dock-reminder-global{display:none!important;}

/* Sidebar button + font select refinement */
body:has(.prompter-page) .prompt-buttons{display:grid!important;grid-template-columns:1.15fr 1fr 1fr 1fr;gap:10px;align-items:stretch;}
body:has(.prompter-page) .prompt-buttons .btn{min-height:44px;padding:0 12px;border-radius:999px;font-size:10px;font-weight:950;letter-spacing:.04em;text-transform:uppercase;background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.028));border:1px solid rgba(255,255,255,.13);color:rgba(255,255,255,.88);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 10px 24px rgba(0,0,0,.28);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease;}
body:has(.prompter-page) .prompt-buttons .btn:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.24);box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 14px 30px rgba(0,0,0,.34);}
body:has(.prompter-page) .prompt-buttons .btn:active{transform:translateY(0) scale(.985);}
body:has(.prompter-page) .prompt-buttons .start-button{min-height:48px;border-radius:18px;background:linear-gradient(135deg,#8068ff,#9d8cff);border-color:rgba(196,184,255,.42);color:#fff;box-shadow:0 16px 36px rgba(128,104,255,.36),inset 0 1px 0 rgba(255,255,255,.18);}
body:has(.prompter-page) .prompt-buttons .cyan{background:linear-gradient(135deg,#43dff5,#7cf5ff);border-color:rgba(124,245,255,.45);color:#061013;box-shadow:0 16px 34px rgba(67,223,245,.25),inset 0 1px 0 rgba(255,255,255,.25);}
body:has(.prompter-page) .prompt-control-topline .btn{background:linear-gradient(180deg,rgba(35,39,56,.92),rgba(22,24,35,.86));border:1px solid rgba(255,255,255,.13);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 12px 26px rgba(0,0,0,.24);}
body:has(.prompter-page) .reset-controls{min-height:36px;border-radius:999px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.14);font-size:10px;font-weight:950;letter-spacing:.06em;color:rgba(255,255,255,.86);box-shadow:inset 0 1px 0 rgba(255,255,255,.06);}
body:has(.prompter-page) .reset-controls:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.22);}
body:has(.prompter-page) .control-range:has(select){position:relative;padding:12px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025));}
body:has(.prompter-page) .control-range select{margin-top:8px;width:100%;min-height:44px;padding:0 42px 0 14px;border-radius:14px;background:linear-gradient(180deg,rgba(10,12,18,.94),rgba(5,6,9,.94));border:1px solid rgba(255,255,255,.12);color:#fff;font-size:12px;font-weight:800;letter-spacing:.01em;appearance:none;-webkit-appearance:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 10px 24px rgba(0,0,0,.25);}
body:has(.prompter-page) .control-range:has(select)::after{content:"⌄";position:absolute;right:26px;bottom:22px;color:rgba(255,255,255,.62);font-size:16px;line-height:1;pointer-events:none;}
body:has(.prompter-page) .control-range select:focus{outline:none;border-color:rgba(157,140,255,.72);box-shadow:0 0 0 3px rgba(157,140,255,.18),inset 0 1px 0 rgba(255,255,255,.07);}
body:has(.prompter-page).controls-hidden .prompt-control-panel .prompt-control-topline .btn{font-size:9px;letter-spacing:.06em;}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-buttons{display:grid!important;}

/* Larger, cleaner sidebar action buttons */
body:has(.prompter-page) .prompt-buttons{grid-template-columns:1fr 1fr!important;gap:10px;}
body:has(.prompter-page) .prompt-buttons .btn{min-height:46px;width:100%;font-size:11px;}
body:has(.prompter-page) .prompt-buttons .stop-button{background:linear-gradient(135deg,rgba(255,93,124,.88),rgba(255,136,92,.78));border-color:rgba(255,160,160,.36);color:#fff;}
body:has(.prompter-page) .prompt-buttons .start-button{min-height:54px;border-radius:20px;}
body:has(.prompter-page) .prompt-buttons .cyan{min-height:54px;border-radius:20px;}

/* Final sidebar action layout + visible font selector */
body:has(.prompter-page) .prompt-control-panel .prompt-buttons{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .btn{width:auto!important;min-width:0!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .start-button,
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .cyan{min-height:52px;}
body:has(.prompter-page) .font-control{grid-column:1/-1!important;}
body:has(.prompter-page) .font-control select{font-size:13px;font-weight:850;}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-buttons{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;}

/* Balance action buttons: primary/back full width, secondary pair */
body:has(.prompter-page) .prompt-buttons .start-button{grid-column:1/-1;}
body:has(.prompter-page) .prompt-buttons .stop-button{grid-column:1/-1;}
body:has(.prompter-page) .prompt-buttons .cyan{grid-column:1/-1;width:100%!important;}

/* Custom premium font picker */
body:has(.prompter-page) .font-picker{position:relative!important;display:block!important;overflow:visible!important;padding:6px 8px!important;z-index:100!important;}
body:has(.prompter-page) .font-picker .control-label{display:block;margin-bottom:8px;color:rgba(255,255,255,.72);font-size:10px;font-weight:950;letter-spacing:.11em;text-transform:uppercase;}
body:has(.prompter-page) .font-picker > select{position:absolute!important;inline-size:1px!important;block-size:1px!important;opacity:0!important;pointer-events:none!important;}
body:has(.prompter-page) .font-picker-trigger{width:100%;min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 14px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg,rgba(18,21,31,.98),rgba(6,7,11,.96));color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.07),0 14px 30px rgba(0,0,0,.30);cursor:pointer;overflow:visible!important;}
body:has(.prompter-page) .font-picker-trigger:hover{border-color:rgba(157,140,255,.42);box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 16px 34px rgba(0,0,0,.35),0 0 22px rgba(157,140,255,.10);}
body:has(.prompter-page) .font-picker-current{font-size:14px;font-weight:900;letter-spacing:.01em;}
body:has(.prompter-page) .font-picker-chev{width:24px;height:24px;display:grid;place-items:center;border-radius:999px;background:rgba(255,255,255,.07);color:rgba(255,255,255,.72);font-size:15px;}
body:has(.prompter-page) .font-picker-trigger[aria-expanded="true"] .font-picker-chev{transform:rotate(180deg);background:rgba(157,140,255,.22);color:#fff;}
body:has(.prompter-page) .font-picker-menu{position:absolute;left:12px;right:12px;top:calc(100% - 4px);z-index:90;display:grid;gap:6px;padding:8px;border-radius:18px;border:1px solid rgba(255,255,255,.16);background:linear-gradient(180deg,rgba(16,18,27,.98),rgba(4,5,8,.98));box-shadow:0 22px 55px rgba(0,0,0,.62),0 0 30px rgba(157,140,255,.12);backdrop-filter:blur(18px);}
body:has(.prompter-page) .font-picker-menu[hidden]{display:none!important;}
body:has(.prompter-page) .font-picker-menu button{min-height:36px;display:flex;align-items:center;justify-content:space-between;padding:0 11px;border:1px solid transparent;border-radius:12px;background:transparent;color:rgba(255,255,255,.84);font-size:13px;cursor:pointer;text-align:left;}
body:has(.prompter-page) .font-picker-menu button::after{content:"Aa";opacity:.38;font-family:inherit;font-size:12px;}
body:has(.prompter-page) .font-picker-menu button:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.10);color:#fff;}
body:has(.prompter-page) .font-picker-menu button.is-active{background:linear-gradient(135deg,rgba(128,104,255,.28),rgba(97,231,255,.13));border-color:rgba(157,140,255,.36);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.08);}
body:has(.prompter-page) .font-picker-menu button.is-active::after{content:"✓";opacity:1;color:#8ff6ff;font-family:Inter,ui-sans-serif,system-ui,sans-serif;font-weight:900;}

/* Font menu opens upward to avoid clipping in the dock */
body:has(.prompter-page) .font-picker-menu{top:auto!important;bottom:calc(100% - 4px);max-height:min(320px,calc(100dvh - 72px));overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(157,140,255,.38) transparent;}
body:has(.prompter-page) .font-picker-menu::-webkit-scrollbar{width:6px;}
body:has(.prompter-page) .font-picker-menu::-webkit-scrollbar-thumb{background:rgba(157,140,255,.36);border-radius:999px;}

/* Fix double-arrow on custom font picker */
body:has(.prompter-page) .font-picker::after{display:none!important;content:none!important;}

/* Side margin control now visibly indents the teleprompter text itself */
body:has(.prompter-page) .prompt-output{display:block;margin-left:90px;margin-right:90px;transition:margin-inline .12s ease;}

/* Side margin stays centered: slider changes text column width, not its center */
body:has(.prompter-page) .prompt-stage #prompt-output{margin-left:auto!important;margin-right:auto!important;max-width:calc(100% - 180px);transition:max-width .12s ease;}

/* Centered side margin variable */
body:has(.prompter-page) .prompt-stage{--prompt-side-margin:90px;}
body:has(.prompter-page) .prompt-stage #prompt-output{max-width:calc(100% - (var(--prompt-side-margin) * 2))!important;min-width:240px;}

/* Centered side margin variable corrected for browser calc support */
body:has(.prompter-page) .prompt-stage #prompt-output{max-width:calc(100% - var(--prompt-side-margin) - var(--prompt-side-margin))!important;}

/* JS controls exact centered text width for side-margin slider */
body:has(.prompter-page) .prompt-stage #prompt-output{max-width:none!important;}

/* Bottom controls dock redesign */
body:has(.prompter-page) .prompter-page{display:block!important;padding:0!important;background:#000;min-height:100dvh;height:100dvh;}
body:has(.prompter-page) .prompt-stage{height:100dvh!important;width:100%!important;border:0!important;border-radius:0!important;padding-bottom:52vh!important;}
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within{position:fixed!important;left:50%!important;right:auto!important;top:auto!important;bottom:16px!important;z-index:90!important;width:min(1120px,calc(100vw - 28px))!important;height:auto!important;max-height:min(62vh,520px)!important;display:grid!important;grid-template-columns:1.15fr 1fr 1fr 1fr!important;gap:10px!important;align-content:start!important;overflow:visible!important;padding:14px 14px 84px!important;border-radius:26px!important;transform:translateX(-50%)!important;background:linear-gradient(180deg,rgba(13,15,22,.94),rgba(0,0,0,.82))!important;border:1px solid rgba(255,255,255,.14)!important;box-shadow:0 26px 80px rgba(0,0,0,.62),0 0 34px rgba(157,140,255,.12)!important;backdrop-filter:blur(18px)!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel{width:min(460px,calc(100vw - 28px))!important;min-height:54px!important;max-height:54px!important;padding:7px!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;border-radius:999px!important;background:linear-gradient(180deg,rgba(18,20,28,.50),rgba(0,0,0,.32))!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) > *:not(.prompt-control-topline),
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel > *:not(.prompt-control-topline){display:none!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .prompt-control-topline,
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel .prompt-control-topline{display:block!important;width:100%!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .prompt-control-topline .btn,
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel .prompt-control-topline .btn{min-height:40px!important;width:100%!important;border-radius:999px!important;writing-mode:horizontal-tb!important;text-orientation:mixed!important;}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel > .prompt-control-title,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons,
body:has(.prompter-page) .prompt-control-panel > .font-control,
body:has(.prompter-page) .prompt-control-panel > .reset-controls{grid-column:1/-1!important;}
body:has(.prompter-page) .prompt-control-topline{order:1;}
body:has(.prompter-page) .prompt-control-title{order:2;}
body:has(.prompter-page) .font-control{order:3;}
body:has(.prompter-page) .prompt-buttons{order:4;}
body:has(.prompter-page) .control-range{order:5;}
body:has(.prompter-page) .reset-controls{order:6;}
body:has(.prompter-page) .prompt-control-title{display:flex!important;justify-content:center;}
body:has(.prompter-page) .prompt-buttons{display:grid!important;grid-template-columns:repeat(6,minmax(0,1fr))!important;gap:8px!important;}
body:has(.prompter-page) .prompt-buttons .start-button,
body:has(.prompter-page) .prompt-buttons .stop-button,
body:has(.prompter-page) .prompt-buttons .cyan{grid-column:auto!important;min-height:46px!important;border-radius:16px!important;}
body:has(.prompter-page) .control-range{min-width:0;}
body:has(.prompter-page) .font-picker-menu{bottom:calc(100% + 8px)!important;top:auto!important;}
body:has(.prompter-page) .font-picker-menu[hidden]{display:none!important;}
body:has(.prompter-page).controls-hidden.show-dock-hint .dock-reminder-global{left:50%!important;top:auto!important;bottom:82px!important;transform:translateX(-50%)!important;}
@media(max-width:900px){body:has(.prompter-page) .prompt-control-panel,body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within{grid-template-columns:1fr 1fr!important;max-height:min(72vh,560px)!important;overflow-y:auto!important;}body:has(.prompter-page) .prompt-buttons{grid-template-columns:1fr 1fr!important;}body:has(.prompter-page) .prompt-buttons .start-button,body:has(.prompter-page) .prompt-buttons .stop-button,body:has(.prompter-page) .prompt-buttons .cyan{grid-column:1/-1!important;}}

/* Single-row compact bottom control bar */
body:has(.prompter-page) .prompt-stage{padding-bottom:24vh!important;}
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within{left:50%!important;bottom:12px!important;width:min(1240px,calc(100vw - 18px))!important;max-height:92px!important;min-height:74px!important;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:7px!important;overflow-x:auto!important;overflow-y:visible!important;padding:8px 10px!important;border-radius:999px!important;transform:translateX(-50%)!important;background:linear-gradient(180deg,rgba(12,14,20,.90),rgba(0,0,0,.76))!important;}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open){width:min(360px,calc(100vw - 18px))!important;min-height:52px!important;max-height:52px!important;padding:6px!important;overflow:hidden!important;}
body:has(.prompter-page) .prompt-control-title{display:none!important;}
body:has(.prompter-page) .prompt-control-topline{order:1!important;flex:0 0 92px!important;width:92px!important;display:block!important;}
body:has(.prompter-page) .prompt-control-topline .btn{min-height:38px!important;width:100%!important;border-radius:999px!important;writing-mode:horizontal-tb!important;font-size:9px!important;padding:0 8px!important;}
body:has(.prompter-page) .prompt-buttons{display:contents!important;}
body:has(.prompter-page) .prompt-buttons .btn{flex:0 0 auto!important;width:auto!important;min-width:74px!important;min-height:40px!important;padding:0 10px!important;border-radius:999px!important;font-size:9px!important;grid-column:auto!important;}
body:has(.prompter-page) .prompt-buttons .start-button{order:2!important;min-width:86px!important;}
body:has(.prompter-page) .prompt-buttons .stop-button{order:3!important;min-width:78px!important;}
body:has(.prompter-page) .prompt-buttons [data-action="pause"]{order:4!important;}
body:has(.prompter-page) .prompt-buttons [data-action="mirror"]{order:5!important;}
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"]{order:6!important;min-width:96px!important;}
body:has(.prompter-page) .prompt-buttons .cyan{order:7!important;min-width:72px!important;min-height:40px!important;border-radius:999px!important;}
body:has(.prompter-page) .font-control{order:8!important;flex:0 0 auto!important;grid-column:auto!important;padding:6px 10px!important;border-radius:18px!important;display:flex!important;align-items:center!important;gap:4px!important;overflow:visible!important;z-index:100!important;}
body:has(.prompter-page) .font-picker .control-label{display:none!important;}
body:has(.prompter-page) .font-picker-trigger{min-height:38px!important;border-radius:999px!important;padding:0 10px!important;}
body:has(.prompter-page) .font-picker-current{font-size:11px!important;}
body:has(.prompter-page) .control-range{order:9!important;flex:0 0 auto!important;min-width:auto!important;padding:6px 10px!important;border-radius:18px!important;font-size:10px!important;font-weight:700;gap:2px!important;}
body:has(.prompter-page) .control-range input[type="range"]{margin-top:2px!important;}
body:has(.prompter-page) .reset-controls{order:10!important;flex:0 0 auto!important;grid-column:auto!important;min-height:40px!important;border-radius:999px!important;font-size:10px!important;font-weight:700;padding:0 12px!important;white-space:nowrap!important;}
body:has(.prompter-page) .font-picker-menu{bottom:calc(100% + 8px)!important;left:50%!important;right:auto!important;width:200px!important;z-index:9999!important;transform:translateX(-50%)!important;}
body:has(.prompter-page) .prompt-control-panel::-webkit-scrollbar{height:0!important;width:0!important;}
body:has(.prompter-page).controls-hidden.show-dock-hint .dock-reminder-global{bottom:72px!important;}

/* Final compact-bar overrides: flatten nested button grid into the single row */
body:has(.prompter-page) .prompt-control-panel .prompt-control-title{display:none!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-buttons{display:contents!important;width:auto!important;height:auto!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .btn{width:auto!important;min-width:72px!important;max-width:110px!important;height:40px!important;min-height:40px!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons [data-action="fullscreen"]{min-width:92px!important;}

/* Fit every control inside one visible row on desktop */
body:has(.prompter-page) .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .prompt-control-topline{display:block!important;}
body:has(.prompter-page) .prompt-control-panel:hover .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:focus-within .prompt-control-topline,
body:has(.prompter-page) .controls-dock-open .prompt-control-panel .prompt-control-topline{display:none!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .btn{min-width:58px!important;max-width:92px!important;padding:0 8px!important;font-size:8px!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .start-button,
body:has(.prompter-page) .prompt-control-panel .prompt-buttons .stop-button{min-width:68px!important;}
body:has(.prompter-page) .prompt-control-panel .prompt-buttons [data-action="fullscreen"]{min-width:82px!important;}
body:has(.prompter-page) .font-control{flex-basis:96px!important;min-width:96px!important;}
body:has(.prompter-page) .control-range{flex-basis:78px!important;min-width:78px!important;padding:5px 6px!important;font-size:6px!important;}
body:has(.prompter-page) .reset-controls{flex-basis:78px!important;min-width:78px!important;font-size:7px!important;padding:0 7px!important;}
body:has(.prompter-page).controls-dock-open .prompt-control-panel .prompt-control-topline,
body:has(.prompter-page).controls-dock-open .prompt-control-panel .prompt-control-title,
body:has(.prompter-page) .prompt-control-panel:hover .prompt-control-title,
body:has(.prompter-page) .prompt-control-panel:focus-within .prompt-control-title{display:none!important;width:0!important;min-width:0!important;flex-basis:0!important;overflow:hidden!important;opacity:0!important;}

body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel{left:50%!important;right:auto!important;top:auto!important;bottom:12px!important;width:min(360px,calc(100vw - 18px))!important;min-height:52px!important;max-height:52px!important;display:flex!important;align-items:center!important;justify-content:center!important;transform:translateX(-50%)!important;}
body:has(.prompter-page).is-playing.controls-hidden.dock-hover-suppressed .prompt-control-panel .prompt-control-topline .btn{writing-mode:horizontal-tb!important;text-orientation:mixed!important;min-height:40px!important;border-radius:999px!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel{left:50%!important;right:auto!important;top:auto!important;bottom:12px!important;width:min(360px,calc(100vw - 18px))!important;min-height:52px!important;max-height:52px!important;display:flex!important;align-items:center!important;justify-content:center!important;transform:translateX(-50%)!important;overflow:hidden!important;border-radius:999px!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel > *:not(.prompt-control-topline){display:none!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel .prompt-control-topline{display:block!important;width:100%!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel .prompt-control-topline .btn{writing-mode:horizontal-tb!important;text-orientation:mixed!important;min-height:40px!important;border-radius:999px!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within){left:50%!important;right:auto!important;top:auto!important;bottom:12px!important;width:min(360px,calc(100vw - 18px))!important;min-height:52px!important;max-height:52px!important;display:flex!important;align-items:center!important;justify-content:center!important;transform:translateX(-50%)!important;overflow:hidden!important;border-radius:999px!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) .prompt-control-topline{display:block!important;width:100%!important;}
body:has(.prompter-page).is-playing.controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) .prompt-control-topline .btn{writing-mode:horizontal-tb!important;text-orientation:mixed!important;min-height:40px!important;border-radius:999px!important;}

/* === REDESIGNED BOTTOM CONTROL BAR (single row, no scroll) === */
body:has(.prompter-page) .prompt-control-panel {
  position: fixed !important;
  left: 50% !important;
  bottom: 12px !important;
  width: min(980px, calc(100vw - 24px)) !important;
  height: auto !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  transform: translateX(-50%) !important;
  background: rgba(8, 10, 14, 0.92) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.60) !important;
}

/* Collapsed state during playback */
body:has(.prompter-page).controls-hidden .prompt-control-panel {
  width: min(320px, calc(100vw - 24px)) !important;
  height: 48px !important;
  padding: 6px 10px !important;
}

/* Topline toggle button */
body:has(.prompter-page) .prompt-control-topline {
  flex: 0 0 auto !important;
  display: block !important;
}
body:has(.prompter-page) .prompt-control-topline .btn {
  min-height: 36px !important;
  height: 36px !important;
  width: auto !important;
  padding: 0 12px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
}

/* Buttons row */
body:has(.prompter-page) .prompt-buttons {
  display: flex !important;
  flex-direction: row !important;
  gap: 6px !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
}
body:has(.prompter-page) .prompt-buttons .btn {
  min-height: 36px !important;
  height: 36px !important;
  padding: 0 12px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  color: rgba(255, 255, 255, 0.88) !important;
}
body:has(.prompter-page) .prompt-buttons .btn:hover {
  background: rgba(255, 255, 255, 0.10) !important;
  border-color: rgba(255, 255, 255, 0.20) !important;
}
body:has(.prompter-page) .prompt-buttons .start-stop-btn {
  background: rgba(128, 104, 255, 0.75) !important;
  border-color: rgba(157, 140, 255, 0.35) !important;
  color: #fff !important;
}
body:has(.prompter-page) .prompt-buttons .start-stop-btn:hover {
  background: rgba(128, 104, 255, 0.90) !important;
}
body:has(.prompter-page) .prompt-buttons .cyan {
  background: rgba(79, 232, 255, 0.15) !important;
  border-color: rgba(79, 232, 255, 0.30) !important;
  color: #e8f4ff !important;
}

/* Font picker in bar */
body:has(.prompter-page) .font-control {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 8px !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.04) !important;
  overflow: visible !important;
  z-index: 100 !important;
}
body:has(.prompter-page) .font-control .control-label {
  font-size: 10px !important;
  color: rgba(255, 255, 255, 0.60) !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .font-control select {
  min-height: 34px !important;
  height: 34px !important;
  padding: 0 28px 0 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border-radius: 999px !important;
  background: rgba(0, 0, 0, 0.35) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  color: #fff !important;
}

/* Sliders */
body:has(.prompter-page) .control-range {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 8px !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.04) !important;
}
body:has(.prompter-page) .control-range .control-label {
  font-size: 10px !important;
  color: rgba(255, 255, 255, 0.60) !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .control-range input[type="range"] {
  width: 80px !important;
  height: 6px !important;
  margin-top: 0 !important;
}

/* Reset button */
body:has(.prompter-page) .reset-controls {
  min-height: 34px !important;
  height: 34px !important;
  padding: 0 12px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  color: rgba(255, 255, 255, 0.70) !important;
}

/* Font picker menu positioning */
body:has(.prompter-page) .font-picker-menu {
  position: absolute !important;
  bottom: calc(100% + 8px) !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 200px !important;
  z-index: 999 !important;
}

/* Hide title bar */
body:has(.prompter-page) .prompt-control-title {
  display: none !important;
}

/* Dock hint during playback */
body:has(.prompter-page).is-playing .dock-reminder-global {
  bottom: 64px !important;
  top: auto !important;
  transform: translateY(0) !important;
  font-size: 12px !important;
}

/* Hover state during playback - expand smoothly */
body:has(.prompter-page).is-playing.controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).is-playing.controls-hidden .prompt-control-panel:focus-within {
  width: min(980px, calc(100vw - 24px)) !important;
  height: auto !important;
  max-height: none !important;
}

/* Mobile responsive */
@media (max-width: 768px) {
  body:has(.prompter-page) .prompt-control-panel {
    width: calc(100vw - 16px) !important;
    gap: 4px !important;
    padding: 4px 8px !important;
  }
  body:has(.prompter-page) .prompt-buttons .btn,
  body:has(.prompter-page) .prompt-control-topline .btn {
    font-size: 10px !important;
    min-height: 32px !important;
    height: 32px !important;
    padding: 0 8px !important;
  }
  body:has(.prompter-page) .control-range input[type="range"] {
    width: 60px !important;
  }
}

/* === Final Show controls dock fix: collapsed pill + stable expanded bar === */
body:has(.prompter-page) .prompt-control-panel {
  overflow-x: hidden !important;
  overflow-y: visible !important;
}
body:has(.prompter-page) .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:hover .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:focus-within .prompt-control-topline,
body:has(.prompter-page).controls-dock-open .prompt-control-panel .prompt-control-topline {
  display: block !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 112px !important;
  opacity: 1 !important;
  overflow: visible !important;
}
body:has(.prompter-page) .prompt-control-topline .btn {
  white-space: nowrap !important;
  min-width: 112px !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) {
  width: min(360px, calc(100vw - 24px)) !important;
  height: 48px !important;
  min-height: 48px !important;
  max-height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) > *:not(.prompt-control-topline),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) > *:not(.prompt-control-topline) {
  display: none !important;
}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  width: min(980px, calc(100vw - 24px)) !important;
  height: auto !important;
  min-height: 48px !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel > *:not(.dock-reminder),
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover > *:not(.dock-reminder),
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within > *:not(.dock-reminder) {
  display: flex !important;
}
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-buttons {
  display: flex !important;
}
body:has(.prompter-page) .prompt-control-panel::-webkit-scrollbar { width: 0 !important; height: 0 !important; }

/* === Final desktop fit pass: no clipped controls at 1280px === */
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  width: min(1264px, calc(100vw - 8px)) !important;
  gap: 4px !important;
  padding: 5px 6px !important;
  box-sizing: border-box !important;
}
body:has(.prompter-page) .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:hover .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:focus-within .prompt-control-topline,
body:has(.prompter-page).controls-dock-open .prompt-control-panel .prompt-control-topline {
  min-width: 96px !important;
  flex: 0 0 96px !important;
}
body:has(.prompter-page) .prompt-control-topline .btn { min-width: 96px !important; padding: 0 9px !important; font-size: 10px !important; }
body:has(.prompter-page) .prompt-buttons { gap: 4px !important; }
body:has(.prompter-page) .prompt-buttons .btn {
  min-width: 62px !important;
  max-width: 82px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 7px !important;
  font-size: 10px !important;
}
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"] { min-width: 82px !important; }
body:has(.prompter-page) .font-control { padding: 4px 5px !important; gap: 4px !important; }
body:has(.prompter-page) .font-picker-trigger { min-height: 34px !important; padding: 0 8px !important; }
body:has(.prompter-page) .font-picker-current { font-size: 10px !important; }
body:has(.prompter-page) .font-picker-chev { width: 20px !important; height: 20px !important; }
body:has(.prompter-page) .control-range { padding: 4px 5px !important; gap: 4px !important; font-size: 10px !important; }
body:has(.prompter-page) .control-range .control-label { font-size: 10px !important; }
body:has(.prompter-page) .control-range input[type="range"] { width: 60px !important; }
body:has(.prompter-page) .reset-controls {
  min-width: 92px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 8px !important;
  font-size: 10px !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) {
  width: min(360px, calc(100vw - 24px)) !important;
  gap: 0 !important;
  padding: 6px 10px !important;
}

/* === Final no-overflow pass: compact slider tracks fit full bar === */
body:has(.prompter-page) .control-range input[type="range"] { width: 44px !important; }
body:has(.prompter-page) .control-range { gap: 3px !important; padding-left: 4px !important; padding-right: 4px !important; }
body:has(.prompter-page) .font-control { padding-left: 4px !important; padding-right: 4px !important; }
body:has(.prompter-page) .prompt-buttons .btn { min-width: 58px !important; max-width: 78px !important; padding-left: 6px !important; padding-right: 6px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"] { min-width: 78px !important; }

/* === Tiny final shave: eliminate remaining computed overflow === */
body:has(.prompter-page) .control-range input[type="range"] { width: 38px !important; }
body:has(.prompter-page) .prompt-buttons .btn { min-width: 54px !important; max-width: 74px !important; font-size: 9.5px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"] { min-width: 74px !important; }
body:has(.prompter-page) .reset-controls { min-width: 88px !important; }
body:has(.prompter-page) .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:hover .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:focus-within .prompt-control-topline,
body:has(.prompter-page).controls-dock-open .prompt-control-panel .prompt-control-topline {
  min-width: 92px !important;
  flex-basis: 92px !important;
}
body:has(.prompter-page) .prompt-control-topline .btn { min-width: 92px !important; }

/* === Exact no-overflow final: remove last 7px computed excess === */
body:has(.prompter-page) .control-range input[type="range"] { width: 36px !important; }
body:has(.prompter-page) .prompt-buttons .btn { min-width: 52px !important; max-width: 72px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"] { min-width: 72px !important; }

/* === Full-width bottom controls: remove floating pill layout === */
body:has(.prompter-page) .prompt-stage {
  padding-bottom: 190px !important;
}

body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  top: auto !important;
  width: 100vw !important;
  max-width: none !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 122px !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px 12px !important;
  overflow: visible !important;
  padding: 12px 18px 14px !important;
  border-radius: 0 !important;
  transform: none !important;
  background: linear-gradient(180deg, rgba(9,11,16,.78), rgba(0,0,0,.96)) !important;
  border: 0 !important;
  border-top: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 -22px 70px rgba(0,0,0,.72), inset 0 1px 0 rgba(255,255,255,.05) !important;
  backdrop-filter: blur(18px) !important;
  box-sizing: border-box !important;
}

body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) {
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 58px !important;
  min-height: 58px !important;
  max-height: 58px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  padding: 8px 18px !important;
  border-radius: 0 !important;
  transform: none !important;
}

body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) > *:not(.prompt-control-topline),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) > *:not(.prompt-control-topline) {
  display: none !important;
}

body:has(.prompter-page) .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:hover .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel:focus-within .prompt-control-topline,
body:has(.prompter-page).controls-dock-open .prompt-control-panel .prompt-control-topline {
  order: 1 !important;
  flex: 0 0 auto !important;
  min-width: 132px !important;
  width: auto !important;
  display: block !important;
  opacity: 1 !important;
  overflow: visible !important;
}
body:has(.prompter-page) .prompt-control-topline .btn {
  height: 40px !important;
  min-height: 40px !important;
  min-width: 132px !important;
  padding: 0 16px !important;
  border-radius: 12px !important;
  font-size: 11px !important;
  white-space: nowrap !important;
}

body:has(.prompter-page) .prompt-buttons,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-buttons {
  order: 2 !important;
  display: flex !important;
  flex: 0 1 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 8px !important;
}
body:has(.prompter-page) .prompt-buttons .btn {
  width: auto !important;
  min-width: 92px !important;
  max-width: none !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 14px !important;
  border-radius: 12px !important;
  font-size: 11px !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .prompt-buttons .start-stop-btn { min-width: 104px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"] { min-width: 118px !important; }

body:has(.prompter-page) .font-control {
  order: 3 !important;
  flex: 0 0 180px !important;
  min-width: 180px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 7px 10px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.045) !important;
  overflow: visible !important;
  z-index: 100 !important;
}
body:has(.prompter-page) .font-picker .control-label { display: inline !important; font-size: 11px !important; }
body:has(.prompter-page) .font-picker-trigger {
  min-height: 38px !important;
  padding: 0 12px !important;
  border-radius: 12px !important;
}
body:has(.prompter-page) .font-picker-current { font-size: 12px !important; }
body:has(.prompter-page) .font-picker-menu {
  bottom: calc(100% + 12px) !important;
  left: 50% !important;
  right: auto !important;
  width: 220px !important;
  transform: translateX(-50%) !important;
  z-index: 9999 !important;
}

body:has(.prompter-page) .control-range {
  order: 4 !important;
  flex: 0 1 160px !important;
  min-width: 142px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 7px 10px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.045) !important;
  font-size: 11px !important;
}
body:has(.prompter-page) .control-range .control-label,
body:has(.prompter-page) label.control-range {
  font-size: 11px !important;
  color: rgba(255,255,255,.70) !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .control-range input[type="range"] {
  width: 86px !important;
  min-width: 86px !important;
}

body:has(.prompter-page) .reset-controls {
  order: 5 !important;
  flex: 0 0 auto !important;
  min-width: 132px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: 12px !important;
  font-size: 11px !important;
  white-space: nowrap !important;
}

body:has(.prompter-page) .prompt-control-title,
body:has(.prompter-page) .dock-reminder { display: none !important; }
body:has(.prompter-page) .prompt-control-panel::-webkit-scrollbar { width: 0 !important; height: 0 !important; }

@media(max-width: 920px) {
  body:has(.prompter-page) .prompt-stage { padding-bottom: 280px !important; }
  body:has(.prompter-page) .prompt-control-panel,
  body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
  body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
  body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
    justify-content: flex-start !important;
    max-height: 45vh !important;
    overflow-y: auto !important;
  }
  body:has(.prompter-page) .prompt-buttons { flex-wrap: wrap !important; }
  body:has(.prompter-page) .control-range { flex: 1 1 170px !important; }
}

/* === Full bottom console refinement: clean two-row layout === */
body:has(.prompter-page) .prompt-stage { padding-bottom: 205px !important; }
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  min-height: 152px !important;
  display: grid !important;
  grid-template-columns: 132px repeat(4, minmax(92px, auto)) 190px !important;
  grid-auto-rows: minmax(42px, auto) !important;
  align-content: center !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  padding: 16px 20px !important;
}
body:has(.prompter-page) .prompt-control-topline { grid-column: 1 !important; grid-row: 1 !important; min-width: 132px !important; }
body:has(.prompter-page) .prompt-buttons,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover .prompt-buttons,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within .prompt-buttons {
  display: contents !important;
}
body:has(.prompter-page) .prompt-buttons .start-stop-btn { grid-column: 2 !important; grid-row: 1 !important; min-width: 92px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="mirror"] { grid-column: 3 !important; grid-row: 1 !important; min-width: 92px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"] { grid-column: 4 !important; grid-row: 1 !important; min-width: 116px !important; }
body:has(.prompter-page) .prompt-buttons [data-action="close-prompt-page"] { grid-column: 5 !important; grid-row: 1 !important; min-width: 92px !important; }
body:has(.prompter-page) .font-control { grid-column: 6 !important; grid-row: 1 !important; min-width: 190px !important; width: 190px !important; }
body:has(.prompter-page) .prompt-buttons .btn,
body:has(.prompter-page) .reset-controls,
body:has(.prompter-page) .prompt-control-topline .btn { height: 42px !important; min-height: 42px !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  grid-row: 2 !important;
  min-width: 176px !important;
  width: 176px !important;
  flex: none !important;
  justify-content: space-between !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(1) { grid-column: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(2) { grid-column: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(3) { grid-column: 3 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(4) { grid-column: 4 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(5) { grid-column: 5 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(6) { grid-column: 6 !important; }
body:has(.prompter-page) .control-range input[type="range"] { width: 76px !important; min-width: 76px !important; }
body:has(.prompter-page) .reset-controls {
  grid-column: 1 / -1 !important;
  grid-row: 3 !important;
  justify-self: center !important;
  min-width: 160px !important;
  width: 160px !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) {
  min-height: 58px !important;
  height: 58px !important;
  display: flex !important;
}
@media(max-width:1180px){
  body:has(.prompter-page) .prompt-control-panel,
  body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
  body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
  body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within{
    grid-template-columns: repeat(4, minmax(0, auto)) !important;
    min-height: 210px !important;
  }
  body:has(.prompter-page) .prompt-stage { padding-bottom: 260px !important; }
  body:has(.prompter-page) .prompt-control-topline{grid-column:1!important;grid-row:1!important}
  body:has(.prompter-page) .prompt-buttons .start-stop-btn{grid-column:2!important;grid-row:1!important}
  body:has(.prompter-page) .prompt-buttons [data-action="mirror"]{grid-column:3!important;grid-row:1!important}
  body:has(.prompter-page) .prompt-buttons [data-action="fullscreen"]{grid-column:4!important;grid-row:1!important}
  body:has(.prompter-page) .prompt-buttons [data-action="close-prompt-page"]{grid-column:1!important;grid-row:2!important}
  body:has(.prompter-page) .font-control{grid-column:2/4!important;grid-row:2!important;width:220px!important;min-width:220px!important}
  body:has(.prompter-page) .prompt-control-panel > label.control-range{grid-row:auto!important;grid-column:auto!important}
}

/* === Grid specificity fix for full-width bottom console === */
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline {
  grid-column: 1 !important;
  grid-row: 1 !important;
  min-width: 132px !important;
  width: 132px !important;
  flex-basis: auto !important;
}
body:has(.prompter-page) .prompt-control-panel > .font-control {
  grid-column: 6 !important;
  grid-row: 1 !important;
  min-width: 190px !important;
  width: 190px !important;
  flex-basis: auto !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons {
  display: contents !important;
  grid-column: auto !important;
  grid-row: auto !important;
  width: auto !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-width: 92px !important;
  width: 92px !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="mirror"] {
  grid-column: 3 !important;
  grid-row: 1 !important;
  min-width: 92px !important;
  width: 92px !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="fullscreen"] {
  grid-column: 4 !important;
  grid-row: 1 !important;
  min-width: 116px !important;
  width: 116px !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"] {
  grid-column: 5 !important;
  grid-row: 1 !important;
  min-width: 92px !important;
  width: 92px !important;
}
body:has(.prompter-page) .prompt-control-panel > .reset-controls {
  grid-column: 1 / -1 !important;
  grid-row: 3 !important;
  justify-self: center !important;
  min-width: 160px !important;
  width: 160px !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(1) { grid-column: 1 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(2) { grid-column: 2 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(3) { grid-column: 3 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(4) { grid-column: 4 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(5) { grid-column: 5 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(6) { grid-column: 6 !important; grid-row: 2 !important; }

body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) > .prompt-control-topline,
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) > .prompt-control-topline {
  display: block !important;
  width: 132px !important;
}

/* === Full bottom console final grid: equal wide cells prevent slider overlap === */
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  grid-template-columns: repeat(6, 176px) !important;
  grid-auto-rows: minmax(42px, auto) !important;
  justify-content: center !important;
  gap: 12px !important;
  min-height: 202px !important;
}
body:has(.prompter-page) .prompt-stage { padding-bottom: 250px !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="mirror"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="fullscreen"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"],
body:has(.prompter-page) .prompt-control-panel > .font-control,
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  width: 176px !important;
  min-width: 176px !important;
  max-width: 176px !important;
  box-sizing: border-box !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline { grid-column: 1 !important; grid-row: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn { grid-column: 2 !important; grid-row: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="mirror"] { grid-column: 3 !important; grid-row: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="fullscreen"] { grid-column: 4 !important; grid-row: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"] { grid-column: 5 !important; grid-row: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > .font-control { grid-column: 6 !important; grid-row: 1 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(1) { grid-column: 1 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(2) { grid-column: 2 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(3) { grid-column: 3 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(4) { grid-column: 4 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(5) { grid-column: 5 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(6) { grid-column: 6 !important; grid-row: 2 !important; }
body:has(.prompter-page) .prompt-control-panel > .reset-controls { grid-column: 3 / 5 !important; grid-row: 3 !important; justify-self: center !important; width: 180px !important; min-width: 180px !important; }
body:has(.prompter-page) .control-range input[type="range"] { width: 78px !important; min-width: 78px !important; }
body:has(.prompter-page) .prompt-control-topline .btn { width: 100% !important; min-width: 0 !important; }
body:has(.prompter-page) .prompt-buttons .btn { width: 100% !important; min-width: 0 !important; max-width: none !important; }
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) {
  min-height: 58px !important;
  height: 58px !important;
  display: flex !important;
}

/* === Remove inner Show Controls pill + larger button text === */
body:has(.prompter-page) .prompt-control-topline .btn,
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .prompt-control-topline .btn,
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) .prompt-control-topline .btn {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  color: rgba(255,255,255,.88) !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  min-width: 0 !important;
  width: auto !important;
  padding: 0 4px !important;
}
body:has(.prompter-page) .prompt-control-topline .btn:hover,
body:has(.prompter-page) .prompt-control-topline .btn:focus-visible {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff !important;
  transform: none !important;
  outline: 0 !important;
}
body:has(.prompter-page) .prompt-buttons .btn,
body:has(.prompter-page) .reset-controls {
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
}
body:has(.prompter-page) .font-picker-current,
body:has(.prompter-page) .font-picker .control-label,
body:has(.prompter-page) .control-range .control-label,
body:has(.prompter-page) label.control-range {
  font-size: 13px !important;
  font-weight: 850 !important;
}
body:has(.prompter-page) .font-picker-menu button {
  font-size: 14px !important;
}

/* === Strong final override: larger teleprompter action button fonts === */
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .btn,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="mirror"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="fullscreen"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"] {
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
  line-height: 1 !important;
}
body:has(.prompter-page) .prompt-control-panel > .reset-controls {
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
}

/* === Grey/blue console palette + flat sliders + non-glow Back === */
body:has(.prompter-page) {
  --violet: #3b82f6;
  --violet2: #60a5fa;
  --cyan: #38bdf8;
  --cyan2: #0ea5e9;
}

body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  background: linear-gradient(180deg, rgba(14, 18, 24, .86), rgba(2, 6, 12, .96)) !important;
  border-top: 1px solid rgba(148, 163, 184, .22) !important;
  box-shadow: 0 -20px 64px rgba(0,0,0,.68), inset 0 1px 0 rgba(255,255,255,.045) !important;
}

body:has(.prompter-page) .prompt-buttons .start-stop-btn,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn {
  background: linear-gradient(180deg, #2563eb, #1d4ed8) !important;
  border-color: rgba(96, 165, 250, .50) !important;
  color: #eff6ff !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14) !important;
}
body:has(.prompter-page) .prompt-buttons .start-stop-btn:hover,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn:hover {
  background: linear-gradient(180deg, #3b82f6, #2563eb) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16) !important;
}

body:has(.prompter-page) .prompt-buttons .btn,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .btn {
  background: linear-gradient(180deg, rgba(31,41,55,.90), rgba(15,23,42,.88)) !important;
  border-color: rgba(148, 163, 184, .22) !important;
  color: #e5edf8 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07) !important;
}
body:has(.prompter-page) .prompt-buttons .btn:hover,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .btn:hover {
  background: linear-gradient(180deg, rgba(51,65,85,.94), rgba(30,41,59,.92)) !important;
  border-color: rgba(96, 165, 250, .36) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09) !important;
}

body:has(.prompter-page) .prompt-buttons .cyan,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"] {
  background: linear-gradient(180deg, #334155, #1e293b) !important;
  border-color: rgba(59, 130, 246, .45) !important;
  color: #bfdbfe !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
  text-shadow: none !important;
}
body:has(.prompter-page) .prompt-buttons .cyan:hover,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"]:hover {
  background: linear-gradient(180deg, #3b4a5f, #263449) !important;
  border-color: rgba(96, 165, 250, .62) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10) !important;
}

body:has(.prompter-page) .font-control {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
body:has(.prompter-page) .font-picker-trigger {
  background: linear-gradient(180deg, rgba(15,23,42,.92), rgba(2,6,23,.92)) !important;
  border-color: rgba(148, 163, 184, .24) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06) !important;
}
body:has(.prompter-page) .font-picker-trigger:hover,
body:has(.prompter-page) .font-picker-trigger[aria-expanded="true"] {
  border-color: rgba(96, 165, 250, .48) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
}
body:has(.prompter-page) .font-picker-chev {
  background: rgba(51,65,85,.82) !important;
  color: #bfdbfe !important;
}
body:has(.prompter-page) .font-picker-menu {
  background: linear-gradient(180deg, rgba(15,23,42,.98), rgba(2,6,23,.98)) !important;
  border-color: rgba(148, 163, 184, .24) !important;
  box-shadow: 0 22px 55px rgba(0,0,0,.62) !important;
}
body:has(.prompter-page) .font-picker-menu button.is-active {
  background: linear-gradient(135deg, rgba(37,99,235,.30), rgba(14,165,233,.18)) !important;
  border-color: rgba(96,165,250,.42) !important;
}
body:has(.prompter-page) .font-picker-menu button.is-active::after { color: #7dd3fc !important; }

body:has(.prompter-page) .prompt-control-panel > label.control-range,
body:has(.prompter-page) .control-range {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  border-radius: 0 !important;
}
body:has(.prompter-page) .control-range .control-label,
body:has(.prompter-page) label.control-range {
  color: rgba(226, 232, 240, .78) !important;
}
body:has(.prompter-page) .control-range input[type="range"]::-webkit-slider-runnable-track {
  height: 6px !important;
  background: linear-gradient(90deg, #2563eb, #e2e8f0) !important;
}
body:has(.prompter-page) .control-range input[type="range"]::-webkit-slider-thumb {
  background: #60a5fa !important;
  box-shadow: 0 0 0 2px rgba(2,6,23,.92) !important;
}
body:has(.prompter-page) .control-range input[type="range"]::-moz-range-track {
  height: 6px !important;
  background: linear-gradient(90deg, #2563eb, #e2e8f0) !important;
}
body:has(.prompter-page) .control-range input[type="range"]::-moz-range-thumb {
  background: #60a5fa !important;
  box-shadow: 0 0 0 2px rgba(2,6,23,.92) !important;
}

body:has(.prompter-page) .reset-controls {
  background: transparent !important;
  border-color: rgba(148, 163, 184, .30) !important;
  color: #cbd5e1 !important;
  box-shadow: none !important;
}
body:has(.prompter-page) .reset-controls:hover {
  background: rgba(30, 41, 59, .52) !important;
  border-color: rgba(96, 165, 250, .42) !important;
  color: #e5edf8 !important;
  box-shadow: none !important;
}

/* === Final palette specificity: keep Start blue, Back grey-blue no glow === */
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="play"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn.btn.primary {
  background: linear-gradient(180deg, #2563eb, #1d4ed8) !important;
  border-color: rgba(96, 165, 250, .50) !important;
  color: #eff6ff !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14) !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="play"]:hover,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn.btn.primary:hover {
  background: linear-gradient(180deg, #3b82f6, #2563eb) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16) !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .cyan {
  background: linear-gradient(180deg, #334155, #1e293b) !important;
  border-color: rgba(59, 130, 246, .45) !important;
  color: #bfdbfe !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
  text-shadow: none !important;
}

/* === Slider spacing fix: label left, full slider right, no collisions === */
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  grid-template-columns: repeat(6, 186px) !important;
  gap: 12px 10px !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .start-stop-btn,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="mirror"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="fullscreen"],
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"],
body:has(.prompter-page) .prompt-control-panel > .font-control,
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  width: 186px !important;
  min-width: 186px !important;
  max-width: 186px !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  display: grid !important;
  grid-template-columns: 86px 1fr !important;
  align-items: center !important;
  column-gap: 10px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  line-height: 1 !important;
  text-align: left !important;
  overflow: visible !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range,
body:has(.prompter-page) .prompt-control-panel > label.control-range .control-label {
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
  color: rgba(226,232,240,.82) !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range input[type="range"] {
  width: 90px !important;
  min-width: 90px !important;
  max-width: 90px !important;
  justify-self: end !important;
  margin: 0 !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(3) {
  grid-template-columns: 104px 1fr !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(3) input[type="range"] {
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(5) {
  grid-template-columns: 100px 1fr !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(5) input[type="range"] {
  width: 76px !important;
  min-width: 76px !important;
  max-width: 76px !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(6) {
  grid-template-columns: 96px 1fr !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:nth-of-type(6) input[type="range"] {
  width: 80px !important;
  min-width: 80px !important;
  max-width: 80px !important;
}

/* === Hephaestus fix: font picker + aligned controls === */
body:has(.prompter-page) .font-picker-chev { display: none !important; }

/* Hide the old external hover hint; collapsed bottom bar already communicates the action. */
body:has(.prompter-page) .dock-reminder-global,
body:has(.prompter-page).controls-hidden.show-dock-hint .dock-reminder-global {
  display: none !important;
}

/* Keep collapsed Show Controls perfectly centered in the full-width bottom dock. */
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open),
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 58px !important;
  min-height: 58px !important;
  max-height: 58px !important;
  padding: 0 !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) > .prompt-control-topline,
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) > .prompt-control-topline {
  width: auto !important;
  min-width: 0 !important;
  display: block !important;
  justify-self: center !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .prompt-control-topline .btn,
body:has(.prompter-page).controls-hidden:not(.controls-dock-open) .prompt-control-panel:not(:hover):not(:focus-within) .prompt-control-topline .btn {
  width: auto !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  font-size: 16px !important;
  line-height: 58px !important;
}

/* Expanded console: align every slider label + range on the same grid. */
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  grid-template-columns: repeat(6, 184px) !important;
  gap: 12px !important;
  min-height: 202px !important;
  padding: 18px 20px !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .btn,
body:has(.prompter-page) .prompt-control-panel > .font-control,
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  width: 184px !important;
  min-width: 184px !important;
  max-width: 184px !important;
  box-sizing: border-box !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  display: grid !important;
  grid-template-columns: 92px 78px !important;
  column-gap: 10px !important;
  align-items: center !important;
  justify-items: stretch !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  line-height: 1 !important;
  text-align: left !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range,
body:has(.prompter-page) .prompt-control-panel > label.control-range .control-label {
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
  color: rgba(226,232,240,.76) !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range input[type="range"] {
  grid-column: 2 !important;
  width: 78px !important;
  min-width: 78px !important;
  max-width: 78px !important;
  margin: 0 !important;
  justify-self: end !important;
  align-self: center !important;
}

/* Font picker: no chevron space, clean button, menu remains usable. */
body:has(.prompter-page) .font-control {
  display: grid !important;
  grid-template-columns: 42px 1fr !important;
  column-gap: 10px !important;
  align-items: center !important;
}
body:has(.prompter-page) .font-picker .control-label {
  display: block !important;
  font-size: 11px !important;
  color: rgba(226,232,240,.76) !important;
}
body:has(.prompter-page) .font-picker-trigger {
  justify-content: center !important;
  padding: 0 12px !important;
}
body:has(.prompter-page) .font-picker-current {
  text-align: center !important;
  font-size: 13px !important;
}

/* Wider desktop grid needs a touch more breathing room above the bottom dock. */
body:has(.prompter-page) .prompt-stage { padding-bottom: 255px !important; }

/* === Slider controls: each title + slider in its own aligned box === */
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  column-gap: 12px !important;
  align-items: center !important;
  justify-items: stretch !important;
  width: 184px !important;
  min-width: 184px !important;
  max-width: 184px !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 12px !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  border-radius: 12px !important;
  background: rgba(15, 23, 42, .56) !important;
  border: 1px solid rgba(148, 163, 184, .18) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.045) !important;
  text-align: left !important;
  line-height: 1 !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range,
body:has(.prompter-page) .prompt-control-panel > label.control-range .control-label {
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .025em !important;
  color: rgba(226,232,240,.80) !important;
  white-space: nowrap !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range input[type="range"] {
  grid-column: 2 !important;
  width: 78px !important;
  min-width: 78px !important;
  max-width: 78px !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-self: end !important;
  align-self: center !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range:hover {
  background: rgba(30, 41, 59, .64) !important;
  border-color: rgba(96, 165, 250, .26) !important;
}

/* === Slider box internal spacing polish === */
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  grid-template-columns: 1fr 76px !important;
  column-gap: 10px !important;
  width: 196px !important;
  min-width: 196px !important;
  max-width: 196px !important;
  padding: 0 14px 0 16px !important;
  overflow: hidden !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range input[type="range"] {
  width: 76px !important;
  min-width: 76px !important;
  max-width: 76px !important;
}
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  grid-template-columns: repeat(6, 196px) !important;
  gap: 10px !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .btn,
body:has(.prompter-page) .prompt-control-panel > .font-control {
  width: 196px !important;
  min-width: 196px !important;
  max-width: 196px !important;
}
/* Keep long labels readable without touching borders. */
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  font-size: 10.5px !important;
  letter-spacing: .012em !important;
}

/* === Stable Hide Controls: collapse lock prevents instant hover-reopen === */
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel:focus-within {
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  top: auto !important;
  width: 100vw !important;
  height: 58px !important;
  min-height: 58px !important;
  max-height: 58px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  padding: 0 !important;
  border-radius: 0 !important;
  transform: none !important;
}
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel > *:not(.prompt-control-topline),
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel:hover > *:not(.prompt-control-topline),
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel:focus-within > *:not(.prompt-control-topline) {
  display: none !important;
}
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel:hover > .prompt-control-topline,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-panel:focus-within > .prompt-control-topline {
  display: block !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
}
body:has(.prompter-page).controls-hidden.controls-collapse-locked .prompt-control-topline .btn {
  width: auto !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  line-height: 58px !important;
  font-size: 16px !important;
}

/* === Prompt date/time overlay + controls === */
body:has(.prompter-page) .prompt-date-time {
  position: fixed;
  z-index: 8;
  padding: 10px 14px;
  border-radius: 12px;
  background: rgba(2, 6, 23, .58);
  border: 1px solid rgba(148, 163, 184, .18);
  color: rgba(226, 232, 240, .82);
  font-size: 24px;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1;
  pointer-events: none;
  backdrop-filter: blur(10px);
  box-shadow: none;
}
body:has(.prompter-page) .prompt-date-time[hidden] { display: none !important; }
body:has(.prompter-page) .prompt-date-time[data-position="top-left"] { top: 22px; left: 22px; }
body:has(.prompter-page) .prompt-date-time[data-position="top-center"] { top: 22px; left: 50%; transform: translateX(-50%); }
body:has(.prompter-page) .prompt-date-time[data-position="top-right"] { top: 24px; right: 28px; }
body:has(.prompter-page) .prompt-date-time[data-position="bottom-left"] { bottom: 270px; left: 22px; }
body:has(.prompter-page) .prompt-date-time[data-position="bottom-center"] { bottom: 270px; left: 50%; transform: translateX(-50%); }
body:has(.prompter-page) .prompt-date-time[data-position="bottom-right"] { bottom: 270px; right: 22px; }

body:has(.prompter-page) .date-time-toggle,
body:has(.prompter-page) .date-time-position {
  display: grid !important;
  align-items: center !important;
  height: 46px !important;
  min-height: 46px !important;
  width: 196px !important;
  min-width: 196px !important;
  max-width: 196px !important;
  margin: 0 !important;
  padding: 0 16px !important;
  box-sizing: border-box !important;
  border-radius: 12px !important;
  background: rgba(15, 23, 42, .56) !important;
  border: 1px solid rgba(148, 163, 184, .18) !important;
  color: rgba(226,232,240,.80) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .025em !important;
  text-transform: uppercase !important;
}
body:has(.prompter-page) .date-time-toggle {
  grid-column: 1 !important;
  grid-row: 3 !important;
  grid-template-columns: 18px 1fr !important;
  column-gap: 10px !important;
}
body:has(.prompter-page) .date-time-toggle input {
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  accent-color: #3b82f6 !important;
}
body:has(.prompter-page) .date-time-position {
  grid-column: 2 / 4 !important;
  grid-row: 3 !important;
  width: 402px !important;
  min-width: 402px !important;
  max-width: 402px !important;
  grid-template-columns: 72px 1fr !important;
  column-gap: 12px !important;
}
body:has(.prompter-page) .date-time-position select {
  width: 100% !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 10px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(148, 163, 184, .22) !important;
  background: rgba(2, 6, 23, .58) !important;
  color: #e2e8f0 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  outline: 0 !important;
}
body:has(.prompter-page) .prompt-control-panel > label.time-size-control {
  grid-column: 4 !important;
  grid-row: 3 !important;
}
body:has(.prompter-page) .date-time-position select:focus {
  border-color: rgba(96, 165, 250, .58) !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .16) !important;
}
body:has(.prompter-page) .prompt-control-panel > .reset-controls {
  grid-column: 5 / 7 !important;
  grid-row: 3 !important;
  justify-self: center !important;
}
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .date-time-toggle,
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .date-time-position,
body:has(.prompter-page).controls-hidden .prompt-control-panel:not(:hover):not(:focus-within):not(.force-open) .time-size-control,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .date-time-toggle,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .date-time-position,
body:has(.prompter-page).controls-hidden.controls-collapse-locked .time-size-control {
  display: none !important;
}
/* START TELEPROMPTER primary action */
.toolbar-actions .btn.start-teleprompter-btn,
.compact-actions .btn.start-teleprompter-btn,
.toolbar-actions .btn[data-action="open-prompt-page"].start-teleprompter-btn,
.compact-actions .btn[data-action="open-prompt-page"].start-teleprompter-btn{
  border-color:rgba(81,231,165,.55);
  color:#03140c;
  background:linear-gradient(135deg,#2bdc87,#8cffc6);
  box-shadow:0 12px 28px rgba(43,220,135,.24), inset 0 1px 0 rgba(255,255,255,.30);
}
.toolbar-actions .btn.start-teleprompter-btn:hover,
.compact-actions .btn.start-teleprompter-btn:hover,
.toolbar-actions .btn.start-teleprompter-btn:focus-visible,
.compact-actions .btn.start-teleprompter-btn:focus-visible{
  border-color:rgba(140,255,198,.82);
  background:linear-gradient(135deg,#35e992,#a5ffd3);
  box-shadow:0 15px 34px rgba(43,220,135,.32), inset 0 1px 0 rgba(255,255,255,.36);
}

/* === Hephaestus intuitive prompt controls layout === */
body:has(.prompter-page) .prompt-control-panel,
body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(150px, 196px)) !important;
  grid-template-areas:
    "toggle start back mirror fullscreen font"
    "speed textsize spacing kerning side top"
    "datetime position position timesize reset reset" !important;
  gap: 10px 12px !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 206px !important;
  padding: 16px 20px !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
}
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline { grid-area: toggle !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons { display: contents !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="play"] { grid-area: start !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="close-prompt-page"] { grid-area: back !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="mirror"] { grid-area: mirror !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > [data-action="fullscreen"] { grid-area: fullscreen !important; }
body:has(.prompter-page) .prompt-control-panel > .font-control { grid-area: font !important; }
body:has(.prompter-page) .prompt-control-panel > .speed-control { grid-area: speed !important; }
body:has(.prompter-page) .prompt-control-panel > .text-size-control { grid-area: textsize !important; }
body:has(.prompter-page) .prompt-control-panel > .text-spacing-control { grid-area: spacing !important; }
body:has(.prompter-page) .prompt-control-panel > .kerning-control { grid-area: kerning !important; }
body:has(.prompter-page) .prompt-control-panel > .side-margin-control { grid-area: side !important; }
body:has(.prompter-page) .prompt-control-panel > .top-margin-control { grid-area: top !important; }
body:has(.prompter-page) .prompt-control-panel > .date-time-toggle { grid-area: datetime !important; }
body:has(.prompter-page) .prompt-control-panel > .date-time-position { grid-area: position !important; }
body:has(.prompter-page) .prompt-control-panel > .time-size-control { grid-area: timesize !important; }
body:has(.prompter-page) .prompt-control-panel > .reset-controls { grid-area: reset !important; }
body:has(.prompter-page) .prompt-control-panel > .prompt-control-topline,
body:has(.prompter-page) .prompt-control-panel > .prompt-buttons > .btn,
body:has(.prompter-page) .prompt-control-panel > .font-control,
body:has(.prompter-page) .prompt-control-panel > label.control-range,
body:has(.prompter-page) .prompt-control-panel > .date-time-toggle,
body:has(.prompter-page) .prompt-control-panel > .date-time-position,
body:has(.prompter-page) .prompt-control-panel > .reset-controls {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  box-sizing: border-box !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  display: grid !important;
  grid-template-columns: minmax(68px, max-content) minmax(0, 1fr) !important;
  column-gap: 10px !important;
  align-items: center !important;
  justify-items: stretch !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 12px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 12px !important;
  background: rgba(15, 23, 42, .56) !important;
  border: 1px solid rgba(148, 163, 184, .18) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.045) !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range .control-label {
  grid-column: 1 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: 10.5px !important;
  font-weight: 900 !important;
  letter-spacing: .012em !important;
  color: rgba(226,232,240,.82) !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range input[type="range"] {
  grid-column: 2 !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-self: stretch !important;
  align-self: center !important;
  box-sizing: border-box !important;
}
body:has(.prompter-page) .font-control {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  column-gap: 10px !important;
}
body:has(.prompter-page) .date-time-position {
  grid-template-columns: 72px minmax(0, 1fr) !important;
}
body:has(.prompter-page) .date-time-toggle,
body:has(.prompter-page) .date-time-position {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}
body:has(.prompter-page) .prompt-stage { padding-bottom: 260px !important; }
@media(max-width: 1180px) {
  body:has(.prompter-page) .prompt-control-panel,
  body:has(.prompter-page).controls-hidden.controls-dock-open .prompt-control-panel,
  body:has(.prompter-page).controls-hidden .prompt-control-panel:hover,
  body:has(.prompter-page).controls-hidden .prompt-control-panel:focus-within {
    grid-template-columns: repeat(3, minmax(150px, 1fr)) !important;
    grid-template-areas:
      "start back toggle"
      "mirror fullscreen font"
      "speed textsize spacing"
      "kerning side top"
      "datetime position timesize"
      "reset reset reset" !important;
    min-height: 348px !important;
  }
  body:has(.prompter-page) .prompt-stage { padding-bottom: 400px !important; }
}
/* Final slider containment guard: override older nth-of-type range widths. */
body:has(.prompter-page) .prompt-control-panel > label.control-range {
  grid-template-columns: minmax(0, 78px) minmax(0, 1fr) !important;
}
body:has(.prompter-page) .prompt-control-panel > label.control-range input#speed,
body:has(.prompter-page) .prompt-control-panel > label.control-range input#font-size,
body:has(.prompter-page) .prompt-control-panel > label.control-range input#line-height,
body:has(.prompter-page) .prompt-control-panel > label.control-range input#letter-spacing,
body:has(.prompter-page) .prompt-control-panel > label.control-range input#side-margin,
body:has(.prompter-page) .prompt-control-panel > label.control-range input#top-margin,
body:has(.prompter-page) .prompt-control-panel > label.control-range input#date-time-size {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  justify-self: stretch !important;
}
/* Back-to-top button lives on the reading stage; Stop no longer jumps scroll. */
body:has(.prompter-page) .back-to-top-btn {
  position: fixed;
  top: 24px;
  left: 24px;
  z-index: 14;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.30);
  background: rgba(15,23,42,.58);
  color: rgba(226,232,240,.88);
  box-shadow: none;
  backdrop-filter: blur(10px);
  font-size: 11px;
}
body:has(.prompter-page) .back-to-top-btn:hover,
body:has(.prompter-page) .back-to-top-btn:focus-visible {
  background: rgba(30,41,59,.78);
  border-color: rgba(96,165,250,.52);
}
/* Sticky Back-to-top: follows prompt scrolling and is JS-gated by stopped/not-top state. */
body:has(.prompter-page) .back-to-top-btn {
  position: sticky !important;
  top: 24px !important;
  left: 24px !important;
  z-index: 14;
  width: max-content;
}
body:has(.prompter-page) .back-to-top-btn[hidden] {
  display: none !important;
}
/* Centered Back-to-top CTA: large, sticky, and only revealed by JS when stopped + scrolled. */
body:has(.prompter-page) .back-to-top-btn {
  position: sticky !important;
  top: 24px !important;
  left: auto !important;
  right: auto !important;
  z-index: 14;
  display: block;
  width: max-content;
  min-height: 54px;
  margin: 0 auto 10px auto;
  padding: 0 30px;
  border-radius: 999px;
  border: 1px solid rgba(147,197,253,.58);
  background: linear-gradient(135deg, rgba(30,64,175,.92), rgba(37,99,235,.88));
  color: rgba(248,250,252,.98);
  box-shadow: 0 14px 34px rgba(37,99,235,.25), inset 0 1px 0 rgba(255,255,255,.18);
  backdrop-filter: blur(12px);
  font-size: 14px;
  font-weight: 950;
  letter-spacing: .08em;
}
body:has(.prompter-page) .back-to-top-btn:hover,
body:has(.prompter-page) .back-to-top-btn:focus-visible {
  background: linear-gradient(135deg, rgba(37,99,235,.98), rgba(96,165,250,.92));
  border-color: rgba(191,219,254,.82);
  transform: translateY(-1px);
}
body:has(.prompter-page) .back-to-top-btn[hidden] {
  display: none !important;
}
/* Fixed top-center Back-to-top CTA: JS-gated by stopped + scrolled state. */
body:has(.prompter-page) .back-to-top-btn {
  position: fixed !important;
  top: 8px !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%);
  z-index: 30;
  display: block;
  width: max-content;
  min-height: 58px;
  margin: 0;
  padding: 0 34px;
  border-radius: 999px;
  border: 1px solid rgba(147,197,253,.68);
  background: linear-gradient(135deg, rgba(30,64,175,.96), rgba(37,99,235,.92));
  color: rgba(248,250,252,.98);
  box-shadow: 0 14px 34px rgba(37,99,235,.30), inset 0 1px 0 rgba(255,255,255,.20);
  backdrop-filter: blur(12px);
  font-size: 14px;
  font-weight: 950;
  letter-spacing: .08em;
}
body:has(.prompter-page) .back-to-top-btn:hover,
body:has(.prompter-page) .back-to-top-btn:focus-visible {
  background: linear-gradient(135deg, rgba(37,99,235,.98), rgba(96,165,250,.94));
  border-color: rgba(191,219,254,.88);
  transform: translateX(-50%) translateY(-1px);
}
body:has(.prompter-page) .back-to-top-btn[hidden] {
  display: none !important;
}

