*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8fafc;--surface:#fff;--surface2:#f1f5f9;--border:#e2e8f0;--primary:#6366f1;--primary-h:#4f46e5;--primary-light:#eef2ff;--text:#0f172a;--text-2:#64748b;--text-3:#94a3b8;--danger:#ef4444;--danger-bg:#fef2f2;--success:#10b981;--success-bg:#ecfdf5;--warn:#f59e0b;--warn-bg:#fffbeb;--hover-bg:#f1f5f9;--active-bg:#eef2ff;--active-clr:#6366f1;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 30px #0000001f;--shadow-xl:0 20px 60px #00000026;--card-bg:var(--surface);--muted:var(--text-2);--radius:12px;--radius-sm:8px;--radius-lg:16px;--transition:.2s ease}[data-theme=dark]{--bg:#0f172a;--surface:#1e293b;--card-bg:var(--surface);--muted:var(--text-2);--surface2:#334155;--border:#334155;--text:#f1f5f9;--text-2:#94a3b8;--text-3:#64748b;--primary-light:#1e1b4b;--hover-bg:#334155;--active-bg:#312e81;--active-clr:#818cf8;--danger-bg:#451a1a;--success-bg:#064e3b;--warn-bg:#451a03;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 30px #0006;--shadow-xl:0 20px 60px #00000080}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.guest-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.bg-decoration{pointer-events:none;z-index:0;position:fixed;inset:0}.bg-circle{filter:blur(80px);opacity:.15;border-radius:50%;position:absolute}.bg-circle-1{background:#6366f1;width:600px;height:600px;top:-200px;right:-100px}.bg-circle-2{background:#ec4899;width:400px;height:400px;bottom:-100px;left:-100px}.bg-circle-3{background:#10b981;width:300px;height:300px;top:50%;left:50%;transform:translate(-50%,-50%)}.guest-container{z-index:1;flex-direction:column;width:100%;max-width:640px;min-height:100vh;padding:20px;display:flex;position:relative}.guest-header{justify-content:space-between;align-items:center;padding:20px 0;display:flex}.guest-logo{color:var(--text);align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.btn-icon{background:var(--surface);border:1px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text-2);transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--hover-bg);color:var(--text);box-shadow:var(--shadow-sm)}.guest-main{flex:1;justify-content:center;align-items:center;display:flex}.hero-content{text-align:center;width:100%}.hero-icon{opacity:.9;margin-bottom:24px}.hero-icon svg{filter:drop-shadow(0 4px 12px #6366f14d)}.hero-title{color:var(--text);letter-spacing:-.5px;margin-bottom:12px;font-size:32px;font-weight:800;line-height:1.2}.hero-description{color:var(--text-2);max-width:460px;margin-bottom:40px;margin-left:auto;margin-right:auto;font-size:16px}.email-form{max-width:520px;margin:0 auto 32px}.email-input-group{background:var(--surface);border:2px solid var(--border);box-shadow:var(--shadow-md);transition:border-color var(--transition), box-shadow var(--transition);border-radius:16px;display:flex;overflow:hidden}.email-input-group:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px #6366f11f, var(--shadow-md)}.input-wrapper{flex:1;align-items:center;gap:12px;padding:4px 16px;display:flex}.input-icon{color:var(--text-3);flex-shrink:0}.input-wrapper input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:14px 0;font-family:inherit;font-size:16px}.input-wrapper input::placeholder{color:var(--text-3)}.btn-submit{background:var(--primary);color:#fff;cursor:pointer;transition:background var(--transition), transform var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:14px 28px;font-family:inherit;font-size:15px;font-weight:600;display:flex}.btn-submit:hover{background:var(--primary-h)}.btn-submit:active{transform:scale(.98)}.btn-submit.loading{pointer-events:none;opacity:.8}.btn-spinner{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.form-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #fecaca;align-items:center;gap:8px;margin-top:16px;padding:12px 16px;font-size:14px;display:flex}[data-theme=dark] .form-error{border-color:#7f1d1d}.hero-features{flex-wrap:wrap;justify-content:center;gap:32px;display:flex}.feature{color:var(--text-2);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.guest-footer{text-align:center;color:var(--text-3);padding:24px 0;font-size:13px}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-container{width:100%;max-width:420px;padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px 36px}.login-logo{text-align:center;margin-bottom:32px}.login-logo h2{color:var(--text);margin-top:12px;font-size:22px;font-weight:700}.login-card .form-group{margin-bottom:20px}.login-card .btn-full{margin-top:8px}.login-back{text-align:center;color:var(--text-3);margin-top:20px;font-size:13px;display:block}.login-back:hover{color:var(--primary);text-decoration:none}.admin-layout{height:100vh;display:flex;overflow:hidden}.admin-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:240px;min-width:240px;display:flex}.admin-logo{color:var(--primary);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px;font-size:16px;font-weight:700;display:flex}.admin-nav{flex:1;padding:12px;overflow-y:auto}.admin-nav a{border-radius:var(--radius-sm);color:var(--text-2);transition:all var(--transition);align-items:center;gap:10px;margin-bottom:4px;padding:10px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.admin-nav a:hover{background:var(--hover-bg);color:var(--text);text-decoration:none}.admin-nav a.active{background:var(--active-bg);color:var(--active-clr);font-weight:600}.nav-badge{background:var(--primary);color:#fff;text-align:center;border-radius:10px;min-width:22px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:700}.admin-sidebar-footer{border-top:1px solid var(--border);padding:16px}.admin-user{color:var(--text-2);margin-bottom:10px;font-size:13px;font-weight:500}.admin-content{flex:1;padding:32px;overflow-y:auto}.admin-topbar{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-title{color:var(--text);font-size:22px;font-weight:700}.subtitle{color:var(--text-2);margin-top:4px;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);align-items:center;gap:16px;padding:24px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-val{color:var(--text);font-size:28px;font-weight:800;line-height:1}.stat-lbl{color:var(--text-2);margin-top:4px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:24px}.card-title{color:var(--text);margin-bottom:20px;font-size:16px;font-weight:600}.empty-card{text-align:center;color:var(--text-3);padding:48px}.guide-list{color:var(--text-2);padding-left:24px;font-size:14px;line-height:2.2}.form-row{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.form-group{flex-direction:column;flex:1;gap:6px;min-width:180px;display:flex}.form-group label{color:var(--text-2);font-size:13px;font-weight:600}.required{color:var(--danger)}.form-control{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}textarea.form-control{resize:vertical;min-height:120px}select.form-control{cursor:pointer}.form-actions{align-items:center;gap:10px;margin-top:8px;display:flex}.form-help{color:var(--text-2);font-size:13px;line-height:1.6}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-h)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:#fee2e2}[data-theme=dark] .btn-danger:hover{background:#7f1d1d}.btn-success{background:var(--success-bg);color:var(--success)}.btn-success:hover{background:#d1fae5}.btn-ghost{background:var(--surface2);color:var(--text-2)}.btn-ghost:hover{background:var(--hover-bg);color:var(--text)}.btn-sm{padding:6px 12px;font-size:13px}.btn-full{justify-content:center;width:100%}.mm-input-password-wrap{align-items:center;display:flex;position:relative}.mm-input-password-wrap .form-control{width:100%;padding-right:44px}.mm-toggle-pw{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-2);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.mm-toggle-pw:hover{background:var(--hover-bg);color:var(--text)}.mm-pw-field .mm-label-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;display:flex}.mm-pw-field .mm-label-row label{margin:0}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--border);transition:var(--transition);border-radius:24px;position:absolute;inset:0}.toggle-slider:before{content:"";width:18px;height:18px;transition:var(--transition);background:#fff;border-radius:50%;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);border-bottom:2px solid var(--border);background:var(--surface2);padding:12px 16px;font-size:12px;font-weight:700}.data-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:12px 16px}.data-table tr:hover td{background:var(--hover-bg)}.data-table tr:last-child td{border-bottom:none}.truncate{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.actions-cell{align-items:center;gap:6px;display:flex}.badge{background:var(--primary);color:#fff;text-align:center;border-radius:10px;min-width:22px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.badge-pill{border-radius:12px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.badge-active{color:#059669;background:#d1fae5}.badge-inactive{color:#dc2626;background:#fee2e2}.badge-parent{background:var(--primary-light);color:var(--primary)}[data-theme=dark] .badge-active{color:#6ee7b7;background:#064e3b}[data-theme=dark] .badge-inactive{color:#fca5a5;background:#451a1a}.filter-bar{color:var(--text-2);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:20px;font-size:14px;display:flex}.alert{border-radius:var(--radius-sm);margin-bottom:20px;padding:14px 18px;font-size:14px;line-height:1.5}.alert-success{background:var(--success-bg);color:#065f46;border:1px solid #a7f3d0}.alert-error{background:var(--danger-bg);color:#991b1b;border:1px solid #fecaca}.alert-warn{background:var(--warn-bg);color:#92400e;border:1px solid #fde68a}[data-theme=dark] .alert-success{color:#6ee7b7;border-color:#064e3b}[data-theme=dark] .alert-error{color:#fca5a5;border-color:#7f1d1d}[data-theme=dark] .alert-warn{color:#fcd34d;border-color:#78350f}.alert a{color:inherit;text-decoration:underline}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.info-item{flex-direction:column;gap:4px;display:flex}.info-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.info-value{color:var(--text);font-size:14px;font-weight:500}@media (max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--border);height:auto}.admin-nav{flex-direction:row;gap:4px;padding:8px;display:flex;overflow-x:auto}.admin-nav a{white-space:nowrap;margin-bottom:0}.admin-sidebar-footer{display:none}.admin-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row{flex-direction:column}.form-group{min-width:unset}.hero-title{font-size:24px}.email-input-group{border-radius:var(--radius);flex-direction:column}.btn-submit{border-radius:0 0 10px 10px;justify-content:center;padding:14px}.hero-features{flex-direction:column;align-items:center;gap:16px}}@media (max-width:480px){.guest-container{padding:12px}.hero-title{font-size:22px}.hero-description{font-size:14px}.login-card{padding:28px 24px}}.om-wrap{max-width:820px;margin:0 auto;padding:20px 16px 48px}.om-topbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.om-badge{color:var(--text-2);background:var(--surface2);border:1px solid var(--border);border-radius:99px;padding:2px 10px;font-size:.8rem}.om-list{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.om-item{border-bottom:1px solid var(--border);color:inherit;flex-direction:column;gap:3px;padding:12px 16px;text-decoration:none;transition:background .12s;display:flex}.om-item:last-child{border-bottom:none}.om-item:hover{background:var(--hover-bg)}.om-item-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.om-item-subject{color:var(--text);word-break:break-word;font-size:.875rem;font-weight:600;line-height:1.35}.om-item-subject.unread{color:var(--primary)}.om-item-date{color:var(--text-3);white-space:nowrap;flex-shrink:0;padding-top:2px;font-size:.75rem}.om-item-snippet{color:var(--text-2);-webkit-line-clamp:2;word-break:break-word;-webkit-box-orient:vertical;font-size:.8rem;line-height:1.4;display:-webkit-box;overflow:hidden}.om-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.om-empty{text-align:center;color:var(--text-2);padding:48px 16px}.om-back{color:var(--primary);align-items:center;gap:6px;margin-bottom:18px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.om-back:hover{text-decoration:underline}.om-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.om-card-head{border-bottom:1px solid var(--border);padding:18px 18px 14px}.om-card-subject{color:var(--text);word-break:break-word;margin:0 0 12px;font-size:1.05rem;font-weight:700;line-height:1.4}.om-card-meta{flex-wrap:wrap;gap:4px 16px;display:flex}.om-card-meta span{color:var(--text-2);font-size:.8rem}.om-card-meta span strong{color:var(--text);font-weight:600}.om-card-body{color:var(--text);padding:16px 18px;font-size:.9rem;line-height:1.7;overflow:auto}.om-frame{background:#fff;border:none;border-radius:4px;width:100%;min-height:300px;display:block}.om-link-hint{color:var(--text-2);margin-bottom:12px;font-size:.8rem}.om-pretext{white-space:pre-wrap;word-break:break-word;font-family:inherit;font-size:.9rem}.om-error-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:10px;padding:24px}.om-error-card p{color:var(--text-2);margin:10px 0 18px;font-size:.9rem}.om-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:18px;padding-bottom:0;display:flex}.om-tab{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:8px 14px;font-size:.875rem;font-weight:500;transition:color .15s,border-color .15s;display:inline-flex}.om-tab:hover{color:var(--text)}.om-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.om-notice{background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--primary);color:var(--text-2);border-radius:8px;align-items:flex-start;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:.82rem;line-height:1.5;display:flex}.om-notice strong{color:var(--text)}.om-toolbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.om-toolbar-info{color:var(--text-2);font-size:.82rem}.om-spin-wrap{color:var(--primary);align-items:center;gap:6px;display:inline-flex}.om-spinner{border:2px solid var(--primary);border-top-color:#0000;border-radius:50%;width:12px;height:12px;animation:.7s linear infinite om-spin;display:inline-block}@keyframes om-spin{to{transform:rotate(360deg)}}.om-cp-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;max-width:420px;padding:24px 22px}.om-cp-title{color:var(--text);margin:0 0 20px;font-size:1rem;font-weight:600}.ol-wrap{max-width:440px;margin:40px auto;padding:0 20px 32px}.ol-card{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:28px 24px 26px}.ol-card h1{color:var(--text);margin:0 0 20px;font-size:1.2rem;font-weight:600;line-height:1.35}.ol-badge{color:var(--primary);background:var(--surface2);border:1px solid var(--border);border-radius:99px;align-items:center;gap:6px;margin-bottom:18px;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.ol-back-wrap{text-align:center;margin-top:22px}.ol-back{color:var(--primary);font-size:.9rem;font-weight:500;text-decoration:none;display:inline-block}.ol-back:hover{text-decoration:underline}
