:root{--bg: #f5f0e8;--surface: #fffdf9;--surface-soft: #f8f4ed;--text: #1f1a17;--text-soft: #6f675f;--line: #e6ddd2;--gold: #c79345;--gold-2: #b68135;--green: #254f45;--green-2: #325f54;--green-soft: #e7efe9;--danger: #bf4d4d;--radius: 16px;--radius-lg: 24px;--shadow: 0 10px 30px rgba(31, 26, 23, .05);--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-body);background:var(--bg);color:var(--text)}button,input,select,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}.eyebrow{margin:0 0 .45rem;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:700;color:var(--gold)}.muted{color:var(--text-soft);margin:0}.muted-inline{color:var(--text-soft);font-size:.83rem}.stack-lg{display:grid;gap:1.5rem}.stack-md{display:grid;gap:1rem}.splash-screen{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,var(--green),#356a5e);gap:1.5rem}.splash-logo{width:96px}.spinner{width:34px;height:34px;border-radius:999px;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-shell{min-height:100vh;display:grid;grid-template-columns:1.15fr .85fr}.login-brand-panel{background:linear-gradient(135deg,var(--green),#356a5e);color:#fff;padding:5rem;display:grid;align-content:center}.login-brand-panel h1{font-family:var(--font-display);font-size:clamp(3rem,5vw,4.8rem);margin:0 0 1rem}.login-quote{max-width:28rem;color:#ffffffc7;line-height:1.65}.login-logo{width:112px;margin-bottom:1.5rem}.login-form-panel{display:grid;place-items:center;padding:3rem;background:var(--surface)}.auth-card{width:min(100%,430px);background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:2rem}.auth-card h2{margin:0 0 .5rem;font-family:var(--font-display);font-size:2rem}.auth-card label{display:grid;gap:.45rem;margin-top:1rem}.auth-card span,.section-grid label span,.modal-body-pro label span{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft)}input,select,textarea{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:.9rem 1rem;color:var(--text)}textarea{min-height:110px;resize:vertical}input:focus,select:focus,textarea:focus{outline:2px solid rgba(199,147,69,.18);border-color:var(--gold)}.form-error{color:var(--danger);margin-top:.9rem}.app-shell{min-height:100vh;display:grid;grid-template-columns:290px 1fr}.sidebar-pro{background:linear-gradient(180deg,#20483f,#17362f);color:#fff;padding:1.25rem;display:grid;grid-template-rows:auto 1fr auto;gap:1.25rem;position:sticky;top:0;height:100vh}.sidebar-top{display:flex;align-items:center;gap:.9rem}.brand-logo{width:48px;height:48px;object-fit:contain}.brand-name{font-family:var(--font-display);font-size:1.35rem}.brand-sub{color:#ffffffb3;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em}.nav-group{margin-bottom:1rem}.nav-group-label{font-size:.72rem;color:#ffffff8f;text-transform:uppercase;letter-spacing:.12em;margin:0 0 .5rem .4rem}.nav-link{width:100%;display:flex;align-items:center;gap:.75rem;border:0;background:transparent;color:#ffffffc7;padding:.85rem .95rem;border-radius:14px;margin-bottom:.25rem}.nav-link.active,.nav-link:hover{background:#ffffff1f;color:#fff}.sidebar-user{background:#ffffff14;border:1px solid rgba(255,255,255,.08);padding:.8rem;border-radius:16px;display:flex;align-items:center;gap:.75rem}.avatar{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;background:#ffffff29;font-weight:700}.sidebar-user-copy{flex:1;display:grid}.sidebar-user-copy strong{font-size:.92rem}.sidebar-user-copy span{font-size:.74rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.08em}.icon-button{border:1px solid var(--line);background:#fff;width:38px;height:38px;border-radius:999px}.main-shell{padding:1.4rem 1.6rem 2rem}.page-header-pro{background:#ffffffb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:22px;padding:1.4rem 1.5rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.page-header-pro h1{margin:0 0 .35rem;font-family:var(--font-display);font-size:2.3rem}.page-content{display:grid;gap:1.5rem}.header-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:flex-end}.hero-card,.toolbar-card,.panel,.stat-card-pro{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.hero-card{padding:2rem;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--green),#356a5e);color:#fff}.hero-card h2{margin:0 0 .35rem;font-family:var(--font-display);font-size:2.3rem}.hero-card p{margin:0;color:#ffffffc2}.hero-logo{width:70px;opacity:.95}.toolbar-card{padding:1.5rem;display:flex;justify-content:space-between;gap:1rem;align-items:end}.toolbar-card.compact{align-items:center}.toolbar-card h2{margin:0 0 .3rem;font-family:var(--font-display);font-size:1.7rem}.toolbar-actions{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}.search-field{min-width:260px}.stats-grid-pro{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stat-card-pro{padding:1.4rem;display:grid;gap:.75rem}.stat-head{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-soft)}.stat-number{font-family:var(--font-display);font-size:3rem;line-height:1}.stat-empty,.stat-note{margin:0;color:var(--text-soft);font-size:.92rem;min-height:3rem}.text-link{border:0;background:transparent;color:var(--green);font-weight:700;justify-self:start;padding:0}.two-col-dashboard{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem}.panel{padding:1.35rem}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-head h3{margin:0;font-family:var(--font-display);font-size:1.45rem}.badge-brand,.badge-neutral,.badge-status{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.35rem .75rem;font-size:.76rem;font-weight:700}.badge-brand{background:#c793451f;color:var(--gold-2);border:1px solid rgba(199,147,69,.25)}.badge-neutral{background:var(--surface-soft);color:var(--text-soft);border:1px solid var(--line)}.badge-status.is-active{background:#296d551c;color:#296d55;border:1px solid rgba(41,109,85,.2)}.review-box{min-height:56px;border:1.5px solid var(--line);border-radius:var(--radius);background:var(--card);padding:12px 14px;color:var(--text);line-height:1.55;white-space:pre-wrap}.group-card-highlight{border-color:#c79345b3;background:linear-gradient(180deg,#fffdf9,#fff8ef);box-shadow:0 0 0 3px #c7934524,0 20px 42px #1f1a1714;transform:translateY(-2px);transition:all .28s ease}.badge-status.is-danger{background:#b428281f;color:#b42828;border:1px solid rgba(180,40,40,.25)}.badge-status.is-inactive{background:#bf4d4d1a;color:var(--danger);border:1px solid rgba(191,77,77,.22)}.check-list{margin:0;padding-left:1.1rem;display:grid;gap:.8rem;color:var(--text-soft)}.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}.mini-card,.instrument-card{background:var(--surface-soft);border:1px solid var(--line);border-radius:16px;padding:1rem;display:grid;gap:.35rem}.mini-card span,.instrument-card span{color:var(--text-soft);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.mini-card strong,.instrument-card strong{font-family:var(--font-display);font-size:1.45rem}.instrument-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem}.table-shell{overflow:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:1rem .8rem;border-bottom:1px solid var(--line);vertical-align:middle}th{font-size:.72rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.1em}.entity-line{display:flex;align-items:center;gap:.85rem}.entity-line strong{display:block}.entity-line span{display:block;color:var(--text-soft);font-size:.83rem;margin-top:.15rem}.entity-thumb{width:42px;height:42px;border-radius:12px;object-fit:cover}.entity-thumb-fallback{display:grid;place-items:center;background:var(--green-soft);color:var(--green);font-weight:700}.row-actions{display:flex;gap:.6rem;flex-wrap:wrap}.loader-shell{min-height:220px;display:grid;place-items:center}.empty-state-pro{min-height:260px;display:grid;place-items:center;text-align:center;padding:2rem}.empty-state-pro h3{margin:.2rem 0 .45rem;font-family:var(--font-display);font-size:1.65rem}.empty-state-pro p{max-width:40rem;color:var(--text-soft);margin:0 0 1rem}.empty-icon{font-size:2.2rem;color:var(--gold)}.btn{border-radius:999px;padding:.82rem 1.15rem;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:700}.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));border-color:transparent;color:#fff}.btn-outline:hover{border-color:var(--gold);color:var(--gold-2)}.btn-danger{border-color:#bf4d4d33;color:var(--danger);background:#bf4d4d0d}.btn-warning{border-color:#c7934540;color:var(--gold-2);background:#c7934514}.chip-filter{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:999px;padding:.55rem .9rem;font-size:.88rem;font-weight:700;transition:all .18s ease}.chip-filter:hover{border-color:var(--gold);color:var(--gold-2);transform:translateY(-1px)}.chip-filter.active{background:#c793451f;color:var(--gold-2);border-color:#c7934559}.tabs{display:flex;gap:.75rem;flex-wrap:wrap}.tab{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:999px;padding:.72rem 1rem;font-weight:700}.tab.active{background:var(--green);color:#fff;border-color:var(--green)}.attendance-card{background:var(--surface-soft);border:1px solid var(--line);border-radius:18px;padding:1rem;display:grid;gap:.8rem;margin-bottom:1rem}.attendance-name{font-weight:700;font-size:1rem}.status-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.status-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.5rem .85rem;font-weight:700}.status-btn.present.active{background:#296d551c;color:#296d55;border-color:#296d5540}.status-btn.absent.active{background:#bf4d4d1a;color:var(--danger);border-color:#bf4d4d38}.status-btn.retard.active{background:#c793451f;color:var(--gold-2);border-color:#c7934552}.status-btn.excused.active{background:#50587a1a;color:#50587a;border-color:#50587a38}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f1a1752;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;padding:2rem 1.5rem;z-index:50}.modal-pro{width:min(100%,680px);background:#fff;border-radius:24px;border:1px solid var(--line);box-shadow:0 30px 80px #1f1a172e;overflow:hidden;margin:auto 0}.modal-pro.large{width:min(1100px,92vw);max-height:calc(100vh - 4rem);display:flex;flex-direction:column}.modal-header-pro{flex:0 0 auto;padding:1.25rem 1.5rem;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;background:#fff}.modal-header-pro h3{margin:0;font-family:var(--font-display);font-size:1.55rem}.modal-body-pro{flex:1 1 auto;overflow-y:auto;padding:1.5rem;display:grid;gap:1rem}.modal-footer-pro{flex:0 0 auto;display:flex;justify-content:flex-end;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid var(--line);background:#fff;position:sticky;bottom:0;z-index:2}.section-grid{display:grid;gap:1rem}.section-grid.two{grid-template-columns:repeat(2,1fr)}.upload-card{border:1px dashed var(--line);background:var(--surface-soft);border-radius:20px;padding:1rem}.upload-card input{margin-top:.8rem}.photo-preview,.photo-placeholder{width:100%;min-height:220px;border-radius:18px;object-fit:cover;display:grid;place-items:center;background:#fff;margin-top:.65rem}.toast-pro{position:fixed;right:1.25rem;bottom:1.25rem;background:var(--green);color:#fff;padding:.95rem 1.2rem;border-radius:999px;box-shadow:0 16px 40px #254f453d;z-index:80}.login-left{display:flex;align-items:center;justify-content:center;padding:60px;background:linear-gradient(135deg,#1f4d45,#2f6b5f);position:relative;overflow:hidden}.login-left:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.06),transparent 40%);pointer-events:none}.login-left-inner{text-align:center;max-width:520px}.login-logo{width:90px;margin-bottom:24px}.login-location{font-size:12px;letter-spacing:2px;color:#d4a75d;margin-bottom:16px}.login-title{font-family:Playfair Display,serif;letter-spacing:-1px}.login-brand-panel{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:0}.login-left{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:64px;text-align:center}.login-left-inner{width:100%;max-width:620px;margin:0 auto;display:flex;flex-direction:column;align-items:center}html,body{overflow-x:hidden}.login-left:before{content:"";position:absolute;right:-80px;bottom:-80px;width:420px;height:420px;background:url(/violin-outline.svg) no-repeat center;background-size:contain;opacity:.05;pointer-events:none}.login-logo{display:block;width:96px;height:96px;object-fit:contain;margin:0 auto 28px}.login-left-inner{animation:fadeUp .8s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-tagline{font-size:18px;color:#ffffffd9;line-height:1.6;margin-bottom:32px}.login-divider{width:60px;height:2px;background:#d4a75d;margin:0 auto 24px;opacity:.6}.login-subtext{font-size:14px;color:#fff9}.login-left:before{content:"";position:absolute;right:-80px;bottom:-80px;width:400px;height:400px;background:url(/violin-outline.svg) no-repeat center;background-size:contain;opacity:.05}.section-grid.three{display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 900px){.section-grid.three{grid-template-columns:1fr}}.table-shell{overflow-x:auto;-webkit-overflow-scrolling:touch}.search-field,.filter-select{width:100%;min-width:0}.toolbar-actions,.header-actions,.row-actions,.status-buttons,.tabs{flex-wrap:wrap}.hero-logo{flex-shrink:0}@media (max-width: 1200px){.stats-grid-pro{grid-template-columns:repeat(2,1fr)}.instrument-grid{grid-template-columns:repeat(3,1fr)}.two-col-dashboard{grid-template-columns:1fr}.modal-pro.large{width:min(96vw,1000px)}}@media (max-width: 1100px){.app-shell{grid-template-columns:1fr}.sidebar-pro{position:relative;height:auto;border-radius:0 0 24px 24px}.main-shell{padding:1rem 1rem 1.5rem}.page-header-pro{flex-direction:column;align-items:stretch;gap:1rem;padding:1.15rem 1.1rem}.page-header-pro h1{font-size:2rem}.header-actions{justify-content:flex-start}.toolbar-card,.toolbar-card.compact{flex-direction:column;align-items:stretch}.toolbar-actions{width:100%;justify-content:flex-start}.toolbar-actions>*{width:100%}.stats-grid-pro,.mini-grid,.section-grid.two,.login-shell{grid-template-columns:1fr}.instrument-grid{grid-template-columns:repeat(2,1fr)}.hero-card{flex-direction:column;align-items:flex-start;gap:1rem}.hero-card h2{font-size:2rem}.modal-overlay{align-items:flex-start;padding:1rem;overflow-y:auto}.modal-pro.large{width:100%;max-height:calc(100vh - 2rem)}}@media (max-width: 900px){.login-brand-panel{padding:2rem 1.5rem}.login-form-panel{padding:1.25rem}.auth-card{width:100%;padding:1.4rem}.page-header-pro h1{font-size:1.75rem}.hero-card,.panel,.toolbar-card,.stat-card-pro{border-radius:18px}.instrument-grid,.section-grid.three{grid-template-columns:1fr}.modal-header-pro,.modal-body-pro,.modal-footer-pro{padding-left:1rem;padding-right:1rem}.modal-footer-pro{flex-wrap:wrap;justify-content:stretch}.modal-footer-pro .btn{width:100%}.row-actions{flex-direction:column;align-items:stretch}.row-actions .btn{width:100%}.status-buttons{gap:.45rem}.status-btn{min-height:42px}.tabs{display:grid;grid-template-columns:1fr}.tab{width:100%;text-align:center}.check-list{padding-left:1rem}}@media (max-width: 700px){body{font-size:15px}.main-shell{padding:.85rem .85rem 1.25rem}.sidebar-pro{padding:1rem}.sidebar-top{gap:.75rem}.brand-logo{width:42px;height:42px}.brand-name{font-size:1.15rem}.page-header-pro{padding:1rem;border-radius:18px}.hero-card{padding:1.2rem}.hero-card h2{font-size:1.7rem}.toolbar-card,.panel,.stat-card-pro{padding:1rem}.stat-number{font-size:2.25rem}.mini-card,.instrument-card,.attendance-card{padding:.85rem}.entity-line{align-items:flex-start}.entity-thumb{width:38px;height:38px}th,td{padding:.8rem .65rem}.modal-overlay{padding:.5rem}.modal-pro,.modal-pro.large{width:100%;border-radius:18px;max-height:calc(100vh - 1rem)}.modal-header-pro h3{font-size:1.2rem}.photo-preview,.photo-placeholder{min-height:180px}.chip-filter{width:100%;text-align:center}}@media (max-width: 520px){.stats-grid-pro,.mini-grid{grid-template-columns:1fr}.sidebar-user{align-items:flex-start}.sidebar-user-copy strong,.sidebar-user-copy span{word-break:break-word}.page-header-pro h1{font-size:1.5rem}.hero-card h2{font-size:1.45rem}.stat-number{font-size:2rem}.btn,.tab,.nav-link{min-height:44px}.icon-button{width:40px;height:40px}}@media (max-width: 1100px){.app-shell{grid-template-columns:1fr}.sidebar-pro{position:relative;height:auto}.stats-grid-pro,.instrument-grid,.two-col-dashboard,.mini-grid,.section-grid.two,.login-shell{grid-template-columns:1fr}.toolbar-card{align-items:start}.page-header-pro{flex-direction:column;align-items:stretch}.header-actions{justify-content:flex-start}}html,body,#root{width:100%;min-height:100%;overflow-x:hidden}body{max-width:100vw}.app-shell,.main-shell,.page-content,.panel,.toolbar-card,.hero-card,.stat-card-pro,.attendance-card,.mini-card,.instrument-card,.auth-card{min-width:0;max-width:100%}.main-shell,.page-content{overflow-x:hidden}.table-shell{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}table{max-width:none}button,.btn,.nav-link,.tab,.status-btn,.chip-filter,.icon-button,select,input,textarea{touch-action:manipulation}select,input,textarea,button{max-width:100%}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;background:#1f1a1759;padding:1rem;z-index:100;overflow-y:auto;overflow-x:hidden}.modal-pro{margin:0;max-width:100%}.modal-pro.large{width:min(1100px,96vw);max-height:calc(100vh - 2rem)}.modal-body-pro{overflow-x:hidden}@media (max-width: 1100px){.app-shell{grid-template-columns:1fr}.sidebar-pro{position:relative;height:auto;border-radius:0 0 24px 24px}.main-shell{padding:1rem 1rem 1.5rem}.page-header-pro{flex-direction:column;align-items:stretch}.stats-grid-pro,.instrument-grid,.two-col-dashboard,.mini-grid,.section-grid.two,.login-shell{grid-template-columns:1fr}.toolbar-card,.toolbar-card.compact{flex-direction:column;align-items:stretch}.toolbar-actions,.header-actions,.row-actions,.status-buttons,.tabs{flex-wrap:wrap}}@media (max-width: 900px){.section-grid.three{grid-template-columns:1fr}.modal-header-pro,.modal-body-pro,.modal-footer-pro{padding-left:1rem;padding-right:1rem}.modal-footer-pro{flex-wrap:wrap;justify-content:stretch}.modal-footer-pro .btn,.row-actions .btn,.tab,.chip-filter{width:100%}}@media (max-width: 700px){body{font-size:15px}.main-shell{padding:.85rem}.page-header-pro,.hero-card,.toolbar-card,.panel,.stat-card-pro{border-radius:18px}.hero-card,.toolbar-card,.panel,.stat-card-pro{padding:1rem}.modal-overlay{padding:.5rem;align-items:center}.modal-pro,.modal-pro.large{width:100%;max-height:calc(100vh - 1rem);border-radius:18px}.btn,.tab,.nav-link{min-height:44px}}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}.app-shell,.main-shell,.page-content,.panel,.toolbar-card,.hero-card,.stat-card-pro,.attendance-card,.mini-card{max-width:100%;overflow-x:hidden}.table-shell{width:100%;max-width:100%;overflow-x:auto}.table-shell table{width:max-content;min-width:100%}td,th,p,span,strong,div{overflow-wrap:anywhere}input,select,textarea,button,.btn{max-width:100%}
