@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box}:root{font-family:Space Grotesk,Trebuchet MS,sans-serif;line-height:1.4;font-weight:400;color:#1f2b2c;background-color:#f5f3ef;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{margin:0;min-height:100vh;background-color:#f5f3ef}#root{min-height:100vh}button,input,select,textarea{font-family:inherit}:root{color-scheme:light;--teal: #00b2be;--teal-dark: #008f96;--cream: #f5f3ef;--ink: #1f2b2c;--muted: #6e7c80;--card: #ffffff;--border: #d9e0e2;--shadow: 0 20px 40px rgba(17, 41, 45, .12)}body{margin:0;background:radial-gradient(circle at 12% 8%,rgba(0,178,190,.15),transparent 35%),radial-gradient(circle at 88% 12%,rgba(0,178,190,.1),transparent 38%),linear-gradient(180deg,#f9f8f5 0%,var(--cream) 60%,#f7f4ef 100%);color:var(--ink)}.app{min-height:100vh;padding:36px clamp(16px,4vw,56px) 64px;display:flex;flex-direction:column;gap:28px;position:relative;overflow:hidden}.app:before{content:"";position:absolute;right:-120px;top:120px;width:360px;height:360px;background:#00b2be1f;border-radius:50%;filter:blur(2px);opacity:.8}.app:after{content:"";position:absolute;left:-90px;bottom:-120px;width:300px;height:300px;background:#00b2be14;border-radius:48px;transform:rotate(18deg)}.app a{color:inherit;text-decoration:none}.header{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;padding:18px 22px;border-radius:18px;background:var(--teal);color:#fff;box-shadow:var(--shadow);position:relative;z-index:1}.brand{display:flex;align-items:center;gap:16px}.brand-logo{width:92px;height:92px;padding:6px;border-radius:16px;background:#ffffff1f;object-fit:contain;box-shadow:0 12px 24px #08404340}.brand-text{display:flex;flex-direction:column;gap:6px}.brand-name{font-size:1.2rem;font-weight:600}.brand-tagline{font-size:.9rem;color:#fffc;max-width:320px}.nav{display:flex;gap:16px;flex-wrap:wrap;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem}.nav a{color:#ffffffe6}.nav a:hover{color:#fff}.header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.language-toggle{display:inline-flex;align-items:center;gap:6px;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.35);background:#ffffff2e}.language-toggle button{border:none;background:transparent;color:#fff;padding:4px 10px;border-radius:999px;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;cursor:pointer}.language-toggle button.active{background:#fff;color:var(--teal-dark)}.btn{border:none;border-radius:999px;padding:10px 18px;font-weight:600;font-size:.9rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn.light{background:#fff;color:var(--teal-dark);box-shadow:0 8px 16px #0d595c33}.btn.ghost{background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.35)}.btn.accent{background:var(--teal);color:#fff;box-shadow:0 12px 24px #00b2be33}.btn.outline{background:transparent;border:1px solid var(--border);color:var(--ink)}.btn.full{width:100%}.btn.small{padding:6px 12px;font-size:.8rem}.btn:hover{transform:translateY(-1px)}.main{display:flex;flex-direction:column;gap:72px;position:relative;z-index:1}.admin-main{gap:32px}.hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:32px;align-items:start}.hero-content h1{font-size:clamp(2.2rem,2.8vw + 1.4rem,3.6rem);margin:10px 0 16px}.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:.68rem;color:var(--teal-dark);margin:0}.lead{font-size:1.05rem;color:var(--muted);max-width:560px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0 24px}.status-chip{text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;padding:6px 12px;border-radius:999px;border:1px solid rgba(0,178,190,.3);background:#00b2be1f;color:var(--teal-dark);display:inline-flex;align-items:center;gap:8px}.status-chip.live:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px #00b2be99;animation:pulse 2s ease-in-out infinite}.hero-panel{display:grid;gap:18px}.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:22px;box-shadow:var(--shadow)}.card-heading h2,.card-heading h3{margin:0 0 6px}.card-heading p{margin:0;color:var(--muted)}.login-card{display:grid;gap:18px}.login-form{display:grid;gap:14px}.form-field{display:grid;gap:8px;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.form-field input,.form-field select{border:1px solid var(--border);border-radius:12px;padding:12px 14px;font-size:.95rem;background:#fff;color:var(--ink)}.form-field input:focus{outline:2px solid rgba(0,178,190,.35);border-color:#00b2be73}.form-field select:focus{outline:2px solid rgba(0,178,190,.35);border-color:#00b2be73}.inline-input,.inline-select{border:1px solid var(--border);border-radius:10px;padding:8px 10px;font-size:.85rem;background:#fff;color:var(--ink);width:100%}.inline-input:focus,.inline-select:focus{outline:2px solid rgba(0,178,190,.35);border-color:#00b2be73}.login-helper{font-size:.85rem;color:var(--muted)}.admin-login{display:flex;justify-content:center;width:100%}.admin-login .login-card{width:100%;max-width:420px}.admin-shell{display:grid;grid-template-columns:220px minmax(0,1fr);gap:24px;align-items:start;width:100%}.school-shell{display:grid;grid-template-columns:240px minmax(0,1fr);gap:24px;align-items:start;width:100%}.admin-menu{display:grid;gap:10px;padding:16px;border-radius:16px;border:1px solid var(--border);background:#ffffffbf;box-shadow:0 12px 24px #11292d14}.admin-menu-title{text-transform:uppercase;letter-spacing:.14em;font-size:.65rem;color:var(--muted)}.admin-menu a{padding:8px 12px;border-radius:10px;color:var(--teal-dark);font-weight:600}.admin-menu a.active,.admin-menu a[aria-current=page]{background:#00b2be29}.admin-menu a:hover{background:#00b2be1f}.school-menu-item{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:8px 12px;border-radius:10px;border:none;background:transparent;color:var(--teal-dark);font-weight:600;text-align:left;cursor:pointer}.school-menu-item.active{background:#00b2be29}.school-menu-item:hover{background:#00b2be1f}.school-menu-count{font-size:.75rem;color:var(--muted);font-weight:600}.admin-content{display:grid;gap:24px}.inline-edit{display:flex;flex-wrap:wrap;align-items:center;gap:8px;width:100%}.inline-stack{display:grid;gap:8px}.inline-actions{display:flex;align-items:center;gap:8px}.admin-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.admin-form-card,.admin-form{display:grid;gap:12px}.form-actions{display:flex;flex-wrap:wrap;gap:12px}.dashboard-header{display:grid;gap:6px}.dashboard-header h2{margin:0;font-size:1.4rem}.dashboard-header p{margin:0;color:var(--muted)}.class-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.class-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.class-header h3{margin:0}.class-meta{margin:4px 0 0;color:var(--muted);font-size:.85rem}.student-table{display:grid;gap:10px;margin-top:14px}.student-row{display:grid;grid-template-columns:1.6fr 1fr 1fr .5fr;gap:12px;align-items:center;padding:10px 12px;border-radius:12px;background:#f7faf9;border:1px solid var(--border);font-size:.9rem}.student-row.student-head{background:transparent;border:none;padding:0 4px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.row-subtitle{display:block;margin-top:4px;font-size:.75rem;color:var(--muted)}.tag-count{font-weight:600}.parent-shell{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,.6fr);gap:24px;align-items:start}.preferences-form{display:grid;gap:12px}.toggle-field{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#fff}.toggle-field input{width:18px;height:18px;accent-color:var(--teal)}.preferences-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.form-status{font-size:.85rem;color:var(--muted)}.form-status.error{color:#a24848;font-weight:600}.admin-section{display:grid;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--border)}.admin-section:last-child{border-bottom:none}.admin-section h2{margin:0;font-size:1.1rem}.section{display:grid;gap:24px}.section-head{max-width:720px}.section-head h2{margin:6px 0 10px;font-size:clamp(1.8rem,2vw + 1.2rem,2.6rem)}.section-head p{color:var(--muted)}.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.feature-card h3{margin-top:0}.feature-card p{color:var(--muted)}.privacy-card ul{margin:16px 0 18px;padding-left:18px;color:var(--muted)}.admin-table{display:grid;gap:10px}.admin-empty,.admin-error{padding:16px;border-radius:12px}.admin-notice{padding:16px;border-radius:12px;background:#00b2be1f;border:1px solid rgba(0,178,190,.35);color:var(--teal-dark);font-weight:600}.admin-empty{background:#ffffffb3;border:1px dashed var(--border);color:var(--muted)}.admin-error{background:#eb66661f;border:1px solid rgba(235,102,102,.35);color:#a24848;font-weight:600}.admin-row{display:grid;grid-template-columns:1.2fr 1fr auto;gap:12px;align-items:center;padding:10px 12px;border-radius:12px;background:#f7faf9;border:1px solid var(--border);font-size:.9rem}.admin-row.schools-row{grid-template-columns:1.4fr .6fr .6fr .6fr}.admin-row.gateways-row{grid-template-columns:1.2fr 1.6fr 1fr .6fr}.admin-row.classes-row,.admin-row.logins-row{grid-template-columns:1.4fr 1fr .6fr}.admin-row.tags-row{grid-template-columns:1.2fr 1.2fr 1fr .6fr}.admin-row.students-row{grid-template-columns:1.4fr 1fr 1.2fr 1.2fr}.admin-row.parents-row{grid-template-columns:1.4fr 1.6fr .6fr}.admin-row.users-row{grid-template-columns:1.4fr .6fr .6fr 1.8fr}.admin-row.admin-head{background:transparent;border:none;padding:0 4px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.admin-row.admin-edit-row{background:#ffffffb3;border:1px dashed var(--border)}.admin-status{justify-self:start;text-transform:uppercase;letter-spacing:.12em;font-size:.65rem;font-weight:600;padding:4px 8px;border-radius:999px;background:#00b2be1f;color:var(--teal-dark)}.admin-status.stale,.admin-status.invited,.admin-status.idle{background:#ffba5a33;color:#b2742d}.admin-status.sent{background:#00b2be1f;color:var(--teal-dark)}.admin-status.offline,.admin-status.disabled,.admin-status.missing,.admin-status.failed{background:#eb66662e;color:#a24848}.admin-pill-list{display:flex;flex-wrap:wrap;gap:8px}.admin-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#00b2be1f;color:var(--teal-dark);font-size:.75rem;font-weight:600}.pill-action{border:none;background:transparent;color:inherit;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;padding:0 2px}.pill-action:disabled{cursor:not-allowed;opacity:.6}.admin-pill.muted{background:#ffffffb3;color:var(--muted);border:1px dashed var(--border)}.mail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;align-items:start}.mail-card{display:grid;gap:16px}.mail-stats{display:grid;gap:12px}.mail-stats>div{display:grid;gap:4px}.mail-stat-label{text-transform:uppercase;letter-spacing:.12em;font-size:.65rem;color:var(--muted)}.mail-stat-value{font-size:1.05rem;font-weight:600}.mail-providers{display:grid;gap:8px}.mail-provider-list{display:flex;flex-wrap:wrap;gap:8px}.mail-provider-item{padding:4px 10px;border-radius:999px;background:#00b2be1f;color:var(--teal-dark);font-size:.75rem;font-weight:600}.mail-form{display:grid;gap:12px}.mail-input{width:100%}.mail-log{display:grid;gap:10px}.mail-row{display:grid;grid-template-columns:1.2fr 1.6fr .6fr .9fr .5fr;gap:12px;align-items:center;padding:10px 12px;border-radius:12px;background:#f7faf9;border:1px solid var(--border);font-size:.85rem}.mail-row.mail-head{background:transparent;border:none;padding:0 4px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.cta{background:var(--teal);color:#fff;border-radius:20px;padding:28px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;box-shadow:var(--shadow)}.cta p{color:#fffc}.cta .btn.accent{background:#fff;color:var(--teal-dark);box-shadow:none}.cta .btn.outline{border-color:#fff9;color:#fff}.cta-actions{display:flex;gap:12px;flex-wrap:wrap}.footer{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;color:var(--muted);position:relative;z-index:1}.footer-brand{display:flex;align-items:center;gap:12px}.footer-logo{width:52px;height:52px;border-radius:14px;padding:4px;background:#00b2be1f;object-fit:contain}.footer-brand span{display:block;font-size:.85rem}.footer-links{display:flex;gap:16px;flex-wrap:wrap}.footer-meta{display:flex;flex-direction:column;gap:6px;font-size:.85rem}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.status-chip.live:before{animation:none}.btn:hover{transform:none}}@media(max-width:1100px){.hero{grid-template-columns:1fr}.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-shell,.school-shell{grid-template-columns:1fr}.admin-menu{display:flex;flex-wrap:wrap;align-items:center}.admin-menu-title{width:100%}.header{align-items:flex-start}.parent-shell,.mail-grid{grid-template-columns:1fr}}@media(max-width:720px){.feature-grid,.admin-row{grid-template-columns:1fr}.admin-row.admin-head{display:none}.student-row{grid-template-columns:1fr}.student-row.student-head{display:none}.mail-row{grid-template-columns:1fr}.mail-row.mail-head{display:none}.cta,.footer{flex-direction:column;align-items:flex-start}}
