*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background:#f6f8fc;color:#0f172a;overflow:hidden}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:236px;background:linear-gradient(180deg,#07163b,#0a1330 68%,#071a47);color:#fff;padding:18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}.brandWrap{display:flex;justify-content:center;align-items:center;margin-bottom:14px}.logo{width:78px;height:78px;border-radius:18px;background:#0b173f;display:grid;place-items:center;overflow:hidden;border:1px solid rgba(165,186,255,.35)}.logo img{width:100%;height:100%;object-fit:cover;display:block}.brand,.sub{display:none!important}.brand{font-weight:800;letter-spacing:.5px}.sub{font-size:11px;color:#9cb0ff}nav{margin-top:10px;flex:1;overflow:auto}nav a{display:flex;align-items:center;gap:10px;color:#d6ddff;padding:10px 12px;border-radius:10px;margin-bottom:4px;font-size:15px;text-decoration:none}nav a .navIcon{width:18px;height:18px;display:inline-flex;flex:0 0 18px;opacity:.92}nav a .navIcon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}nav a.active,nav a:hover{background:#2548d3;color:#fff}.quickActions{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;display:grid;gap:8px}.qaTitle{font-size:11px;color:#9fb0e3;letter-spacing:.6px}.quickActions button{background:#192f68;color:#fff;border:1px solid #2b4a9f;border-radius:10px;padding:10px;cursor:pointer;text-align:left}.userFooter{margin-top:12px;border-top:1px solid rgba(255,255,255,.1);padding-top:12px;display:flex;align-items:center;gap:10px;position:relative;cursor:pointer}.avatar{width:36px;height:36px;border-radius:50%;background:#3558df;display:grid;place-items:center;font-size:12px;overflow:hidden}.uName{font-size:14px;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.uRole{font-size:12px;color:#9fb0e3;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#userMenuBtn{margin-left:auto;background:transparent;border:1px solid rgba(255,255,255,.25);color:#dbe7ff;border-radius:8px;padding:2px 8px;cursor:pointer}.userMenu{position:absolute;left:0;bottom:56px;background:#fff;border:1px solid #dbe4f2;border-radius:12px;box-shadow:0 12px 28px rgba(2,6,23,.24);min-width:180px;padding:6px;z-index:30}.userMenu button{display:block;width:100%;text-align:left;background:#fff;border:none;border-radius:8px;padding:10px 12px;color:#0f172a;cursor:pointer}.userMenu button:hover{background:#f1f5f9}.content{flex:1;padding:0 22px 20px;overflow:auto;height:100vh}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;position:sticky;top:0;background:#f6f8fc;z-index:6;padding:20px 0 8px}.topbar h1{margin:0;font-size:40px;line-height:1.1}.topbar input{width:520px;max-width:56vw;padding:12px 14px;border:1px solid #d8e0ef;border-radius:12px;background:#fff}.cards{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px}.card,.panel{background:#fff;border:1px solid #e6ecf5;border-radius:16px;box-shadow:0 2px 6px rgba(15,23,42,.04)}.card{padding:16px}.kpiTop{display:flex;align-items:center;gap:12px}.kpiIcon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff;font-weight:800}.kpiIcon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.kpiI1{background:linear-gradient(145deg,#8b5cf6,#6d28d9)}.kpiI2{background:linear-gradient(145deg,#22c55e,#16a34a)}.kpiI3{background:linear-gradient(145deg,#38bdf8,#2563eb)}.kpiI4{background:linear-gradient(145deg,#f59e0b,#d97706)}.label{color:#64748b;font-size:13px}.value{font-size:34px;font-weight:700}.kpiSub{font-size:13px;color:#16a34a;margin-top:8px}.gridMain{display:grid;grid-template-columns:1.1fr 1.3fr .8fr;gap:14px;margin-top:14px}.gridBottom{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:14px;margin-top:14px}.panel{padding:16px}.panel h3{margin:0 0 10px}.muted{color:#64748b}.pill{display:inline-block;padding:3px 8px;border-radius:999px;background:#e8efff;color:#3451d1;font-size:12px}.row{display:flex;justify-content:space-between;align-items:center;margin:8px 0}.dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:8px}.legend li{list-style:none;margin:6px 0;font-size:14px}.legend{padding:0;margin:0}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px 8px;border-bottom:1px solid #edf2f8;text-align:left;font-size:14px}.table th{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.priority-high{color:#dc2626}.priority-medium{color:#d97706}.priority-low{color:#16a34a}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}.alerts{display:flex;flex-wrap:wrap;gap:8px}.alert-chip{display:inline-flex;gap:6px;align-items:center;padding:6px 10px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:999px;font-size:12px;color:#334155}.activity{display:grid;gap:10px}.activityItem{font-size:14px;padding:10px;border:1px solid #edf2f8;border-radius:10px}.ok{color:#16a34a}.warn{color:#d97706}.bad{color:#dc2626}.royaltySplitMatrix{display:grid;grid-template-columns:340px 1fr;border:1px solid #dbe4f2;border-radius:12px;overflow:hidden;max-height:65vh;background:#fff}.royalty-left-pane{border-right:1px solid #dbe4f2;background:#fff;display:flex;flex-direction:column}.royalty-right-pane{display:flex;flex-direction:column;min-width:0}.royalty-fixed-col,.royalty-scroll-grid{margin:0;border-collapse:separate;border-spacing:0}.royalty-fixed-col th,.royalty-fixed-col td,.royalty-scroll-grid th,.royalty-scroll-grid td{white-space:nowrap;padding:10px 12px;border-bottom:1px solid #edf2f8}.royalty-fixed-col th,.royalty-scroll-grid th{background:#f1f6ff;border-bottom:2px solid #dbe4f2;color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.royalty-fixed-col-body{overflow:hidden auto;max-height:calc(65vh - 44px)}.royalty-fixed-col td{max-width:340px;overflow:hidden;text-overflow:ellipsis}.royalty-scroll-head{overflow:hidden;background:#f8fbff}.royalty-scroll-body{overflow:auto;max-height:calc(65vh - 44px);overscroll-behavior:contain;touch-action:pan-x pan-y}.royalty-scroll-grid{min-width:max-content}.royalty-scroll-grid .money-col{text-align:right;font-variant-numeric:tabular-nums}.royalty-scroll-grid .lifetime-col{font-weight:700;background:#f8fbff}.royalty-fixed-col tbody tr:nth-child(even) td,.royalty-scroll-grid tbody tr:nth-child(even) td{background:#fbfdff}.royalty-fixed-col tbody tr:hover td,.royalty-scroll-grid tbody tr:hover td{background:#eef4ff}.toolbar{display:flex;gap:8px;align-items:end;flex-wrap:wrap;margin-bottom:10px}.toolbar label{display:grid;gap:4px;font-size:12px;color:#475569}.toolbar input{padding:8px;border:1px solid #d8e0ef;border-radius:8px}.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.55);display:flex;align-items:flex-start;justify-content:center;z-index:9999;overflow-y:auto;padding:24px 12px}.modal-card{width:min(1420px,95vw);height:min(90vh,980px);background:#fff;border-radius:16px;border:1px solid #dbe6f7;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #e5edf7}.modal-header h2{margin:0;font-size:24px}.modal-header button{margin-left:8px}.song-grid{padding:14px 16px;display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:10px;overflow:auto}.song-grid label{display:grid;gap:4px;font-size:12px;color:#475569}.song-grid input,.song-grid textarea,.song-grid select{width:100%;padding:8px;border:1px solid #d8e0ef;border-radius:8px;font-size:13px}.song-grid textarea{min-height:68px;resize:vertical}.song-grid-wide{grid-template-columns:repeat(3,minmax(180px,1fr))}.song-audit-meta{display:flex;justify-content:space-between;gap:12px;padding:10px 16px 14px;color:#64748b;font-size:12px;border-top:1px dashed #e2e8f0}.song-audit-meta b{color:#334155;font-weight:600}.merge-preview-wrap{margin-top:12px}.merge-review-panel{background:#fff;color:#0f172a;border:1px solid #dbe4f2}.merge-review-title{margin:0 0 8px;color:#0f172a}.merge-review-list{margin:0 0 10px 18px;color:#1e293b}.merge-review-list li{margin:4px 0}.merge-review-warnings{color:#334155;background:#f8fafc;border:1px solid #e2e8f0;padding:8px;border-radius:8px}.merge-review-check{display:block;margin:8px 0;color:#0f172a}.merge-review-check input[type='checkbox']{margin-right:8px}.merge-review-input{display:block;margin-top:6px;padding:8px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#0f172a}.merge-review-btn{margin-top:8px;background:#1d4ed8;color:#fff;border:1px solid #1e40af;border-radius:10px;padding:10px 12px;cursor:pointer}.merge-review-btn:hover{background:#1e40af}#songPubContractsModal .gm-pubcontracts-modal{max-width:1680px;height:auto;max-height:94vh;overflow:auto}#songPubContractsModal .gm-pubcontracts-body{padding:14px 16px;display:grid;gap:14px}#songPubContractsModal .gm-section{border-radius:18px;border:1px solid #dfe7f5;box-shadow:0 2px 8px rgba(30,41,59,.04)}#songPubContractsModal .gm-pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;align-items:start}#songPubContractsModal .gm-pricing-item{display:grid;gap:8px}#songPubContractsModal .gm-pricing-head{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:#0f172a}#songPubContractsModal .gm-pricing-head span:last-child{font-size:33px;font-weight:700}#songPubContractsModal .gm-pricing-icon{width:52px;height:52px;display:grid;place-items:center;border:1px solid #d8e3f7;border-radius:12px;background:#f8fbff;font-size:26px}#songPubContractsModal .gm-pricing-item label{display:grid;gap:4px;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}#songPubContractsModal .gm-pricing-item input,#songPubContractsModal .gm-add-ownership-form input,#songPubContractsModal .gm-add-ownership-form select,#songPubContractsModal .gm-contract-form input,#songPubContractsModal .gm-contract-form select{width:100%;padding:9px 10px;border:1px solid #d7e0ef;border-radius:9px;background:#fff;font-size:16px;color:#0f172a}#songPubContractsModal .gm-pricing-actions{grid-column:1 / -1}#songPubContractsModal .gm-section-head{display:flex;justify-content:space-between;align-items:center;gap:10px}#songPubContractsModal .gm-btn{border:1px solid #cdd8eb;background:#fff;color:#0f172a;border-radius:10px;padding:8px 12px;cursor:pointer;font-weight:600}#songPubContractsModal .gm-btn-primary{background:#2457f5;border-color:#1d4ed8;color:#fff}#songPubContractsModal .gm-btn-danger-lite{color:#b42318;background:#fff;border-color:#f4c7c3}#songPubContractsModal .status-pill{display:inline-block;padding:3px 8px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.4px}
#songPubContractsModal .status-pending{background:#fff7dd;color:#b98900;border:1px solid #f2d98d}
#songPubContractsModal .status-approved{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}
#songPubContractsModal .status-rejected{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}

