@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";:root{color-scheme:light;--font-body: "Manrope", "Helvetica Neue", sans-serif;--font-display: "Space Grotesk", "Helvetica Neue", sans-serif;--ink: #1e1a16;--muted: #5d5a55;--paper: #ffffff;--accent: #0f5c5c;--accent-soft: #d7f0ee;--highlight: #f5b14c;--border: #e4ded6;--shadow: 0 24px 60px rgba(24, 16, 7, .12);background-color:#f4f0e9;color:var(--ink);font-family:var(--font-body)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 15% 15%,#f8efe0,#f2ece2 45%,#e8e0d4)}button,input,select,textarea{font-family:inherit}button:disabled{opacity:.6;cursor:not-allowed}.app-shell{min-height:100vh;padding:32px 20px}.app-shell.is-login{display:flex;align-items:center;justify-content:center}.app-shell.is-auth{display:block}.login-shell{width:100%;display:flex;justify-content:center}.login-hero{padding:32px;border-radius:24px;background:linear-gradient(135deg,#0f5c5c33,#f5b14c33);display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow)}.login-hero h1{font-family:var(--font-display);margin:0;font-size:clamp(28px,4vw,40px)}.login-hero p{margin:0;color:var(--muted);line-height:1.5}.login-card{background:var(--paper);padding:32px;border-radius:24px;box-shadow:var(--shadow);display:grid;gap:20px;width:min(460px,100%)}.login-brand{display:grid;gap:4px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:11px}.login-brand strong{font-family:var(--font-display);text-transform:none;letter-spacing:.02em;font-size:16px;color:var(--ink)}.login-card h2{margin:0;font-family:var(--font-display)}.login-card form{display:grid;gap:16px}.login-card label{display:grid;gap:8px;font-size:14px;color:var(--muted)}.login-card input{padding:12px 14px;border-radius:12px;border:1px solid var(--border);font-size:14px;background:#fcfbf9}.login-card button{padding:12px 16px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-weight:600;cursor:pointer}.login-card .ghost{background:#fff;color:var(--ink);border:1px solid var(--border)}.login-divider{margin:16px 0 12px;text-align:center;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.2em}.invite-form{margin-top:12px;display:grid;gap:12px}.crm-page{width:100%;display:flex;flex-direction:column;gap:24px}.crm-shell{display:flex;flex-direction:column;gap:18px;width:min(1280px,100%);margin:0 auto}.crm-tabs{display:flex;flex-wrap:wrap;gap:10px;padding:8px;border-radius:16px;background:var(--paper);box-shadow:var(--shadow);width:100%}.crm-tab{border:none;border-radius:999px;padding:8px 16px;background:transparent;color:var(--muted);font-weight:600;cursor:pointer}.crm-tab.is-active{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1px var(--border)}.desktop-only{display:block}.mobile-only{display:none}.crm-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.crm-topbar h1{margin:6px 0;font-family:var(--font-display);font-size:clamp(28px,3vw,36px)}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--muted)}.subtle{margin:0;color:var(--muted);max-width:420px;font-size:14px}.topbar-actions{display:flex;gap:12px;flex-wrap:wrap}.primary,.ghost,.danger{border:none;border-radius:12px;padding:10px 16px;font-weight:600;cursor:pointer}.primary{background:var(--accent);color:#fff}.ghost{background:#fff;border:1px solid var(--border);color:var(--ink)}.danger{background:#d64545;color:#fff}.crm-grid{display:grid;grid-template-columns:minmax(0,3fr) minmax(240px,1fr);gap:20px}.calendar-card{background:var(--paper);padding:20px;border-radius:20px;box-shadow:var(--shadow)}.calendar-toolbar{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:12px}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th,.data-table td{padding:10px 8px;text-align:left;border-bottom:1px solid #efe7dc;vertical-align:top}.data-table th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.table-scroll{width:100%;overflow-x:auto}.table-empty{text-align:center;color:var(--muted);padding:20px 0}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:20px}.metric-card{background:#fff;border-radius:16px;padding:16px;box-shadow:var(--shadow);display:grid;gap:8px}.metric-card span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.metric-card strong{font-size:22px}.detail-grid{display:grid;gap:12px}.detail-row{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#faf7f2;font-size:14px}.detail-row span{color:var(--muted)}.detail-row strong{font-weight:600}.lesson-list{display:grid;gap:10px;margin-top:12px}.lesson-item{display:grid;grid-template-columns:auto 1fr;align-items:flex-start;gap:12px;padding:12px;border-radius:14px;border:1px solid var(--border);background:#fff}.lesson-item-plain{grid-template-columns:1fr}.lesson-item .toggle{margin-top:2px}.lesson-item.is-unpaid{border-color:#f3d7ab;background:#fff7ec}.lesson-item-body{display:grid;gap:4px}.lesson-meta{font-size:12px;color:var(--muted)}.lesson-warning{font-size:11px;color:#a66300}.unpaid-students{display:flex;flex-wrap:wrap;gap:8px}.unpaid-student{border:1px solid var(--border);background:#faf7f2;color:var(--ink);border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer}.unpaid-student:hover{border-color:#d8cfc4}.tab-switch{display:inline-flex;gap:6px;background:#f3ede3;padding:6px;border-radius:999px}.tab-switch button{border:none;border-radius:999px;padding:6px 12px;font-size:12px;cursor:pointer;background:transparent;color:var(--muted)}.tab-switch button.is-active{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1px var(--border)}.switch-stack{display:grid;gap:12px}.switch-panel{display:none}.switch-panel.is-active{display:block}.info-chip{padding:8px 12px;background:#f2efe9;border-radius:12px;font-size:13px;font-weight:600}.info-chip.is-muted{color:var(--muted);font-weight:500}.info-slot{min-height:48px}.modal-actions{display:flex;justify-content:flex-end;margin-top:16px}.action-stack{justify-content:space-between;gap:10px}.modal-wide{width:min(900px,96vw)}.link-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(200px,1fr);gap:16px}.link-summary{display:flex;justify-content:space-between;color:var(--muted);font-size:12px;margin-bottom:10px}.filters{display:flex;gap:12px;flex-wrap:wrap}.filters label{display:grid;gap:6px;font-size:12px;color:var(--muted)}.filters .select{min-width:180px}.filters .select-label{font-size:12px}.filters .select-trigger{padding:8px 10px;border-radius:10px;font-size:13px}.filters select{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:#faf7f2}.filters input{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:#faf7f2;font-size:13px;color:var(--ink)}.payment-list,.stats-list{display:grid;gap:12px}.payment-card,.stats-card{padding:14px;border-radius:16px;border:1px solid var(--border);background:#fff;display:grid;gap:8px}.payment-main{display:grid;gap:4px}.payment-meta,.stats-meta{font-size:12px;color:var(--muted)}.payment-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.toolbar-hint{font-size:12px;color:var(--muted);align-self:center}.side-panel{display:flex;flex-direction:column;gap:20px}.panel-block{background:var(--paper);padding:18px;border-radius:18px;box-shadow:var(--shadow)}.panel-block h2{font-family:var(--font-display);margin:0 0 12px;font-size:18px}.students-panel{display:grid;gap:16px}.students-toolbar label{display:grid;gap:6px;font-size:13px;color:var(--muted)}.students-toolbar input{padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#fcfbf9;font-size:14px}.student-list{display:grid;gap:12px}.student-line{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff}.student-actions{display:flex;align-items:center;gap:10px}.invite-code{padding:6px 10px;border-radius:999px;background:#f2efe9;font-size:12px;font-weight:600}.student-dashboard{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:20px}.student-pack{grid-column:1 / -1}.pack-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.pack-label{font-size:12px;color:var(--muted)}.pack-value{font-size:15px;font-weight:600}.lesson-list{display:grid;gap:10px}.lesson-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#fff}.lesson-time{font-weight:600}.lesson-meta,.lesson-subtime{font-size:12px;color:var(--muted)}.panel-block ul{margin:0;padding-left:18px;color:var(--muted);display:grid;gap:6px;font-size:13px}.status-legend{display:flex;flex-wrap:wrap;gap:8px}.status-chip{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#f2efe9;color:var(--ink)}.status-planned{background:#e8f6f5;color:#0c5b5b}.status-done{background:#e7f3d7;color:#3d6c1c}.status-canceled{background:#fde8e7;color:#b3261e}.status-unpaid{background:#fff0da;color:#a66300}.loading{margin:12px 0;font-size:13px;color:var(--muted)}.error-banner{margin-top:12px;background:#fdeceb;color:#b42318;padding:10px 12px;border-radius:12px;font-size:13px}.info-banner{margin-top:12px;background:#e8f6f5;color:#0c5b5b;padding:10px 12px;border-radius:12px;font-size:13px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a080666;display:flex;align-items:flex-start;justify-content:center;padding:24px;z-index:50}.modal{width:min(720px,100%);background:var(--paper);border-radius:24px;padding:24px;box-shadow:var(--shadow);display:grid;gap:16px;max-height:90vh;overflow-y:auto;margin-top:24px}.modal-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.modal-header h3{margin:0 0 6px;font-family:var(--font-display)}.modal-loading{padding:24px 0;text-align:center;color:var(--muted)}.lesson-form{display:grid;gap:16px}.lesson-form label{display:grid;gap:8px;font-size:14px;color:var(--muted)}.select{display:grid;gap:6px;position:relative}.select-label{font-size:12px;color:var(--muted)}.select-trigger{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#faf7f2;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;color:var(--ink);cursor:pointer}.select-trigger:disabled{opacity:.6;cursor:not-allowed}.select-caret{width:12px;height:12px;border-right:2px solid #655f57;border-bottom:2px solid #655f57;transform:rotate(45deg)}.select-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 40px #1810071f;padding:8px;z-index:40;max-height:260px;overflow-y:auto}.select-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a080673;display:flex;align-items:flex-end;justify-content:center;padding:16px;z-index:60}.select-sheet{width:min(520px,100%);background:#fff;border-radius:20px 20px 0 0;padding:16px;display:grid;gap:12px;max-height:70vh;overflow:hidden}.select-sheet-header{display:flex;justify-content:space-between;align-items:center;font-weight:600}.select-sheet-header button{background:none;border:none;color:var(--accent);cursor:pointer}.select-sheet-list{display:grid;gap:6px;overflow-y:auto;padding-right:4px}.select-search input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#faf7f2}.select-option{width:100%;border:none;background:transparent;padding:10px 12px;border-radius:10px;text-align:left;cursor:pointer}.select-option.is-selected{background:#e8f6f5;color:#0c5b5b;font-weight:600}.select-hint,.select-empty{font-size:12px;color:var(--muted);padding:6px 4px}.lesson-form input,.lesson-form select,.lesson-form textarea{padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#faf7f2}.lesson-form select,.filters select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 14 10'%3E%3Cpath d='M1 2l6 6 6-6' fill='none' stroke='%23655f57' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}.lesson-form input:disabled{background:#f1ece4;color:#8a8074}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.form-row{grid-column:1 / -1}.datetime-row{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr)) auto;gap:16px;align-items:end;grid-column:1 / -1}.auto-end{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);align-self:end;padding-bottom:6px}.toggle{border:none;background:none;padding:0;display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:var(--muted)}.toggle.is-disabled{opacity:.6;cursor:not-allowed}.toggle-track{width:44px;height:24px;border-radius:999px;background:#e8e1d8;position:relative;box-shadow:inset 0 0 0 1px var(--border);transition:background .2s ease}.toggle-thumb{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;box-shadow:0 4px 10px #1e181033;transition:transform .2s ease}.toggle.is-checked .toggle-track{background:var(--accent);box-shadow:none}.toggle.is-checked .toggle-thumb{transform:translate(20px)}.toggle-sm .toggle-track{width:34px;height:20px}.toggle-sm .toggle-thumb{width:16px;height:16px;top:2px;left:2px}.toggle-sm.is-checked .toggle-thumb{transform:translate(14px)}.toggle-label{font-weight:500}.form-section{display:grid;gap:12px}.form-section h4{margin:0;font-family:var(--font-display);font-size:16px}.segmented{display:flex;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--muted)}.segmented label{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff}.student-search input{width:100%}.student-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;max-height:220px;overflow-y:auto;padding-right:4px}.student-card{border:1px solid var(--border);border-radius:12px;padding:10px;display:grid;grid-template-columns:auto 1fr;row-gap:4px;column-gap:10px;align-items:center;background:#fffdf9;font-size:13px;color:var(--ink);cursor:pointer}.student-name{grid-column:2;font-weight:600}.student-meta{font-size:11px;color:var(--muted);grid-column:2;justify-self:start}.student-search{display:grid;gap:8px}.search-hint{font-size:12px;color:var(--muted)}.error-list{margin-top:8px;background:#fdeceb;color:#b42318;padding:10px 12px;border-radius:12px;font-size:12px;display:grid;gap:4px}.empty-state{font-size:13px;color:var(--muted);padding:6px 0}.new-student-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.conflict-box{padding:10px 12px;border-radius:12px;background:#fff4e5;color:#7a3b00;font-size:13px}.conflict-box ul{margin:6px 0 0;padding-left:18px;display:grid;gap:4px}.form-actions,.detail-actions{display:flex;gap:12px;flex-wrap:wrap}.lesson-details{display:grid;gap:12px}.detail-row{display:flex;justify-content:space-between;gap:12px;font-size:14px}.detail-row strong{color:var(--ink)}.event-card{display:grid;gap:4px}.event-title{font-weight:600;font-size:12px}.event-time{font-size:11px;opacity:.8}.fc .fc-toolbar-title{font-family:var(--font-display);font-size:18px}.fc .fc-button{border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--ink);text-transform:none}.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--accent);color:#fff;border-color:transparent}.fc .fc-timegrid-slot,.fc .fc-daygrid-day{border-color:#efe7dc}.fc .fc-timegrid-event{border-radius:12px;border:none;padding:6px;cursor:pointer}.fc .status-planned{background:#0f5c5c;color:#fff}.fc .status-done{background:#3d6c1c;color:#fff}.fc .status-canceled{background:#d64545;color:#fff}.fc .status-unpaid{background:#f5b14c;color:#2b1a05}@media (max-width: 980px){.crm-grid{grid-template-columns:1fr}.crm-topbar{flex-direction:column;align-items:flex-start}.link-grid{grid-template-columns:1fr}.desktop-only{display:none}.mobile-only{display:block}.student-dashboard{grid-template-columns:1fr}}@media (max-width: 720px){.app-shell{padding:20px 14px}.calendar-card,.panel-block,.login-card,.login-hero{padding:16px}.calendar-toolbar{flex-direction:column;align-items:flex-start}.filters{flex-direction:column;width:100%}.filters label,.filters select,.filters input,.filters .select,.filters .select-trigger{width:100%}.crm-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.crm-tab{white-space:nowrap}.datetime-row{grid-template-columns:repeat(2,minmax(0,1fr))}.auto-end{grid-column:1 / -1;padding-bottom:0}.student-line{flex-direction:column;align-items:flex-start}.student-actions{width:100%;justify-content:flex-start}.detail-row{flex-direction:column;align-items:flex-start}.topbar-actions{width:100%;flex-direction:column;align-items:stretch}.topbar-actions button{width:100%}.action-stack{flex-direction:column;align-items:stretch}.filters select,.filters input,.lesson-form input,.lesson-form select,.lesson-form textarea{font-size:16px}.fc .fc-toolbar{flex-direction:column;align-items:flex-start;gap:8px}.fc .fc-toolbar-chunk{display:flex;flex-wrap:wrap;gap:6px}.fc .fc-button{padding:6px 10px;font-size:12px}.fc .fc-toolbar-title{font-size:16px}.side-panel{display:none}.modal{padding:18px;margin-top:12px}.detail-row{flex-direction:column}}@media (max-width: 540px){.datetime-row{grid-template-columns:1fr}.student-grid{grid-template-columns:1fr;max-height:180px}.student-card{grid-template-columns:20px 1fr}.student-meta{grid-column:2;text-align:left}}
