:root{--color-accent:#3aa1aa;--color-accent-dark:#267b82;--color-accent-soft:#e5f5f6;--color-border:#dce5e6;--color-danger:#c94b4b;--color-ink:#182225;--color-muted:#667477;--color-page:#f6f8f8;--color-surface:#ffffff;--color-warning:#d99a22;--color-yellow:#f4d45c;--font-body:"Segoe UI Variable","Segoe UI",system-ui,-apple-system,BlinkMacSystemFont,"Roboto","Helvetica Neue",Arial,sans-serif;--font-heading:"Segoe UI Variable Display","Segoe UI",system-ui,-apple-system,BlinkMacSystemFont,"Roboto","Helvetica Neue",Arial,sans-serif}*{box-sizing:border-box}html{background:var(--color-page);color:var(--color-ink);font-family:var(--font-body)}body,html{max-width:100%;overflow-x:hidden}body{margin:0;min-height:100vh}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;max-width:100%;min-width:0}button{cursor:pointer}.account-card,.app-shell,.card,.content,.dashboard-grid,.day-agenda,.feedback-thread-card,.item-main,.lesson-card,.list-item,.main-area,.month-calendar,.panel-grid,.parent-child-card,.relation-list,.schedule-lesson-form,.selected-lessons,.student-card,.topbar,.topbar-title{min-width:0}.agenda-main span,.agenda-main strong,.card-title,.feedback-message p,.item-meta,.item-title,.lesson-heading-topic,.lesson-main h3,.lesson-note p,.page-title,.relation-value,.student-notes,.summary-tile p{overflow-wrap:anywhere}.app-shell{display:grid;grid-template-columns:264px minmax(0,1fr);min-height:100vh}.sidebar{background:#111a1d;color:#f8fbfb;display:flex;flex-direction:column;gap:32px;padding:28px 20px}.brand{align-items:center;display:flex;gap:12px}.brand-logo{border-radius:8px;display:block;height:auto;max-width:210px;width:100%}.login-card .brand-logo{max-width:235px;padding:0}.login-card .brand{justify-content:center}.nav-list{display:grid;grid-gap:6px;gap:6px}.nav-item{align-items:center;border-radius:8px;color:#d7e0e2;display:flex;gap:10px;padding:11px 12px}.nav-item[data-active=true]{background:rgba(58,161,170,.18);color:#ffffff}.nav-item svg{color:var(--color-accent);height:18px;width:18px}.mobile-bottom-nav{display:none}.mobile-nav-list{display:flex;gap:8px;overflow:visible;padding:8px 12px calc(8px + env(safe-area-inset-bottom))}.mobile-nav-item{align-items:center;border:1px solid transparent;border-radius:8px;color:#d7e0e2;display:flex;flex:1 1;flex-direction:column;font-size:12px;font-weight:700;gap:4px;justify-content:center;min-height:56px;min-width:0;padding:7px 9px;text-align:center}.mobile-nav-item span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-item svg{color:var(--color-accent);height:19px;width:19px}.mobile-nav-item[data-active=true]{background:rgba(58,161,170,.2);border-color:rgba(58,161,170,.28);color:#ffffff}.mobile-more-menu{flex:1 1;min-width:0;position:relative}.mobile-more-trigger{cursor:pointer;list-style:none;width:100%}.mobile-more-trigger::-webkit-details-marker{display:none}.mobile-more-panel{background:#111a1d;border:1px solid rgba(255,255,255,.1);border-radius:8px;bottom:calc(100% + 10px);box-shadow:0 -14px 36px rgba(17,26,29,.24);display:grid;grid-gap:6px;gap:6px;padding:8px;position:absolute;right:0;width:min(240px,calc(100vw - 24px))}.mobile-more-item{align-items:center;border-radius:8px;color:#d7e0e2;display:flex;font-size:14px;font-weight:700;gap:10px;min-height:44px;padding:10px 12px}.mobile-more-item svg{color:var(--color-accent);flex:0 0 auto;height:18px;width:18px}.mobile-more-item span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-more-item[data-active=true]{background:rgba(58,161,170,.18);color:#ffffff}.main-area{display:flex;flex-direction:column;min-width:0}.topbar{align-items:center;background:rgba(246,248,248,.92);border-bottom:1px solid var(--color-border);display:flex;flex-wrap:wrap;justify-content:space-between;min-height:72px;padding:0 32px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar-title{display:grid;grid-gap:2px;gap:2px}.eyebrow{color:var(--color-accent-dark);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.page-title{font-family:var(--font-heading);font-size:30px;font-weight:650;line-height:1.1;margin:0}.user-pill{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;display:flex;gap:10px;padding:7px 12px 7px 8px}.user-pill span:not(.avatar){min-width:0;overflow:hidden;text-overflow:ellipsis}.icon-button{align-items:center;background:transparent;border:0;border-radius:999px;color:var(--color-muted);display:inline-flex;height:32px;justify-content:center;margin-right:-6px;width:32px}.icon-button.bordered{border:1px solid var(--color-border);margin-right:0}.icon-button:disabled{cursor:not-allowed;opacity:.6}.avatar,.icon-button:hover{background:var(--color-accent-soft);color:var(--color-accent-dark)}.avatar{align-items:center;border-radius:999px;display:inline-flex;font-weight:700;height:32px;justify-content:center;width:32px}.content{display:grid;grid-gap:24px;gap:24px;padding:28px 32px 40px}.dashboard-grid{display:grid;grid-gap:16px;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr))}.panel-grid{display:grid;grid-gap:16px;gap:16px;grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:18px}.stat-card{display:grid;grid-gap:12px;gap:12px}.stat-header{align-items:center;color:var(--color-muted);display:flex;font-size:14px;gap:8px}.stat-header svg{color:var(--color-accent);height:18px;width:18px}.stat-value{font-family:var(--font-heading);font-size:32px;line-height:1}.card-title{align-items:center;display:flex;font-size:18px;font-weight:700;gap:8px;margin:0 0 14px}.card-title svg{color:var(--color-accent);height:19px;width:19px}.list{display:grid;grid-gap:10px;gap:10px;margin:0;padding:0}.list-item{align-items:center;border:1px solid var(--color-border);border-radius:8px;display:flex;justify-content:space-between;list-style:none;padding:12px}.item-main{display:grid;grid-gap:3px;gap:3px}.item-title{font-weight:700}.item-meta{color:var(--color-muted);font-size:14px;line-height:1.45}.badge{background:var(--color-accent-soft);border-radius:999px;color:var(--color-accent-dark);font-size:13px;font-weight:700;max-width:100%;overflow:hidden;padding:6px 10px;text-overflow:ellipsis;white-space:nowrap}.login-page{align-items:center;background:linear-gradient(90deg,rgba(17,26,29,.88),rgba(17,26,29,.55)),#111a1d;display:grid;justify-items:center;min-height:100vh;padding:24px}.login-card{background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.4);border-radius:8px;display:grid;grid-gap:24px;gap:24px;max-width:440px;padding:28px;width:100%}.login-heading{display:grid;grid-gap:8px;gap:8px}.login-heading h1{font-family:var(--font-heading);font-size:34px;line-height:1.05;margin:0}.login-heading p{color:var(--color-muted);line-height:1.55;margin:0}.form{display:grid;grid-gap:14px;gap:14px}.field{display:grid;grid-gap:6px;gap:6px}.field label{font-size:14px;font-weight:700}.field input,.field select{border:1px solid var(--color-border);border-radius:8px;min-height:44px;padding:10px 12px;width:100%}.field select{background:#ffffff}.field textarea{border:1px solid var(--color-border);border-radius:8px;min-height:88px;padding:10px 12px;resize:vertical;width:100%}.searchable-select{gap:8px}.searchable-select-hint{color:var(--color-muted);font-size:13px;line-height:1.3}.form-grid,.management-form{display:grid;grid-gap:14px;gap:14px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.primary-button{align-items:center;background:var(--color-accent);border:0;border-radius:8px;color:#ffffff;display:inline-flex;font-weight:700;gap:8px;justify-content:center;min-height:44px;padding:10px 14px}.primary-button:disabled{cursor:not-allowed;opacity:.7}.primary-button:hover{background:var(--color-accent-dark)}.secondary-button{align-items:center;background:#ffffff;border:1px solid var(--color-border);border-radius:8px;color:var(--color-ink);display:inline-flex;font-weight:700;gap:8px;justify-content:center;min-height:44px;padding:10px 14px}.secondary-button:hover{background:var(--color-accent-soft);color:var(--color-accent-dark)}.secondary-button:disabled{cursor:not-allowed;opacity:.55}.danger-button{align-items:center;background:#fff0f0;border:1px solid #efb4b4;border-radius:8px;color:var(--color-danger);display:inline-flex;font-weight:700;gap:8px;justify-content:center;min-height:44px;padding:10px 14px}.danger-button:hover{background:#ffe4e4}.danger-button:disabled{cursor:not-allowed;opacity:.55}.compact-button{min-height:36px;padding:7px 10px}.form-error{background:#fff0f0;border:1px solid #f0c5c5;border-radius:8px;color:var(--color-danger);font-size:14px;margin:0;padding:10px 12px}.schedule-conflict-popover{align-items:flex-start;background:#fff0f0;border:1px solid #efb4b4;border-radius:8px;box-shadow:0 12px 28px rgba(139,45,45,.12);color:#7f2d2d;display:flex;gap:10px;padding:12px 14px}.schedule-conflict-popover svg{color:var(--color-danger);flex:0 0 auto;height:20px;margin-top:1px;width:20px}.schedule-conflict-popover strong{color:#6f2424;display:block;font-size:14px;margin-bottom:3px}.schedule-conflict-popover p{font-size:14px;line-height:1.4;margin:0}.schedule-conflict-popover ul{display:grid;grid-gap:3px;gap:3px;margin:8px 0 0;padding-left:18px}.schedule-conflict-popover li{font-size:14px}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;min-width:720px;width:100%}.data-table td,.data-table th{border-bottom:1px solid var(--color-border);padding:12px;text-align:left}.data-table th{color:var(--color-muted);font-size:13px;font-weight:700}.data-table td{font-size:14px}.account-card-list{display:none}.account-card{border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:12px;gap:12px;padding:14px}.account-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.account-card-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.user-create-panel{display:grid;grid-gap:16px;gap:16px}.user-create-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.user-create-header .card-title{margin-bottom:6px}.people-filter-form{align-items:end;background:#fbfdfd;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:12px;gap:12px;grid-template-columns:minmax(220px,1fr) auto;margin-bottom:14px;padding:14px}.people-filter-actions{align-items:center;display:flex;gap:8px;justify-content:flex-end}.account-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.modal-backdrop{align-items:center;background:rgba(17,26,29,.55);bottom:0;display:flex;justify-content:center;left:0;padding:18px;position:fixed;right:0;top:0;z-index:60}.modal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 20px 54px rgba(17,26,29,.25);display:grid;grid-gap:16px;gap:16px;max-height:calc(100vh - 36px);max-width:680px;overflow-y:auto;padding:18px;width:min(100%,680px)}.delete-modal,.success-modal{max-width:520px}.modal-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.modal-header h3{font-size:22px;line-height:1.15;margin:4px 0}.modal-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.delete-warning{align-items:flex-start;background:#fff0f0;border:1px solid #efb4b4;border-radius:8px;color:#7f2d2d;display:flex;gap:10px;padding:12px}.delete-warning svg{color:var(--color-danger);flex:0 0 auto;height:20px;margin-top:1px;width:20px}.delete-warning strong{color:#6f2424;display:block;margin-bottom:4px}.delete-warning p{font-size:14px;line-height:1.4;margin:2px 0 0}.linked-account-panel{border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:10px;gap:10px;padding:12px}.linked-account-list{display:grid;grid-gap:8px;gap:8px;list-style:none;margin:0;padding:0}.linked-account-list li{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:2px;gap:2px;padding:10px}.linked-account-list span,.linked-account-list strong{min-width:0;overflow-wrap:anywhere}.linked-account-list strong{color:var(--color-text);font-size:14px}.linked-account-list span{color:var(--color-muted);font-size:13px}.modal-checkbox{align-items:flex-start;color:var(--color-text);display:flex;font-size:14px;font-weight:700;gap:10px;line-height:1.35}.modal-checkbox input{flex:0 0 auto;height:18px;margin-top:1px;width:18px}.success-message{align-items:flex-start;background:#eefaf4;border:1px solid #b8e4ce;border-radius:8px;color:#1f6a45;display:flex;gap:10px;padding:12px}.success-message svg{color:#2d9a62;flex:0 0 auto;height:20px;margin-top:1px;width:20px}.success-message p{font-size:14px;line-height:1.4;margin:0}.student-list{display:grid;grid-gap:14px;gap:14px}.student-create-panel{display:grid;grid-gap:16px;gap:16px}.student-create-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.student-create-header .card-title{margin-bottom:6px}.student-form-section{border-top:1px solid var(--color-border);display:grid;grid-gap:4px;gap:4px;padding-top:12px}.student-form-section p{margin:0}.student-filter-form{align-items:end;background:#fbfdfd;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:12px;gap:12px;grid-template-columns:minmax(220px,1fr) auto;margin-bottom:14px;padding:14px}.student-filter-actions{align-items:center;display:flex;gap:8px;justify-content:flex-end}.student-card{border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:16px;gap:16px;padding:16px}.student-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.muted-badge{background:#eef2f2;color:var(--color-muted)}.student-relations{display:grid;grid-gap:10px;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.relation-list{background:var(--color-page);border-radius:8px;display:grid;grid-gap:4px;gap:4px;padding:10px}.relation-label{color:var(--color-muted);font-size:12px;font-weight:700;text-transform:uppercase}.relation-value{font-size:14px}.student-notes{background:#fffaf0;border:1px solid #f1ddaa;border-radius:8px;color:#6d5612;margin:0;padding:10px 12px}.relationship-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:1fr}.student-link-panel{border-top:1px solid var(--color-border);padding-top:14px}.student-link-editor{background:#fbfdfd;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:12px;gap:12px;padding:14px}.student-link-editor-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:12px;justify-content:space-between;padding-bottom:12px}.relationship-error{grid-column:1/-1}.student-link-section{background:#ffffff;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:10px;gap:10px;padding:12px}.student-link-section-header{align-items:center;display:flex;gap:10px;justify-content:space-between}.student-link-section-header label{color:var(--color-muted);font-size:13px;font-weight:700}.student-link-search,.student-link-select{background:#ffffff;border:1px solid var(--color-border);border-radius:8px;height:36px;min-width:0;padding:6px 8px;width:100%}.student-link-checklist{display:grid;grid-gap:8px;gap:8px;max-height:260px;overflow-y:auto;padding-right:2px}.student-link-check-item{align-items:center;background:#fbfdfd;border:1px solid #edf2f2;border-radius:8px;display:flex;gap:10px;min-height:44px;padding:9px 10px}.student-link-check-item input{flex:0 0 auto;height:18px;width:18px}.student-link-account{display:grid;grid-gap:2px;gap:2px;min-width:0}.student-link-account strong{color:var(--color-ink);font-size:14px;overflow-wrap:anywhere}.student-link-account span{color:var(--color-muted);font-size:13px;overflow-wrap:anywhere}.student-link-actions{align-items:center;display:flex;gap:10px;justify-content:flex-end}.parent-child-card,.parent-child-grid{display:grid;grid-gap:18px;gap:18px}.parent-child-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:20px}.parent-child-hero{align-items:center;display:flex;gap:16px}.parent-child-hero h2{font-family:var(--font-heading);font-size:32px;line-height:1.1;margin:4px 0}.parent-child-hero p{color:var(--color-muted);margin:0}.student-avatar-large{align-items:center;background:var(--color-accent-soft);border:1px solid #c7e9ec;border-radius:8px;color:var(--color-accent-dark);display:inline-flex;font-family:var(--font-heading);font-size:34px;font-weight:700;height:82px;justify-content:center;width:82px}.parent-summary-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}.summary-tile{background:var(--color-page);border:1px solid var(--color-border);border-radius:8px;color:inherit;display:grid;grid-gap:8px;gap:8px;padding:14px;transition:background .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease}.summary-tile:hover{background:#ffffff;border-color:#afdadd;box-shadow:0 8px 20px rgba(24,34,37,.08);transform:translateY(-1px)}.summary-tile:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.summary-tile svg{color:var(--color-accent);height:20px;width:20px}.summary-tile span{font-weight:700}.summary-tile p{color:var(--color-muted);font-size:14px;line-height:1.45;margin:0}.parent-teachers{border-top:1px solid var(--color-border);display:grid;grid-gap:6px;gap:6px;padding-top:16px}.parent-teachers h3{font-size:16px;margin:0}.lesson-intro{line-height:1.55;margin:-6px 0 16px;max-width:720px}.calendar-workspace{display:grid;grid-gap:18px;gap:18px}.calendar-section-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.calendar-title{margin-bottom:10px}.month-calendar-layout{align-items:stretch;display:grid;grid-gap:16px;gap:16px;grid-template-columns:minmax(0,1fr) minmax(280px,.34fr)}.month-calendar{background:#fbfdfd;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:12px;gap:12px;padding:16px}.month-calendar-header{align-items:center;display:grid;grid-gap:12px;gap:12px;grid-template-columns:36px minmax(0,1fr) 36px}.month-calendar-header h3{font-size:22px;font-weight:650;margin:0;text-align:center}.weekday-row{display:grid;grid-gap:8px;gap:8px;grid-template-columns:repeat(7,minmax(0,1fr))}.weekday-row span{color:var(--color-muted);font-size:12px;font-weight:700;text-align:center;text-transform:uppercase}.month-grid{display:grid;grid-gap:8px;gap:8px;grid-template-columns:repeat(7,minmax(0,1fr))}.month-day{align-items:flex-start;aspect-ratio:1;background:#ffffff;border:1px solid var(--color-border);border-radius:8px;color:var(--color-ink);display:flex;flex-direction:column;justify-content:space-between;min-height:76px;padding:9px;text-align:left}.month-day:hover{border-color:#afdadd;box-shadow:0 6px 16px rgba(24,34,37,.08)}.month-day[data-outside-month=true]{background:#f2f5f5;color:#9aa7aa}.month-day[data-selected=true]{border-color:var(--color-accent);box-shadow:0 0 0 2px rgba(58,161,170,.18)}.month-day[data-today=true]{background:#fff9dc;border-color:#ecd26b}.month-day[data-today=true][data-selected=true]{box-shadow:0 0 0 2px rgba(58,161,170,.2),inset 0 0 0 1px #ecd26b}.month-day-number{font-size:15px;font-weight:700}.month-day-lessons{align-self:flex-end;background:var(--color-accent-soft);border-radius:999px;color:var(--color-accent-dark);font-size:12px;font-weight:700;min-width:24px;padding:3px 7px;text-align:center}.day-agenda{background:#111a1d;border-radius:8px;color:#f8fbfb;display:grid;grid-gap:14px;gap:14px;align-content:start;padding:16px}.day-agenda .eyebrow{color:#8fd0d6}.day-agenda-header h3{font-size:22px;font-weight:650;line-height:1.15;margin:5px 0 0}.day-agenda .item-meta{color:#b8c5c8}.day-agenda-list{display:grid;grid-gap:10px;gap:10px;margin:0;padding:0}.day-agenda-list li{align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;display:grid;grid-gap:10px;gap:10px;grid-template-columns:58px minmax(0,1fr);list-style:none;padding:10px}.agenda-time{align-self:center;color:#8fd0d6;font-weight:700}.agenda-main{display:grid;grid-gap:3px;gap:3px;min-width:0}.agenda-main strong{color:#ffffff;font-size:14px;font-weight:700}.agenda-main span{color:#b8c5c8;font-size:14px;line-height:1.35}.agenda-more{color:#b8c5c8;font-size:13px;font-weight:700;margin:0}.schedule-lesson-panel{border-top:1px solid var(--color-border);padding-top:18px}.schedule-toggle-button{width:-moz-fit-content;width:fit-content}.schedule-lesson-form{background:#fbfdfd;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:16px;gap:16px;padding:16px}.schedule-lesson-form h3{font-size:20px;font-weight:650;margin:0 0 4px}.selected-lessons{border-top:1px solid var(--color-border);display:grid;grid-gap:14px;gap:14px;padding-top:18px}.selected-lessons-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.selected-lessons-header h3{font-size:22px;font-weight:650;margin:4px 0 0}.pagination-controls{align-items:center;display:flex;gap:12px;justify-content:flex-end}.pagination-link[data-disabled=true]{opacity:.55;pointer-events:none}.feedback-create-panel{display:grid;grid-gap:16px;gap:16px}.feedback-create-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.feedback-create-header .card-title{margin-bottom:6px}.feedback-board{display:grid;grid-gap:14px;gap:14px}.feedback-filter-form{align-items:end;background:#fbfdfd;border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:12px;gap:12px;grid-template-columns:minmax(180px,1.2fr) repeat(3,minmax(140px,.7fr)) auto;padding:14px}.feedback-filter-actions{align-items:center;display:flex;gap:8px;justify-content:flex-end}.feedback-thread-card,.feedback-thread-list{display:grid;grid-gap:14px;gap:14px}.feedback-thread-card{border:1px solid var(--color-border);border-radius:8px;padding:16px}.feedback-thread-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.feedback-thread-header h3{font-size:22px;font-weight:650;line-height:1.15;margin:4px 0 0}.feedback-student{align-items:center;background:var(--color-page);border-radius:8px;display:flex;font-weight:700;gap:8px;padding:10px 12px}.feedback-student svg{color:var(--color-accent);height:18px;width:18px}.feedback-message-list{display:grid;grid-gap:10px;gap:10px}.feedback-message{background:#fbfdfd;border:1px solid #edf2f2;border-radius:8px;display:grid;grid-gap:8px;gap:8px;padding:12px}.feedback-message-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between}.feedback-message-header strong{font-size:14px}.feedback-message-header span{color:var(--color-muted);font-size:13px}.feedback-message p{line-height:1.5;margin:0;white-space:pre-wrap}.feedback-edit-form{display:grid;grid-gap:12px;gap:12px}.feedback-actions,.feedback-edit-form{border-top:1px solid var(--color-border);padding-top:14px}.feedback-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.feedback-actions .form-error{flex-basis:100%}.lesson-list{display:grid;grid-gap:14px;gap:14px}.lesson-card{border:1px solid var(--color-border);border-radius:8px;display:grid;grid-gap:16px;gap:16px;padding:16px}.lesson-card-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.lesson-time{align-items:center;display:flex;font-weight:700;gap:8px}.lesson-time svg{color:var(--color-accent);height:18px;width:18px}.lesson-status[data-status=COMPLETED]{background:#e7f6ed;color:#2d7b4f}.lesson-status[data-status=CANCELLED]{background:#fff0f0;color:var(--color-danger)}.lesson-status[data-status=MISSED]{background:#fff6e6;color:#9a6a13}.lesson-main{display:grid;grid-gap:12px;gap:12px}.lesson-main h3{font-family:var(--font-heading);font-size:24px;font-weight:650;line-height:1.1;margin:3px 0 0}.lesson-heading-topic{color:var(--color-muted);font-family:var(--font-body);font-size:18px;font-weight:500}.lesson-meta-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))}.lesson-meta{background:#f9fbfb;border:1px solid #edf2f2;border-radius:8px;display:grid;grid-gap:5px;gap:5px;padding:12px 13px}.lesson-meta span{color:#738084;font-size:13px;font-weight:600;line-height:1.25}.lesson-meta strong{color:#1d292c;font-size:15px;font-weight:600;line-height:1.25}.lesson-meta[data-attendance=PRESENT]{background:#e7f6ed}.lesson-meta[data-attendance=PRESENT] strong{color:#2d7b4f}.lesson-meta[data-attendance=LATE]{background:#fff6e6}.lesson-meta[data-attendance=LATE] strong{color:#9a6a13}.lesson-meta[data-attendance=ABSENT]{background:#fff0f0}.lesson-meta[data-attendance=ABSENT] strong{color:var(--color-danger)}.lesson-meta[data-attendance=EXCUSED]{background:var(--color-accent-soft)}.lesson-meta[data-attendance=EXCUSED] strong{color:var(--color-accent-dark)}.lesson-note{align-items:flex-start;background:#fffaf0;border:1px solid #f1ddaa;border-radius:8px;color:#6d5612;display:flex;gap:8px;padding:10px 12px}.lesson-note svg{flex:0 0 auto;height:18px;margin-top:1px;width:18px}.lesson-note p{margin:0}.lesson-card-actions{border-top:1px solid var(--color-border);align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding-top:14px}.lesson-update-block{min-width:0}.lesson-update-block[data-editing=true]{display:contents}.lesson-edit-close{margin-left:auto;order:1}.lesson-update-form{display:grid;flex-basis:100%;grid-gap:12px;gap:12px;order:2;width:100%}.lesson-update-actions{align-items:center;display:flex;gap:12px;justify-content:space-between}.lesson-update-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.lesson-delete-area{display:flex;justify-content:flex-end;margin-left:auto}@media (max-width:1023px){.app-shell{display:block;min-height:100vh}.sidebar{display:none}.mobile-bottom-nav{background:#111a1d;border-top:1px solid rgba(255,255,255,.1);bottom:0;box-shadow:0 -8px 24px rgba(17,26,29,.18);display:block;left:0;position:fixed;right:0;z-index:30}.main-area{min-height:100vh}.topbar{align-items:center;gap:14px;min-height:68px;padding:18px}.user-pill{max-width:100%}.content{padding:18px 18px calc(100px + env(safe-area-inset-bottom))}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.account-card-grid,.feedback-filter-form,.form-grid,.lesson-meta-grid,.lesson-update-grid,.month-calendar-layout,.panel-grid,.parent-summary-grid,.people-filter-form,.relationship-grid,.student-filter-form,.student-relations{grid-template-columns:1fr}.table-wrap{display:none}.account-card-list{display:grid;grid-gap:12px;gap:12px}}@media (max-width:560px){.mobile-nav-list{gap:6px;padding:7px 10px calc(7px + env(safe-area-inset-bottom))}.mobile-nav-item{font-size:11px;min-height:54px;padding:6px 8px}.mobile-more-panel{right:-2px;width:min(220px,calc(100vw - 20px))}.topbar{align-items:flex-start;flex-direction:column;gap:12px;padding:14px}.topbar-title{width:100%}.user-pill{justify-content:space-between;width:100%}.content{gap:14px;padding:14px 12px calc(96px + env(safe-area-inset-bottom))}.card{padding:14px}.login-page{padding:16px}.login-card{gap:18px;padding:20px}.login-heading h1{font-size:28px}.brand-logo{max-width:190px}.page-title{font-size:24px}.dashboard-grid{grid-template-columns:1fr}.list-item{gap:10px}.account-card-header,.lesson-card-header,.list-item,.parent-child-hero,.student-card-header{align-items:flex-start;flex-direction:column}.student-avatar-large{font-size:28px;height:66px;width:66px}.parent-child-hero h2{font-size:26px}.calendar-section-header{flex-direction:column}.feedback-create-header,.feedback-filter-actions,.feedback-thread-header,.lesson-update-actions,.modal-actions,.pagination-controls,.people-filter-actions,.selected-lessons-header,.student-create-header,.student-filter-actions,.student-link-editor-header,.user-create-header{align-items:flex-start;flex-direction:column}.danger-button,.primary-button,.secondary-button{width:100%}.compact-button{min-height:44px}.icon-button{min-width:36px}.student-link-section{padding:10px}.student-link-actions,.student-link-section-header{align-items:flex-start;flex-direction:column}.student-link-search,.student-link-select{height:44px}.account-actions,.account-actions .danger-button,.account-actions .secondary-button,.feedback-actions,.feedback-filter-actions,.lesson-card-actions,.lesson-delete-area,.lesson-delete-area .danger-button,.lesson-update-block,.lesson-update-block .secondary-button,.modal-actions,.modal-actions .danger-button,.modal-actions .primary-button,.modal-actions .secondary-button,.people-filter-actions,.student-filter-actions,.student-link-actions{width:100%}.lesson-edit-close{margin-left:0}.modal-backdrop{align-items:flex-end;padding:10px}.modal-card{max-height:calc(100vh - 20px);padding:14px}.month-calendar{gap:10px;padding:10px}.month-calendar-header{gap:8px;grid-template-columns:36px minmax(0,1fr) 36px}.month-calendar-header h3{font-size:18px}.month-grid,.weekday-row{gap:4px}.month-day{border-radius:6px;min-height:42px;padding:5px}.month-day-number{font-size:12px}.month-day-lessons{font-size:10px;min-width:18px;padding:2px 5px}.weekday-row span{font-size:10px}.account-card,.day-agenda,.feedback-thread-card,.lesson-card,.parent-child-card,.schedule-lesson-form,.student-card{padding:12px}.day-agenda-list li{grid-template-columns:48px minmax(0,1fr)}.day-agenda-header h3,.feedback-thread-header h3,.lesson-main h3,.selected-lessons-header h3{font-size:20px}.lesson-heading-topic{display:block;font-size:16px;margin-top:4px}.pagination-controls{width:100%}}