#songPubContractsModal select.status-pill{
  cursor:pointer;
  appearance:auto;
  -webkit-appearance:auto;
  padding:4px 10px;
  line-height:1.1;
  background-clip:padding-box;
}
#songPubContractsModal select.status-pill:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(36,87,245,.12);
}

#songPubContractsModal .gm-ownership-table th,#songPubContractsModal .gm-ownership-table td{font-size:14px}#songPubContractsModal .gm-ownership-progress{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:14px;margin:10px 0 12px;padding:14px;border:1px solid #dbe4f2;border-radius:12px;background:#fbfdff}#songPubContractsModal .gm-ownership-progress-icon{width:52px;height:52px;display:grid;place-items:center;border:1px solid #d8e3f7;border-radius:12px;background:#f1f6ff;font-size:24px}#songPubContractsModal .gm-ownership-progress-label{font-size:13px;font-weight:700;color:#64748b;letter-spacing:.3px}#songPubContractsModal .gm-ownership-progress-text{font-size:20px;color:#64748b;font-weight:600;white-space:nowrap}#songPubContractsModal .gm-ownership-progress-text b{color:#2457f5}#songPubContractsModal .gm-ownership-progress-text span{margin:0 8px;color:#94a3b8}#songPubContractsModal .gm-ownership-progress-bar-wrap{width:100%}#songPubContractsModal .gm-ownership-progress-bar{width:100%;height:18px;border-radius:999px;background:#e9edf3;overflow:hidden}#songPubContractsModal .gm-ownership-progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2457f5,#336dff)}#songPubContractsModal .gm-ownership-progress-pct{font-size:40px;line-height:1;font-weight:800;color:#2457f5;min-width:90px;text-align:right}#songPubContractsModal .gm-add-ownership-form{grid-template-columns:2fr 1fr 1fr auto;gap:8px;align-items:end}#songPubContractsModal .gm-publisher-contract-section{border:1px solid #dbe3f1;border-radius:12px;padding:8px 10px;display:grid;gap:10px}#songPubContractsModal .gm-publisher-contract-summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px;font-weight:700;padding:4px 2px}#songPubContractsModal .gm-publisher-contract-summary::-webkit-details-marker{display:none}#songPubContractsModal .gm-publisher-contract-section:not([open]) .gm-product-contract-grid{display:none}#songPubContractsModal .gm-product-contract-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}#songPubContractsModal .gm-contract-card{border:1px solid #dbe3f1;border-radius:10px;padding:10px;display:grid;gap:8px;background:#fff}#songPubContractsModal .gm-contract-card-header{display:flex;justify-content:space-between;align-items:center}#songPubContractsModal .gm-contract-form{display:grid;gap:8px}#songPubContractsModal .gm-contract-form label{display:grid;gap:4px}#songPubContractsModal .date-empty-indicator{font-size:12px;color:#64748b}a:visited{color:inherit}:root{--gm-bg:#f6f8fc;--gm-surface:#fff;--gm-border:#d9e3f3;--gm-text:#0f172a;--gm-muted:#64748b;--gm-primary:#2457f5;--gm-primary-strong:#1d4ed8;--gm-danger:#c7392f;--gm-danger-border:#f4c7c3;--gm-radius:12px}body{background:var(--gm-bg);color:var(--gm-text)}.panel,.card{border:1px solid var(--gm-border);border-radius:18px;box-shadow:0 2px 8px rgba(15,23,42,.04)}.panel h3{font-size:38px;line-height:1.15;margin-bottom:12px}.table th{font-size:12px;color:#657a9a;letter-spacing:.8px}.table td{font-size:14px;padding-top:14px;padding-bottom:14px}input,select,textarea{border:1px solid #cdd9ec;border-radius:12px;padding:10px 12px;color:#0f172a;background:#fff}input:focus,select:focus,textarea:focus{outline:none;border-color:#9bb7f4;box-shadow:0 0 0 3px rgba(36,87,245,.12)}button{border:1px solid #cfd9ea;border-radius:12px;background:#fff;color:#0f172a;padding:9px 14px;font-weight:600;cursor:pointer}button:hover{background:#f8fbff}.pill{background:#edf3ff;color:#3555cc}.gm-btn{border:1px solid #cfd9ea;background:#fff;color:#0f172a;border-radius:12px;padding:9px 14px;font-weight:700}.gm-btn-primary{background:var(--gm-primary)!important;border-color:var(--gm-primary-strong)!important;color:#fff!important}.gm-btn-primary:hover{background:#1e4dde!important}.gm-btn-danger-lite{color:var(--gm-danger)!important;background:#fff!important;border-color:var(--gm-danger-border)!important}.status-pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.4px}
.status-pending{background:#fff7dd;color:#b98900;border:1px solid #f2d98d}
.status-approved{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}
.status-rejected{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}
.status-active{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}
.status-disabled{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}

/* Users page */
.gm-users-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:14px;align-items:start}
.gm-users-tools details+details{margin-top:10px}
.gm-collapsible{border:1px solid #e2e8f0;border-radius:14px;background:#fbfdff;overflow:hidden}
.gm-collapsible summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;font-weight:800;color:#0f172a}
.gm-collapsible summary::-webkit-details-marker{display:none}
.gm-collapsible summary::after{content:'▾';opacity:.65;font-weight:900}
.gm-collapsible[open] summary{border-bottom:1px solid #e2e8f0}
.gm-collapsible[open] summary::after{content:'▴'}
.gm-collapsible-body{padding:12px 14px}

.modal-card{border-radius:18px;border:1px solid var(--gm-border);box-shadow:0 10px 28px rgba(15,23,42,.12)}.modal-header{padding:16px 18px}.modal-header h2{font-size:32px}.toolbar label{font-size:12px;color:#556a86}.card .label{font-size:13px}.card .value{font-size:34px}.mobileMenuBtn{display:none;align-items:center;justify-content:center;border:1px solid #cdd9ec;background:#fff;border-radius:10px;padding:6px 10px;font-size:18px;line-height:1;cursor:pointer}
.dash-kpi-cards{grid-template-columns:repeat(5,minmax(130px,1fr))}
.dash-months{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.dash-bottom{display:grid;grid-template-columns:1.6fr 1fr;gap:14px;margin-top:14px}
@media(max-width:1250px){.gridMain{grid-template-columns:1fr}.gridBottom{grid-template-columns:1fr}.gm-users-grid{grid-template-columns:1fr}.cards{grid-template-columns:repeat(2,1fr)}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:9998;transform:translateX(-100%);transition:transform .2s ease}.layout.sidebar-open .sidebar{transform:translateX(0)}.overview-grid{grid-template-columns:1fr}.royaltySplitMatrix{grid-template-columns:260px 1fr}.song-grid{grid-template-columns:repeat(3,minmax(150px,1fr))}.song-grid-wide{grid-template-columns:1fr}.song-audit-meta{flex-direction:column}#songPubContractsModal .gm-pricing-grid,#songPubContractsModal .gm-product-contract-grid{grid-template-columns:1fr}#songPubContractsModal .gm-ownership-progress{grid-template-columns:1fr;gap:10px}#songPubContractsModal .gm-ownership-progress-text{font-size:16px;white-space:normal}#songPubContractsModal .gm-ownership-progress-pct{font-size:28px;text-align:left;min-width:0}.table th{font-size:12px}.table td{font-size:14px}.panel h3{font-size:28px}.modal-header h2{font-size:32px}.topbar{gap:8px;padding-top:14px}.topbar input{max-width:58vw}.mobileMenuBtn{display:inline-flex !important}.content{padding:0 10px 14px}.panel{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:720px}}

/* Compact density pass (target: ~67% visual scale feel) */
.topbar h1{font-size:30px}
.topbar input{padding:10px 12px;border-radius:10px}
.panel h3{font-size:26px}
.card .value{font-size:28px}
.card .label{font-size:12px}
.kpiIcon{width:36px;height:36px;border-radius:10px}
.kpiSub{font-size:12px}
.panel,.card{border-radius:14px}
.panel{padding:12px}
.card{padding:12px}
.table th{font-size:11px;padding:8px 7px}
.table td{font-size:13px;padding:10px 7px}
button,.gm-btn{padding:7px 11px;border-radius:10px;font-size:13px}
input,select,textarea{padding:8px 10px;border-radius:10px;font-size:14px}
.modal-header h2{font-size:24px}
.modal-header{padding:12px 14px}
.song-grid{padding:10px 12px;gap:8px}
.song-grid label{font-size:11px}
.song-grid input,.song-grid textarea,.song-grid select{font-size:12px;padding:7px}
.song-audit-meta{font-size:11px;padding:8px 12px 10px}
#songPubContractsModal .gm-pubcontracts-body{padding:10px 12px;gap:10px}
#songPubContractsModal .gm-pricing-head{font-size:14px}
#songPubContractsModal .gm-pricing-head span:last-child{font-size:24px}
#songPubContractsModal .gm-pricing-icon{width:44px;height:44px;font-size:20px}
#songPubContractsModal .gm-pricing-item input,#songPubContractsModal .gm-add-ownership-form input,#songPubContractsModal .gm-add-ownership-form select,#songPubContractsModal .gm-contract-form input,#songPubContractsModal .gm-contract-form select{padding:8px 9px;font-size:14px}
#songPubContractsModal .gm-ownership-progress{padding:10px;gap:10px}
#songPubContractsModal .gm-ownership-progress-text{font-size:16px}
#songPubContractsModal .gm-ownership-progress-pct{font-size:30px}

/* Login page makeover */
.login-body{overflow:auto;background:#f2f4f9}
.login-shell{min-height:100vh;display:grid;grid-template-columns:560px 1fr}
.login-brand{position:relative;background:radial-gradient(circle at 25% 20%,#0d2a7a 0%,#05133d 55%,#020b24 100%);color:#e6eeff;padding:48px 44px;overflow:hidden}
.login-brand::after{content:'';position:absolute;left:-18%;right:-18%;bottom:-180px;height:320px;background:radial-gradient(ellipse at center,rgba(42,88,255,.35) 0%,rgba(42,88,255,0) 66%)}
.login-brand-inner{position:relative;z-index:1;max-width:390px;margin:0 auto;display:grid;gap:18px;justify-items:center;text-align:center}
.login-logo-wrap{width:210px;height:210px;border-radius:38px;border:1px solid rgba(132,165,255,.42);display:grid;place-items:center;background:rgba(8,22,66,.58)}
.login-logo{width:100%;height:100%;object-fit:cover;border-radius:38px}
.login-brand h1{margin:6px 0 0;font-size:56px;line-height:1.02;letter-spacing:-1px;color:#f8fbff;text-align:center}
.login-brand h1 span{color:#3f6bff}
.login-brand p{margin:0;font-size:40px;color:#b9c9f6;line-height:1.45;text-align:center}
.login-main{display:grid;place-items:center;padding:40px 20px}
.login-mobile-brand{display:none}
.login-card{width:min(680px,92vw);background:#fff;border:1px solid #e6ecf7;border-radius:26px;box-shadow:0 12px 28px rgba(15,23,42,.08);padding:36px 38px;display:grid;gap:16px}
.login-card-head{display:grid;justify-items:center;gap:12px;text-align:center}
.login-icon{width:68px;height:68px;border-radius:16px;background:#f4f7ff;display:grid;place-items:center;font-size:30px;margin:0 auto}
.login-card h2{margin:0;font-size:34px;letter-spacing:-.3px}
.login-card p{margin:0;font-size:17px;color:#5d6f90}
#authSubtitle{display:none!important}
.login-google-link{text-decoration:none;display:block}
.login-google-btn{width:100%;padding:11px 16px;background:#fff;border:1px solid #dadce0;border-radius:24px;font-size:15px;font-weight:500;font-family:'Google Sans','Roboto',sans-serif;color:#3c4043;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 1px 2px rgba(60,64,67,.2),0 1px 3px rgba(60,64,67,.1);transition:box-shadow .15s,background .15s;letter-spacing:.25px;cursor:pointer}
.login-google-btn:hover{box-shadow:0 2px 6px rgba(60,64,67,.25),0 1px 3px rgba(60,64,67,.15);background:#f8f9fa}
.login-divider{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;color:#64748b;font-size:16px}
.login-divider::before,.login-divider::after{content:'';height:1px;background:#d9e2f0}
.login-form{display:grid;gap:12px}
.login-form label{display:grid;gap:6px;font-size:18px;color:#0f172a}
.login-form input{padding:12px 14px;border-radius:12px;font-size:18px}
.login-pass-wrap{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.login-pass-toggle{padding:10px 12px;border-radius:12px;border:1px solid #d5dfef;background:#fff;color:#0f172a;font-weight:800;cursor:pointer}
.login-pass-toggle:hover{background:#f8fbff}
.login-submit{width:100%;font-size:18px;padding:12px 14px}
.login-links{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.login-links a{font-size:16px}
.login-message{font-size:14px;min-height:24px}

@media (min-width: 981px){
  .login-mobile-brand{display:none!important}
}

@media (max-width: 980px){

  .login-shell{grid-template-columns:1fr!important}
  .login-brand{display:none!important;visibility:hidden!important;max-height:0!important;overflow:hidden!important;padding:0!important;margin:0!important}
  .login-brand *{display:none!important}
  .login-main{
    padding:18px 12px 22px!important;
    align-content:start!important;
    gap:12px!important;
    background:
      radial-gradient(circle at 20% 0%,rgba(53,93,255,.26),rgba(53,93,255,0) 45%),
      linear-gradient(180deg,#eef3ff 0%,#f5f7fc 44%,#f1f4fa 100%)!important;
  }
  .login-mobile-brand{
    width:min(620px,95vw)!important;
    display:grid!important;
    justify-items:center!important;
    text-align:center!important;
    gap:8px!important;
    padding:10px 12px 2px!important;
    overflow:hidden!important;
  }
  /* Mobile uses the exact same logo markup/styles as desktop (.login-logo-wrap + .login-logo)
     so we don't have two slightly-different logos drifting over time. DRY, baby. */
  .login-mobile-logo{display:none!important}
  .login-mobile-brand .login-logo-wrap{
    width:72px!important;
    height:72px!important;
    border-radius:16px!important;
    border:1px solid rgba(94,125,255,.45)!important;
    display:grid!important;
    place-items:center!important;
    background:rgba(8,22,66,.58)!important;
    box-shadow:0 10px 20px rgba(33,56,128,.22)!important;
  }
  .login-mobile-brand .login-logo{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    border-radius:16px!important;
    display:block!important;
  }
  .login-mobile-brand h1{
    margin:2px 0 0!important;
    font-size:28px!important;
    line-height:1.05!important;
    letter-spacing:-.3px!important;
    color:#11204a!important;
  }
  .login-mobile-brand h1 span{color:#2d5bff!important}
  .login-mobile-brand p{
    margin:0!important;
    font-size:14px!important;
    color:#4f6291!important;
    letter-spacing:.2px!important;
  }
  .login-card{
    padding:20px 16px 18px!important;
    border-radius:20px!important;
    width:min(620px,95vw)!important;
    border-color:#dfe8fb!important;
    box-shadow:0 16px 34px rgba(20,39,95,.10)!important;
  }
  .login-card h2{font-size:46px!important}
  .login-card p{font-size:20px!important}
  .login-google-btn,.login-divider,.login-form label,.login-form input,.login-submit,.login-links a,.login-message{font-size:18px!important}
}
@keyframes gm-spin{to{transform:rotate(360deg)}}
.gm-page-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:80px 20px;color:#64748b;font-size:14px}
.gm-page-loader-ring{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#2457f5;border-radius:50%;animation:gm-spin .7s linear infinite}
.gm-skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e8edf4 50%,#f1f5f9 75%);background-size:200% 100%;animation:gm-skeleton-shimmer 1.4s ease infinite;border-radius:8px}
@keyframes gm-skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* ── Song detail grouped form ────────────────────────────────────────────── */
.sg-section{padding:16px 24px}
.sg-section-first{padding-top:20px}
.sg-section+.sg-section{border-top:1px solid #f0f4f9}
.sg-group-label{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#94a3b8;margin-bottom:10px}
.sg-row{display:grid;gap:12px}
.sg-cols-identity{grid-template-columns:1.6fr 1fr 1fr}
.sg-cols-4{grid-template-columns:repeat(4,1fr)}
.sg-cols-5{grid-template-columns:repeat(5,1fr)}
.sg-cols-3{grid-template-columns:repeat(3,1fr)}
.sg-cols-2{grid-template-columns:2fr 1fr}
.sg-label-field{display:grid;gap:5px;font-size:11px;font-weight:600;letter-spacing:.5px;color:#8496b0;text-transform:uppercase}
.sg-title-field input{font-size:16px!important;font-weight:600!important;color:#0f172a!important}
.sg-label-field input,.sg-label-field textarea,.sg-label-field select{padding:9px 11px;border:1px solid #dce5f2;border-radius:10px;font-size:13.5px;color:#1e293b;background:#fff;width:100%;transition:border-color .15s,box-shadow .15s}
.sg-label-field input:focus,.sg-label-field textarea:focus,.sg-label-field select:focus{outline:none;border-color:#93b4f5;box-shadow:0 0 0 3px rgba(36,87,245,.09)}
.sg-label-field input:disabled,.sg-label-field textarea:disabled,.sg-label-field select:disabled{background:#f8fafc;color:#334155;border-color:#e8edf6;cursor:default;opacity:1}
.sg-label-field textarea{min-height:90px;resize:vertical;line-height:1.5}
@media(max-width:1250px){.sg-cols-identity,.sg-cols-5{grid-template-columns:repeat(2,1fr)}.sg-cols-4{grid-template-columns:repeat(2,1fr)}.sg-cols-3{grid-template-columns:1fr}.sg-cols-2{grid-template-columns:1fr}}
/* ── Inline pub/contracts section inside song modal ─────────────────────── */
#songPubContractsSection .gm-pubcontracts-body{padding:14px 16px;display:grid;gap:14px}
#songPubContractsSection .gm-section{border-radius:18px;border:1px solid #dfe7f5;box-shadow:0 2px 8px rgba(30,41,59,.04)}
#songPubContractsSection .gm-pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;align-items:start}
#songPubContractsSection .gm-pricing-item{display:grid;gap:8px}
#songPubContractsSection .gm-pricing-head{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:#0f172a}
#songPubContractsSection .gm-pricing-head span:last-child{font-size:33px;font-weight:700}
#songPubContractsSection .gm-pricing-icon{width:52px;height:52px;display:grid;place-items:center;border:1px solid #d8e3f7;border-radius:12px;background:#f8fbff;font-size:26px}
#songPubContractsSection .gm-pricing-item label{display:grid;gap:4px;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}
#songPubContractsSection .gm-pricing-item input,#songPubContractsSection .gm-add-ownership-form input,#songPubContractsSection .gm-add-ownership-form select,#songPubContractsSection .gm-contract-form input,#songPubContractsSection .gm-contract-form select{width:100%;padding:9px 10px;border:1px solid #d7e0ef;border-radius:9px;background:#fff;font-size:16px;color:#0f172a}
#songPubContractsSection .gm-pricing-actions{grid-column:1/-1}
#songPubContractsSection .gm-section-head{display:flex;justify-content:space-between;align-items:center;gap:10px}
#songPubContractsSection .gm-btn{border:1px solid #cdd8eb;background:#fff;color:#0f172a;border-radius:10px;padding:8px 12px;cursor:pointer;font-weight:600}
#songPubContractsSection .gm-btn-primary{background:#2457f5;border-color:#1d4ed8;color:#fff}
#songPubContractsSection .gm-btn-danger-lite{color:#b42318;background:#fff;border-color:#f4c7c3}
#songPubContractsSection .status-pill{display:inline-block;padding:3px 8px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.4px}
#songPubContractsSection .status-pending{background:#fff7dd;color:#b98900;border:1px solid #f2d98d}
#songPubContractsSection .status-approved{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}
#songPubContractsSection .status-rejected{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}
#songPubContractsSection .gm-ownership-table th,#songPubContractsSection .gm-ownership-table td{font-size:14px}
#songPubContractsSection .gm-ownership-progress{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:14px;margin:10px 0 12px;padding:14px;border:1px solid #dbe4f2;border-radius:12px;background:#fbfdff}
#songPubContractsSection .gm-ownership-progress-icon{width:52px;height:52px;display:grid;place-items:center;border:1px solid #d8e3f7;border-radius:12px;background:#f1f6ff;font-size:24px}
#songPubContractsSection .gm-ownership-progress-label{font-size:13px;font-weight:700;color:#64748b;letter-spacing:.3px}
#songPubContractsSection .gm-ownership-progress-text{font-size:20px;color:#64748b;font-weight:600;white-space:nowrap}
#songPubContractsSection .gm-ownership-progress-text b{color:#2457f5}
#songPubContractsSection .gm-ownership-progress-text span{margin:0 8px;color:#94a3b8}
#songPubContractsSection .gm-ownership-progress-bar-wrap{width:100%}
#songPubContractsSection .gm-ownership-progress-bar{width:100%;height:18px;border-radius:999px;background:#e9edf3;overflow:hidden}
#songPubContractsSection .gm-ownership-progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2457f5,#336dff)}
#songPubContractsSection .gm-ownership-progress-pct{font-size:40px;line-height:1;font-weight:800;color:#2457f5;min-width:90px;text-align:right}
#songPubContractsSection .gm-add-ownership-form{grid-template-columns:2fr 1fr 1fr auto;gap:8px;align-items:end}
#songPubContractsSection .gm-publisher-contract-section{border:1px solid #dbe3f1;border-radius:12px;padding:8px 10px;display:grid;gap:10px}
#songPubContractsSection .gm-publisher-contract-summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px;font-weight:700;padding:4px 2px}
#songPubContractsSection .gm-publisher-contract-summary::-webkit-details-marker{display:none}
#songPubContractsSection .gm-publisher-contract-section:not([open]) .gm-product-contract-grid{display:none}
#songPubContractsSection .gm-product-contract-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
#songPubContractsSection .gm-contract-card{border:1px solid #dbe3f1;border-radius:10px;padding:10px;display:grid;gap:8px;background:#fff}
#songPubContractsSection .gm-contract-card-header{display:flex;justify-content:space-between;align-items:center}
#songPubContractsSection .gm-contract-form{display:grid;gap:8px}
#songPubContractsSection .gm-contract-form label{display:grid;gap:4px}
#songPubContractsSection .date-empty-indicator{font-size:12px;color:#64748b}
@media(max-width:1250px){#songPubContractsSection .gm-pricing-grid,#songPubContractsSection .gm-product-contract-grid{grid-template-columns:1fr}#songPubContractsSection .gm-ownership-progress{grid-template-columns:1fr;gap:10px}#songPubContractsSection .gm-ownership-progress-text{font-size:16px;white-space:normal}#songPubContractsSection .gm-ownership-progress-pct{font-size:28px;text-align:left;min-width:0}#songPubContractsSection .gm-pubcontracts-body{padding:10px 12px;gap:10px}#songPubContractsSection .gm-pricing-head{font-size:14px}#songPubContractsSection .gm-pricing-head span:last-child{font-size:24px}#songPubContractsSection .gm-pricing-icon{width:44px;height:44px;font-size:20px}#songPubContractsSection .gm-pricing-item input,#songPubContractsSection .gm-add-ownership-form input,#songPubContractsSection .gm-add-ownership-form select,#songPubContractsSection .gm-contract-form input,#songPubContractsSection .gm-contract-form select{padding:8px 9px;font-size:14px}}
/* ── Mobile (phones ≤640px) ──────────────────────────────────────────────── */
@media(max-width:640px){
  /* Layout & spacing */
  .content{padding:0 10px 8px}
  .topbar{flex-wrap:wrap;gap:6px;padding:8px 0 6px}
  .topbar h1{font-size:24px}
  .topbar>div{flex:1;min-width:0}
  .topbar input{width:100%;max-width:none;padding:9px 12px;font-size:15px}
  /* KPI cards — 2 col on phone */
  .cards{grid-template-columns:1fr 1fr;gap:10px}
  .dash-kpi-cards{grid-template-columns:1fr 1fr!important}
  .dash-months{grid-template-columns:1fr 1fr!important}
  .dash-bottom{grid-template-columns:1fr!important}
  .card .value{font-size:26px}
  .card{padding:12px}
  .kpiIcon{width:36px;height:36px}
  .kpiIcon svg{width:18px;height:18px}
  /* Panels */
  .panel h3{font-size:20px}
  .panel{padding:12px}
  /* Tables */
  .table th,.table td{padding:9px 6px;font-size:13px}
  /* Modals — bottom sheet on phones */
  .modal-backdrop{padding:0;align-items:flex-end;padding-bottom:env(safe-area-inset-bottom)}
  .modal-card{width:100%;max-width:100%;border-radius:20px 20px 0 0;height:92dvh;border-bottom:none}
  .modal-header{padding:12px 14px}
  .modal-header h2{font-size:18px}
  .modal-header button{padding:6px 10px}
  /* Song form */
  .sg-section{padding:12px 14px}
  .sg-cols-identity,.sg-cols-4,.sg-cols-5,.sg-cols-3,.sg-cols-2{grid-template-columns:1fr}
  /* Toolbar filters — wrap & full width on phone */
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar label{width:100%}
  .toolbar input,.toolbar select{width:100%;font-size:15px}
  /* Buttons — bigger tap targets */
  button{min-height:42px;padding:10px 14px;touch-action:manipulation}
  .modal-header button{min-height:36px}
  nav a{padding:11px 12px}
  /* Sidebar — wider on phone when open */
  .sidebar{width:min(280px,85vw)}
  /* Pub/contracts sections */
  #songPubContractsSection .gm-add-ownership-form{grid-template-columns:1fr}
  #songPubContractsSection .gm-product-contract-grid{grid-template-columns:1fr}
  #songPubContractsSection .gm-pubcontracts-body{padding:8px 10px}
  /* Topbar search full row */
  #globalSearch{display:block}
}

/* ── Tools back navigation ───────────────────────────────────────────────── */
.tools-back{margin-bottom:12px}
.tools-back a{font-size:13px;font-weight:600;color:#2563eb;text-decoration:none;display:inline-flex;align-items:center;gap:4px;padding:4px 0;opacity:.85;transition:opacity .15s}
.tools-back a:hover{opacity:1;text-decoration:underline}

/* ── Publisher songs accordion ───────────────────────────────────────────── */
.pub-songs-accordion{display:grid;gap:4px;margin-top:4px}

.pub-song-header{display:grid;grid-template-columns:32px 1fr 90px 130px 100px 100px 110px;align-items:center;gap:8px;padding:10px 10px 10px 4px}
.pub-song-header-labels{padding:4px 10px 4px 4px;font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:#94a3b8}

.pub-song-card{border:1px solid #e8edf6;border-radius:10px;background:#fff;transition:border-color .15s}
.pub-song-card:hover{border-color:#c7d7f0}
.pub-song-card-open{border-color:#bfdbfe;background:#fafcff}

.pub-song-toggle{width:28px;height:28px;border-radius:6px;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;flex-shrink:0;padding:0;transition:background .15s}
.pub-song-toggle:hover{background:#f1f5f9;color:#1e293b}
.pub-song-toggle-empty{cursor:default;opacity:.3}
.pub-song-toggle-empty:hover{background:transparent;color:#64748b}
.pub-song-chevron{width:14px;height:14px;transition:transform .2s;flex-shrink:0}

.pub-song-name-link{font-weight:600;font-size:14px;color:#1e293b;cursor:pointer;text-decoration:none}
.pub-song-name-link:hover{color:#2563eb;text-decoration:underline}

.pub-song-share{font-size:13.5px;color:#334155;font-weight:500}
.pub-song-status-cell{display:flex;align-items:center}
.pub-song-date{font-size:13px}
.pub-song-contract-count{text-align:right}

.pub-song-contracts-body{border-top:1px solid #e8edf6}

@media(max-width:640px){
  .pub-song-header{grid-template-columns:28px 1fr 80px;gap:6px}
  .pub-song-header-labels{display:none}
  .pub-song-share,.pub-song-date,.pub-song-contract-count{display:none}
  .pub-song-status-cell{display:none}
}

/* ── Publisher contract detail cards ─────────────────────────────────────── */
.pub-ctr-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 20px}
.pub-ctr-kv{display:flex;flex-direction:column;gap:1px}
.pub-ctr-kv span{font-size:10.5px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:#94a3b8}
.pub-ctr-kv b{font-size:13px;font-weight:600;color:#1e293b}

/* ── Viewer mode — read-only enforcement ─────────────────────────────────── */
body.viewer-mode .gm-btn-primary,
body.viewer-mode .gm-btn-danger-lite{display:none!important}
body.viewer-mode #appRoot button:not(.viewer-safe){pointer-events:none}
body.viewer-mode #appRoot input:not(.toolbar input):not(#globalSearch),
body.viewer-mode #appRoot select:not(.toolbar select),
body.viewer-mode #appRoot textarea{pointer-events:none!important;background:#f8fafc!important;color:#94a3b8!important;cursor:not-allowed!important}
body.viewer-mode #appRoot [class*="openUserProfile"],[body.viewer-mode] #appRoot [class*="editRow"]{cursor:default!important;pointer-events:none}
