:root{--bg: #ffffff;--fg: #1a1a1a;--muted: #6b7280;--accent: #0284c7;--band: #f3f4f6;--text: #ea580c;--breath: #10b981}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";background:var(--bg);color:var(--fg);overflow-x:hidden}button,input,select{font:inherit}a{color:var(--accent);text-decoration:none}.app{display:grid;grid-template-rows:auto 1fr;height:100%;overflow:hidden}.toolbar{display:flex;gap:.75rem;align-items:center;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;background:#f9fafb;position:sticky;top:0;z-index:2}.toolbar .group{display:flex;gap:.5rem;align-items:center}.field{display:flex;gap:.4rem;align-items:center}.field label{font-size:.85rem;color:var(--muted)}.input,.select{background:#fff;border:1px solid #d1d5db;color:var(--fg);padding:.4rem .5rem;border-radius:.4rem;min-width:7rem}.select,select.select{height:34px;line-height:34px}.select.required{border-color:#ef4444;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:#ef4444}50%{border-color:#dc2626}}.btn{background:#4b5563;border:1px solid #374151;color:#fff;padding:.45rem .7rem;border-radius:.4rem;cursor:pointer;transition:all .2s ease}.btn:hover{background:#374151;border-color:#1f2937}.btn.primary{background:#0284c7;border-color:#0369a1}.btn.primary:hover{background:#0369a1;border-color:#075985}.btn.secondary{background:#fff;border-color:#d1d5db;color:#374151}.btn.secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn.danger{background:#ef4444;border-color:#dc2626;color:#fff}.btn.danger:hover{background:#dc2626;border-color:#b91c1c}.btn:disabled{opacity:.55;cursor:not-allowed}.main{display:grid;grid-template-columns:1fr 320px;height:100%;overflow:hidden}.content-area{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.panel{overflow:auto;flex:1;display:flex;flex-direction:column}.sidebar{border-left:0;background:#f9fafb;padding:.75rem;overflow:hidden;height:100%;display:flex;flex-direction:column}.hstack{display:flex;gap:.5rem;align-items:center}.vstack{display:flex;flex-direction:column;gap:.5rem}.section-title{font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.rule{height:1px;background:#e5e7eb;margin:.5rem 0}.cueli{padding:.35rem .4rem;border-radius:.3rem;cursor:pointer;transition:background .15s ease}.cueli:hover{background:#f3f4f6}.stage-badge{padding:.2rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:inline-block}.cue-text{color:#374151;margin-top:4px;font-size:.85rem;line-height:1.4;opacity:.95}.badge{font-size:.72rem;color:#6b7280;border:1px solid #d1d5db;padding:.05rem .35rem;border-radius:.25rem}.small{font-size:.85rem;color:var(--muted)}.timeline-wrap{width:100%;overflow-x:auto;overflow-y:visible}.ruler{position:sticky;top:0;background:#f9fafb;border-bottom:1px solid #e5e7eb;z-index:1}svg{display:block}.content-loader{display:flex;align-items:center;justify-content:center;min-height:400px;width:100%}.loader-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:10}.loader{display:flex;flex-direction:column;align-items:center;gap:20px;padding:32px;background:linear-gradient(135deg,#fff,#f3f4f6);border-radius:12px;box-shadow:0 4px 16px #0000001a;border:1px solid #e5e7eb}.loader-spinner{width:48px;height:48px;border:3px solid #e5e7eb;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.loader-spinner-small{width:24px;height:24px;border:2px solid #e5e7eb;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loader-text{color:#6b7280;font-size:14px;font-weight:600;text-align:center;animation:pulse 1.5s ease-in-out infinite}.loader-text-small{color:#6b7280;font-size:13px;font-weight:500;margin-left:8px}.script-loader{display:flex;align-items:center;padding:16px;background:#fff;border:1px solid #e5e7eb;border-radius:6px}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}.card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#fff;color:#111827;box-shadow:0 8px 24px #00000014}.card.auditioner{max-width:980px;margin:24px auto}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.card-title{margin:0;font-size:16px;font-weight:600}.section{border:1px solid #e5e7eb;border-radius:8px;padding:12px;background:#fff}.controls-row{display:flex;gap:8px;justify-content:flex-end;margin-top:8px;margin-bottom:16px}.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}.cue-list{flex:1;overflow-y:auto;overflow-x:hidden;display:grid;gap:6px;align-content:start}.cue-item{border:1px solid #e5e7eb;border-radius:6px;padding:6px;display:grid;gap:4px;width:100%;overflow:hidden}.cue-item-meta{font-size:11px;color:#6b7280;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:4px}.cue-item-text{font-size:13px;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;width:100%}.header-right-inline{display:flex;align-items:center;gap:8px}input[type=range]{width:100%}.form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:end}.form-col{display:flex;flex-direction:column;gap:4px}.session-anatomy{padding:20px 24px;margin:0;border-bottom:1px solid rgba(229,231,235,.8);flex-shrink:0;background:#f9fafb80}.anatomy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.anatomy-title{margin:0;color:#6b7280;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:12px}.session-duration{color:#9ca3af;font-size:12px;font-weight:400}.phase-legend-inline{display:flex;gap:12px;align-items:center;font-size:12px;color:#6b7280}.exercise-flow{display:flex;align-items:flex-start;gap:8px;padding:0}.exercise-container{display:flex;flex-direction:column;gap:8px;min-width:120px}.exercise-block{padding:10px 14px;border-radius:4px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;border:1px solid rgba(229,231,235,.5)}.exercise-block:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a;opacity:1!important;filter:brightness(1.05)}.cycle-repetitions-container{display:flex;flex-wrap:wrap;gap:4px;padding:6px 0}.mini-cycle{display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px 4px;background:#f3f4f680;border-radius:2px;border:1px solid rgba(229,231,235,.5);transition:all .15s ease}.mini-cycle:hover{background:#f3f4f6cc}.cycle-number{color:#9ca3af;font-size:9px;font-weight:600}.mini-phase-flow{display:flex;align-items:center;gap:2px}.mini-phase-with-duration{display:inline-flex;align-items:center;gap:1px;font-size:12px;font-weight:700;line-height:1}.mini-duration{font-size:8px;font-weight:400;opacity:.7}.mini-separator{color:#9ca3af;font-size:8px;margin:0 1px}.phase-legend{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#f3f4f6cc;border-radius:6px;margin-bottom:20px}.legend-title{color:#6b7280;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.legend-items{display:flex;gap:20px}.legend-item{display:flex;align-items:center;gap:4px;color:#6b7280;font-size:12px}.legend-item span:first-child{font-size:14px;font-weight:700}.cycle-more-indicator{color:#9ca3af;font-size:11px;font-style:italic;display:flex;align-items:center;padding:4px 8px}.exercise-label{color:#475569;font-weight:500;font-size:13px;margin-bottom:3px}.exercise-stage{color:#64748b;font-size:10px;margin-bottom:2px;text-transform:uppercase;letter-spacing:.03em;font-weight:500}.exercise-duration{color:#64748b;font-size:11px;font-weight:500}.flow-arrow{color:#3a4451;font-size:14px;display:flex;align-items:center;height:50px;opacity:.5}.session-stats{display:flex;gap:24px;padding:12px 16px;background:#f3f4f6cc;border-radius:6px}.stat-item{display:flex;gap:8px;align-items:center}.stat-label{color:#6b7280;font-size:12px}.stat-value{color:#1f2937;font-size:13px;font-weight:600}.script-section{border-top:1px solid #e5e7eb;background:#f9fafb;padding:20px 24px;margin-top:auto}.script-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.script-content{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:16px;max-height:300px;overflow-y:auto}.script-content pre{margin:0;white-space:pre-wrap;word-wrap:break-word;color:#374151;font-size:13px;line-height:1.6;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;opacity:.95}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;animation:fadeIn .2s ease}.modal-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;max-width:900px;height:80%;max-height:700px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;z-index:1000;display:flex;flex-direction:column;animation:slideIn .3s ease;box-shadow:0 20px 60px #00000026}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.modal-title{margin:0;font-size:16px;font-weight:600;color:#1a1a1a;text-transform:uppercase;letter-spacing:.05em}.modal-actions{display:flex;gap:8px;align-items:center}.modal-body{flex:1;overflow:auto;padding:20px;background:#fff}.json-viewer{font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.6;color:#374151}.json-key{color:#059669;font-weight:500}.json-string{color:#b45309}.json-number{color:#0369a1}.json-bool{color:#7c3aed;font-weight:600}.json-null{color:#dc2626;font-style:italic}.json-bracket{color:#6b7280;font-weight:600}.json-bracket.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease}.json-bracket.clickable:hover{color:#0284c7}.json-comma{color:#6b7280}.json-colon{color:#6b7280;margin:0 4px}.p-sm{padding:8px}.p-md{padding:12px}.p-lg{padding:16px}.p-xl{padding:24px}.p-32{padding:32px}.pt-sm{padding-top:8px}.pt-md{padding-top:12px}.pt-lg{padding-top:16px}.pt-xl{padding-top:24px}.pb-sm{padding-bottom:8px}.pb-md{padding-bottom:12px}.pb-lg{padding-bottom:16px}.pb-xl{padding-bottom:24px}.pl-sm{padding-left:8px}.pl-md{padding-left:12px}.pl-lg{padding-left:16px}.pr-sm{padding-right:8px}.pr-md{padding-right:12px}.pr-lg{padding-right:16px}.px-sm{padding-left:8px;padding-right:8px}.px-md{padding-left:12px;padding-right:12px}.px-lg{padding-left:16px;padding-right:16px}.py-sm{padding-top:8px;padding-bottom:8px}.py-md{padding-top:12px;padding-bottom:12px}.py-lg{padding-top:16px;padding-bottom:16px}.m-sm{margin:8px}.m-md{margin:12px}.m-lg{margin:16px}.m-xl{margin:24px}.mt-sm{margin-top:8px}.mt-md{margin-top:12px}.mt-lg{margin-top:16px}.mt-xl{margin-top:24px}.mb-sm{margin-bottom:8px}.mb-md{margin-bottom:12px}.mb-lg{margin-bottom:16px}.mb-xl{margin-bottom:24px}.mb-32{margin-bottom:32px}.ml-sm{margin-left:8px}.ml-md{margin-left:12px}.ml-lg{margin-left:16px}.ml-auto{margin-left:auto}.mr-sm{margin-right:8px}.mr-md{margin-right:12px}.mr-lg{margin-right:16px}.mx-sm{margin-left:8px;margin-right:8px}.mx-md{margin-left:12px;margin-right:12px}.mx-lg{margin-left:16px;margin-right:16px}.mx-auto{margin-left:auto;margin-right:auto}.my-sm{margin-top:8px;margin-bottom:8px}.my-md{margin-top:12px;margin-bottom:12px}.my-lg{margin-top:16px;margin-bottom:16px}.gap-sm{gap:8px}.gap-md{gap:12px}.gap-lg{gap:16px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-around{justify-content:space-around}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.top-8{top:8px}.right-8{right:8px}.bottom-8{bottom:8px}.left-8{left:8px}.top-16{top:16px}.right-16{right:16px}.bottom-16{bottom:16px}.left-16{left:16px}.w-full{width:100%}.w-auto{width:auto}.min-w-0{min-width:0}.min-w-140{min-width:140px}.min-w-180{min-width:180px}.max-w-90vw{max-width:90vw}.max-w-700{max-width:700px}.h-full{height:100%}.h-auto{height:auto}.min-h-60{min-height:60px}.min-h-200{min-height:200px}.bg-white{background-color:#fff}.bg-surface{background-color:#f9fafb}.bg-muted{background-color:#f3f4f6}.bg-overlay{background-color:#00000080}.bg-overlay-light{background-color:#0000004d}.text-primary{color:#0f172a}.text-secondary{color:#334155}.text-muted{color:#6b7280}.text-white{color:#fff}.text-white-70{color:#ffffffb3}.text-error{color:#ef4444}.text-success{color:#10b981}.text-xs{font-size:10px}.text-sm{font-size:12px}.text-base{font-size:13px}.text-md{font-size:14px}.text-lg{font-size:16px}.text-xl{font-size:18px}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.border{border:1px solid #e5e7eb}.border-t{border-top:1px solid #e5e7eb}.border-b{border-bottom:1px solid #e5e7eb}.border-l{border-left:1px solid #e5e7eb}.border-r{border-right:1px solid #e5e7eb}.border-radius-sm{border-radius:4px}.border-radius-md{border-radius:6px}.border-radius-lg{border-radius:8px}.border-radius-xl{border-radius:12px}.border-radius-16{border-radius:16px}.border-radius-20{border-radius:20px}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.transition{transition:all .2s ease}.transition-slow{transition:all .6s cubic-bezier(.4,0,.2,1)}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-default{cursor:default}.z-1{z-index:1}.z-2{z-index:2}.z-10{z-index:10}.z-10000{z-index:10000}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-hidden{overflow-x:hidden}.block{display:block}.inline-block{display:inline-block}.hidden{display:none}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.card-header{padding-bottom:12px;border-bottom:1px solid #e5e7eb;margin-bottom:16px}.card-body{padding:0}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:8px;font-size:13px;color:#6b7280;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{position:relative;width:min(100%,1040px);max-height:90vh;overflow:auto;background:#f9fafb;border-radius:12px}
