:root{--paper:#f7f4ee;--ink:#22201d;--ink-soft:#5c574e;--line:#e0dacd;--accent:#5b7c99;--accent-soft:#dce6ed;--radius:6px;color:var(--ink);background:var(--paper);font-synthesis:none;font-family:Inter,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--paper)}button,input,select,textarea{font:inherit;color:var(--ink)}button{cursor:pointer}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:50;border-bottom:1px solid var(--line);background:#fff;padding:12px 20px;position:sticky;top:0}.header-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.logo,.brand{letter-spacing:.04em;align-items:center;gap:8px;font-size:1.3rem;font-weight:700;display:flex}.logo-mark,.brand span{font-size:1.6rem}.logo-text,.brand strong{font-family:Georgia,serif}.header-role{flex-direction:column;align-items:flex-end;font-size:.85rem;display:flex}.role-label{color:var(--accent);font-weight:600}.user-name{color:var(--ink-soft)}.header-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.page-nav{gap:6px;display:flex}.page-nav button,.view-toggle button,.export-btn,.create-btn,.logout-btn,.ghost,.primary{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:6px 12px;font-size:.85rem}.page-nav button.active,.view-toggle button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.search-input{border:1px solid var(--line);border-radius:var(--radius);flex:1;min-width:170px;padding:7px 10px}.view-toggle{display:flex}.view-toggle button+button{margin-left:-1px}.export-btn,.create-btn{font-weight:600}.create-btn,.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.create-btn:hover,.primary:hover{background:#486a86}.logout-btn{color:var(--ink-soft);margin-left:auto}.small{padding:5px 9px;font-size:.78rem}.app-main,.content{flex:1;padding:16px;overflow-x:auto}.table-wrap{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}.numbers-table{min-width:1900px}th{text-align:left;background:var(--accent-soft);border-bottom:2px solid var(--accent);white-space:nowrap;padding:10px 8px}td{border-bottom:1px solid var(--line);vertical-align:middle;padding:6px 8px}tbody tr:hover{background:#fbfaf7}.empty-row{text-align:center;color:var(--ink-soft);padding:24px!important}td[data-column=title]{min-width:180px}td[data-column=order_index]{min-width:58px}td[data-column=type]{min-width:120px}td[data-column=status]{min-width:235px}td[data-column=executor]{min-width:130px}td[data-column=playback]{text-align:center;min-width:75px}td[data-column=deadline]{min-width:120px}td[data-column=notes]{min-width:170px}td[data-column=composition]{min-width:135px}td[data-column=demo],td[data-column=minus],td[data-column=klavir]{min-width:125px}td[data-column=score],td[data-column=multitrack],td[data-column=materials]{min-width:160px}td input:not([type=checkbox]),td select,td textarea{background:0 0;border:1px solid #0000;border-radius:4px;width:100%;padding:4px;font-size:.82rem}td input:focus,td select:focus,td textarea:focus{border-color:var(--accent);background:#fff;outline:none}td textarea{resize:vertical;font-family:inherit}.muted{color:var(--ink-soft);font-size:.8rem}.cell-empty{color:#b8b2a6;font-size:.8rem}.order-cell{align-items:center;gap:5px;display:flex}.drag-handle{color:var(--accent);cursor:grab;background:0 0;border:0;padding:1px 2px;font-size:1.05rem;line-height:1}.drag-handle:active{cursor:grabbing}.delete-number{color:#a2473f;background:0 0;border:0;padding:0 2px;font-size:1rem;line-height:1}.dragging-row{opacity:.42}.drop-placeholder td{border:0;height:0;background:0 0!important;padding:0!important}.drop-placeholder-inner{box-sizing:border-box;height:var(--drop-height);border:1px dashed var(--accent);color:var(--accent);background:#edf5fa;border-radius:6px;margin:3px 6px;animation:.18s cubic-bezier(.2,.8,.2,1) both open-drop-gap;position:relative;overflow:hidden}.drop-placeholder-inner span{white-space:nowrap;place-items:center;font-size:.75rem;font-weight:600;display:grid;position:absolute;inset:0}@keyframes open-drop-gap{0%{opacity:0;height:0;margin-top:0;margin-bottom:0}to{height:var(--drop-height);opacity:1}}.drag-preview-table{z-index:9999;table-layout:fixed;border-collapse:collapse;pointer-events:none;border:1px solid var(--accent);border-radius:var(--radius);background:#fff;position:fixed;top:-10000px;left:-10000px;overflow:hidden;box-shadow:0 12px 34px #2d435247}.drag-preview-table td{background:#fff}.status-badge,.status{white-space:nowrap;border-radius:999px;padding:4px 10px;font-size:.78rem;font-weight:600;display:inline-block}.status-badge.small{padding:2px 8px;font-size:.72rem}.status-select{font-weight:600;border:0!important;border-radius:999px!important;padding:5px 8px!important;font-size:.78rem!important}.type-marker{background:#5b7c99;border-radius:50%;width:11px;height:11px;display:inline-block}.type-marker.underscore{background:#6fae7c}.type-cell{align-items:center;gap:5px;display:flex}.type-cell select{flex:1}.chips{flex-wrap:wrap;gap:4px;display:flex}.chips span{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:2px 7px;font-size:.7rem}.composition-editor{position:relative}.chip-button{border:1px solid var(--line);background:#fff;border-radius:4px;padding:4px 8px;font-size:.78rem}.composition-popover{z-index:60;border:1px solid var(--line);border-radius:var(--radius);background:#fff;min-width:190px;max-height:240px;padding:8px;position:absolute;top:100%;left:0;overflow:auto;box-shadow:0 5px 18px #0000001f}.composition-popover label{padding:2px;font-size:.78rem;font-weight:400;display:block}.file-cell,.file-list{gap:5px;display:grid}.file-item{gap:3px;display:grid}.file-item>div{display:grid}.file-item a{color:var(--accent);overflow-wrap:anywhere;font-size:.77rem;font-weight:600;text-decoration:none}.file-item a:hover{text-decoration:underline}.file-item small{color:var(--ink-soft);font-size:.67rem}.file-item audio{width:145px;height:27px}.uploader-controls{gap:4px;display:grid}.uploader-controls select{border-color:var(--line);background:#fff}.folder-state{color:var(--ink-soft);background:#f4f6f7;border-radius:4px;gap:3px;padding:6px;display:grid}.folder-state strong{font-size:.72rem}.folder-state small{overflow-wrap:anywhere;font-size:.64rem}.folder-state.ready{color:#2f684b;background:#e9f4ed}.folder-state.error{color:#943a33;background:#f9eae8}.folder-state button{justify-self:start;margin-top:2px}.drop-zone{min-height:28px;color:var(--accent);text-align:center;background:#f8fbfc;border:1.5px dashed #a6bac8;border-radius:4px;place-items:center;padding:4px;font-size:.7rem;display:grid}.drop-zone.over{background:var(--accent-soft);outline:1px solid var(--accent)}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.gallery-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden}.gallery-cover{justify-content:space-between;align-items:flex-start;height:80px;padding:9px;display:flex}.gallery-order{color:var(--ink);font-size:.83rem;font-weight:700}.gallery-body{flex-direction:column;align-items:flex-start;gap:7px;padding:12px;display:flex}.gallery-body h4{margin:0;font-size:1rem}.gallery-meta{color:var(--ink-soft);flex-direction:column;font-size:.76rem;display:flex}.calendar-page h2,.tasks-page h2{margin-top:0}.calendar-month{margin-bottom:24px}.calendar-month h3{color:var(--accent);border-bottom:1px solid var(--line);padding-bottom:4px}.calendar-table{background:#fff}.calendar-table td{padding:7px 8px}.cal-date{white-space:nowrap;width:110px;font-weight:600}.tasks-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px;display:grid}.task-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:13px}.task-card h3{margin:3px 0 10px}.tasks-details summary{color:var(--accent);cursor:pointer;font-weight:600}.task-editor-list{gap:8px;margin:8px 0;display:grid}.task-editor{background:#f7f8f7;border-radius:5px;gap:4px;padding:7px;display:grid}.task-editor strong{font-size:.76rem}.new-task-row{border-top:1px solid var(--line);gap:5px;padding-top:8px;display:grid}.auth-screen,.loading{place-items:center;min-height:100vh;display:grid}.auth-card{border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;width:340px;max-width:calc(100vw - 30px);padding:32px}.auth-card .brand{justify-content:center}.auth-card>p{color:var(--ink-soft);margin:6px 0 24px;font-size:.9rem}.auth-card form{text-align:left;gap:14px;display:grid}label{gap:4px;font-size:.84rem;font-weight:600;display:grid}.auth-card input,.modal input,.modal select,.user-form input,.user-form select,.password-reset input,.users-table input,.users-table select,.role-editor input[type=text],.role-editor input:not([type]),.role-editor select,.integration-card input:not([type=checkbox]){border:1px solid var(--line);background:#fff;border-radius:4px;padding:8px}.form-error{color:#b2382f;font-size:.8rem}.panel{border:1px solid var(--line);border-radius:var(--radius);background:#fff;margin-bottom:17px;padding:17px}.panel h2{margin:0 0 14px;font-size:1.1rem}.user-form{grid-template-columns:repeat(5,minmax(140px,1fr)) auto;align-items:end;gap:10px;display:grid}.users-table td:first-child{min-width:205px}.users-table td:first-child small{color:var(--ink-soft);margin-top:3px;display:block}.switch{white-space:nowrap;grid-auto-flow:column;align-items:center;gap:5px;display:flex}.password-reset{gap:5px;min-width:220px;display:flex}.admin-tabs{border-bottom:1px solid var(--line);gap:4px;margin-bottom:14px;display:flex}.admin-tabs button{color:var(--ink-soft);background:0 0;border:0;border-bottom:3px solid #0000;padding:9px 15px}.admin-tabs button.active{border-bottom-color:var(--accent);color:var(--accent);font-weight:700}.admin-empty{border:1px dashed var(--line);border-radius:var(--radius);color:var(--ink-soft);background:#fbfaf7;padding:14px}.roles-layout{grid-template-columns:260px minmax(0,1fr);align-items:start;gap:14px;display:grid}.roles-list{border:1px solid var(--line);border-radius:var(--radius);background:#fff;gap:5px;padding:8px;display:grid;position:sticky;top:126px}.roles-list button{text-align:left;background:0 0;border:0;border-radius:5px;justify-content:space-between;gap:8px;padding:9px 10px;display:flex}.roles-list button:hover{background:#f4f1eb}.roles-list button.active{background:var(--accent-soft);color:#31536d}.roles-list button span{color:var(--ink-soft);white-space:nowrap;font-size:.72rem}.role-editor{border:1px solid var(--line);border-radius:var(--radius);background:#fff;gap:14px;padding:18px;display:grid}.role-editor-title{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.role-editor-title h2{margin:0;font-size:1.25rem}.role-editor-title span,.permission-section>p{color:var(--ink-soft);font-size:.78rem}.role-main-fields{grid-template-columns:minmax(200px,1fr) minmax(260px,2fr);gap:10px;display:grid}.permission-section{border-top:1px solid var(--line);padding-top:13px}.permission-section h3{margin:0 0 9px;font-size:.96rem}.permission-section>p{margin:-4px 0 10px}.permission-flags,.check-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:7px 12px;display:grid}.permission-flags label,.check-grid label,.inline-check{grid-auto-flow:column;justify-content:flex-start;align-items:center;gap:7px;font-weight:400;display:flex}.permission-table-wrap{border:1px solid var(--line);border-radius:5px;max-height:390px;overflow:auto}.permission-table th{z-index:1;padding:8px;position:sticky;top:0}.permission-table td{padding:7px 8px}.permission-table th:not(:first-child),.permission-table td:not(:first-child){text-align:center;width:120px}.permission-table input[type=checkbox]{width:16px;height:16px}.role-actions{border-top:1px solid var(--line);background:#fff;justify-content:flex-end;padding-top:10px;display:flex;position:sticky;bottom:0}.danger{color:#9d352d;background:#fff;border:1px solid #d9aaa5;border-radius:4px;padding:6px 10px}.danger:disabled{opacity:.45;cursor:not-allowed}.integration-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;gap:17px;max-width:900px;padding:20px;display:grid}.integration-card h2{margin:0 0 4px}.integration-card h2+p{color:var(--ink-soft);margin:0;font-size:.84rem}.integration-toggle{background:var(--accent-soft);border-radius:var(--radius);grid-auto-flow:column;justify-content:flex-start;align-items:flex-start;gap:10px;padding:13px;display:flex}.integration-toggle input{width:18px;height:18px;margin-top:2px}.integration-toggle span{gap:3px;display:grid}.integration-toggle small,.integration-fields small{color:var(--ink-soft);font-weight:400}.integration-fields{grid-template-columns:1fr 2fr;gap:12px;display:grid}.integration-status{border-radius:var(--radius);color:var(--ink-soft);background:#f4f3ef;flex-direction:column;gap:3px;padding:11px 13px;font-size:.8rem;display:flex}.integration-status.success{color:#2f684b;background:#e9f4ed}.integration-status.error{color:#943a33;background:#f9eae8}.integration-note{border-left:3px solid var(--accent);background:#f5f8fa;gap:4px;padding:11px 13px;font-size:.78rem;display:grid}.integration-note span{color:var(--ink-soft)}.integration-actions{gap:8px;display:flex}.modal-backdrop{z-index:100;background:#22201d66;place-items:center;padding:15px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:8px;gap:13px;width:370px;max-width:100%;padding:18px;display:grid}.modal-title{justify-content:space-between;align-items:center;display:flex}.modal-title h2{margin:0;font-size:1.15rem}.modal-title button{background:0 0;border:0;font-size:1.5rem}.notice{z-index:110;color:#8b3028;border-radius:var(--radius);background:#fbe8e6;border:1px solid #efc5c1;gap:12px;max-width:420px;padding:11px 13px;display:flex;position:fixed;bottom:16px;right:16px;box-shadow:0 8px 28px #00000021}.notice.success{color:#275b40;background:#e4f3e9;border-color:#bcdcc6}.notice button{background:0 0;border:0;font-size:1.15rem}.musician-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.number-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;gap:10px;padding:14px;display:grid}.number-card h2{margin:3px 0;font-size:1rem}.order{color:var(--accent);font-weight:700}@media (width<=768px){.header-top{flex-direction:column;align-items:flex-start;gap:6px}.header-role{align-items:flex-start}.header-controls{flex-direction:column;align-items:stretch}.page-nav,.view-toggle{justify-content:center}.logout-btn{margin-left:0}.numbers-table{font-size:.78rem}.gallery-grid,.musician-grid,.user-form,.roles-layout{grid-template-columns:1fr}.roles-list{position:static}.role-main-fields,.integration-fields{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
