.login-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:#0b0f19;z-index:1000;overflow:hidden}.login-stars{position:absolute;inset:0;pointer-events:none}.star-twinkle{position:absolute;background-color:#fff;border-radius:50%;box-shadow:0 0 10px 2px #fffc;animation:twinkle linear infinite}@keyframes twinkle{0%{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1.2)}to{opacity:0;transform:scale(.5)}}.login-blur-shape{position:absolute;width:320px;height:320px;border-radius:50%;pointer-events:none}.pink-blur{top:33%;left:33%;transform:translate(-50%,-50%);background-color:#ec48991a;filter:blur(100px);animation:float 6s ease-in-out infinite}.blue-blur{bottom:33%;right:33%;transform:translate(50%,50%);background-color:#3b82f61a;filter:blur(120px);animation:float 8s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-20px)}}.login-back-btn{position:absolute;top:1.5rem;left:1.5rem;display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:9999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#bfdbfe;font-size:.875rem;font-weight:800;cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .3s;z-index:50}.login-back-btn:hover{color:#fff;transform:scale(1.05);background:#ffffff1a}.login-back-btn:active{transform:scale(.95)}@media(min-width:768px){.login-back-btn{top:2.5rem;left:2.5rem}}.login-main{width:100%;max-width:28rem;z-index:10}.login-glass-card{padding:2rem;border-radius:2rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:relative}@media(min-width:768px){.login-glass-card{padding:2.5rem}}.login-header{text-align:center;margin-bottom:2rem}.login-logo{margin:0 auto 1rem;width:6rem;height:6rem;display:flex;align-items:center;justify-content:center;border-radius:1.5rem;background:linear-gradient(135deg,#2563eb,#ec4899);box-shadow:0 16px 34px #fbcfe852}.login-title{font-size:1.875rem;font-weight:900;background:linear-gradient(to right,#93c5fd,#c4b5fd,#f9a8d4);-webkit-background-clip:text;color:transparent;margin:0;letter-spacing:-.025em}.login-subtitle{color:#dbeafe99;font-weight:600;font-size:.875rem;margin:.5rem 0 0}.login-error-msg{background-color:#f43f5e33;border:1px solid rgba(244,63,94,.3);color:#fecdd3;padding:.875rem 1rem;border-radius:1rem;margin-bottom:1.5rem;text-align:center;font-weight:700;font-size:.875rem;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.login-google-section{margin-bottom:1.5rem;padding:1rem;border-radius:1.5rem;background:#02061759;border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 2px 4px #0000000f}.login-google-section p{margin:0 0 .75rem;text-align:center;font-size:.75rem;font-weight:900;color:#dbeafeb3}.google-auth-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background-color:#fff;border:none;border-radius:1rem;color:#3f3f46;font-weight:700;font-size:.875rem;cursor:pointer;transition:background-color .2s}.google-auth-btn:hover{background-color:#f4f4f5}.google-auth-btn:disabled{opacity:.7;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:.75rem;color:#dbeafe59;margin-bottom:1.5rem}.login-line{flex:1;height:1px;background-color:#ffffff1a}.login-divider span{font-size:11px;font-weight:900}.login-form-fields{display:flex;flex-direction:column;gap:1.5rem}.login-input-group{display:flex;flex-direction:column;gap:.5rem}.login-input-group label{color:#bfdbfe;font-weight:800;font-size:.875rem;padding-left:.25rem}.login-input-group input{width:100%;padding:.875rem 1.25rem;border-radius:1rem;border:2px solid rgba(255,255,255,.1);background-color:#ffffff0d;color:#fff;outline:none;transition:all .2s}.login-input-group input::placeholder{color:#ffffff4d}.login-input-group input:focus{border-color:#ffffff4d;background-color:#ffffff1a}.login-remember{display:flex;align-items:center;padding:0 .25rem}.login-remember label{display:flex;align-items:center;gap:.625rem;color:#dbeafecc;font-weight:700;font-size:.875rem;cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input{width:1rem;height:1rem;accent-color:#f9a8d4;cursor:pointer}.login-submit-btn{width:100%;padding:1rem;border-radius:1rem;font-weight:900;font-size:1.125rem;background:linear-gradient(to right,#60a5fa,#818cf8,#f472b6);color:#0f172a;border:none;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem;box-shadow:0 10px 15px -3px #6366f133}.login-submit-btn:hover{transform:scale(1.02);box-shadow:0 10px 15px -3px #6366f166}.login-submit-btn:active{transform:scale(.95)}.login-submit-btn:disabled{opacity:.5;pointer-events:none}.login-spinner{width:1.25rem;height:1.25rem;border:2px solid #0f172a;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.05)}.login-footer p{color:#dbeafe80;font-weight:600;font-size:.875rem;margin:0}.login-footer a{background:linear-gradient(to right,#93c5fd,#c4b5fd,#f9a8d4);-webkit-background-clip:text;color:transparent;font-weight:900;text-decoration:none;transition:opacity .2s}.login-footer a:hover{opacity:.8;text-decoration:underline}.index-container{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;background-color:#0b0f19;font-family:Inter,Sarabun,sans-serif;color:#fff}.star-twinkle{position:absolute;background-color:#fff;border-radius:50%;animation-name:twinkle;animation-timing-function:ease-in-out;animation-iteration-count:infinite;box-shadow:0 0 10px 2px #fffc}@keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.blur-ball{position:absolute;border-radius:50%;pointer-events:none;filter:blur(100px)}.blur-pink{top:25%;left:25%;transform:translate(-50%,-50%);width:18rem;height:18rem;background-color:#ec48991a;animation:float 6s ease-in-out infinite}.blur-blue{bottom:25%;right:25%;transform:translate(50%,50%);width:20rem;height:20rem;background-color:#3b82f61a;animation:float-delayed 8s ease-in-out infinite}.blur-emerald{top:66%;left:66%;transform:translate(-50%);width:16rem;height:16rem;background-color:#10b9810d;animation:float 7s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) translate(0)}50%{transform:translateY(-20px) translate(10px)}}@keyframes float-delayed{0%,to{transform:translateY(0) translate(0)}50%{transform:translateY(20px) translate(-10px)}}.index-header{width:100%;max-width:80rem;margin:0 auto;padding:1.5rem;z-index:10}.index-header-glass{background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:9999px;padding:.875rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 10px 15px -3px #0000001a;border:1px solid rgba(255,255,255,.1)}.brand-title{font-size:1.5rem;font-weight:900;letter-spacing:.05em;background:linear-gradient(to right,#fbcfe8,#bfdbfe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 20px rgba(251,207,232,.2)}.logo-image{height:2.5rem;width:2.5rem;border-radius:50%;object-fit:contain;filter:drop-shadow(0 0 16px rgba(186,230,253,.45))}.hero-main{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1.5rem;z-index:10}.hero-logo{height:8rem;width:8rem;border-radius:28px;object-fit:contain;margin-bottom:2rem;animation:float 6s ease-in-out infinite;filter:drop-shadow(0 18px 40px rgba(186,230,253,.42))}@media(min-width:768px){.hero-logo{height:10rem;width:10rem}}.hero-title{font-size:3rem;font-weight:900;line-height:1.2;letter-spacing:-.02em;margin-bottom:1.5rem}@media(min-width:768px){.hero-title{font-size:4.5rem}}.hero-title span.block{display:block;color:#fff;filter:drop-shadow(0 4px 3px rgba(0,0,0,.07))}.hero-title span.gradient{background:linear-gradient(to right,#fbcfe8,#bfdbfe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:800;filter:drop-shadow(0 5px 15px rgba(251,207,232,.3));animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.hero-subtitle{font-size:1.125rem;color:#dbeafecc;max-width:42rem;font-weight:600;line-height:1.625;margin-bottom:2.5rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}@media(min-width:768px){.hero-subtitle{font-size:1.5rem}}.actions-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;max-width:28rem}.btn-primary-gradient{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 2rem;font-size:1.25rem;font-weight:900;color:#fff;border:none;border-radius:9999px;background:linear-gradient(to right,#3b82f6,#8b5cf6,#ec4899);background-size:200% auto;transition:all .3s ease;box-shadow:0 10px 25px -5px #8b5cf666;cursor:pointer}.btn-primary-gradient:hover{background-position:right center;transform:scale(1.05)}.btn-primary-gradient:active{transform:scale(.95)}.btn-install{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:700;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:9999px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;cursor:pointer}.btn-install:hover{background:#fff3}.install-guide{margin-top:1.5rem;padding:1.5rem;background:#0f172acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(59,130,246,.3);border-radius:1rem;color:#fff;text-align:left;box-shadow:0 20px 25px -5px #00000080;animation:slideUp .4s ease-out;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.install-guide h3{font-size:1.125rem;font-weight:800;color:#93c5fd;margin-bottom:.5rem;margin-top:0}.install-guide p{font-size:.875rem;color:#bfdbfe;margin-bottom:1rem}.install-guide ol{list-style-type:decimal;padding-left:1.25rem;margin-bottom:1rem;color:#e2e8f0;font-size:.875rem;font-weight:500}.install-guide li{margin-bottom:.5rem}.install-guide .note{font-size:.75rem;color:#fbcfe8;font-style:italic}.install-hint{margin-top:1rem;font-size:.875rem;color:#a7f3d0;font-weight:600;background:#05966933;padding:.5rem 1rem;border-radius:9999px;border:1px solid rgba(16,185,129,.3)}:root{color-scheme:light;font-family:Inter,Noto Sans Thai,Sarabun,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--bg: #eef5ff;--ink: #0f172a;--muted: #64748b;--line: rgba(148, 163, 184, .28);--navy: #071832;--navy-2: #102a6b;--violet: #28135f;--blue: #2563eb;--sky: #38bdf8;--green: #10b981;--amber: #f59e0b;--surface: rgba(255, 255, 255, .9);--surface-strong: #ffffff;--shadow: 0 18px 45px rgba(15, 23, 42, .1)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--ink);background:radial-gradient(circle at 18% 0%,rgba(37,99,235,.16),transparent 34%),radial-gradient(circle at 88% 8%,rgba(124,58,237,.16),transparent 32%),linear-gradient(135deg,#f7fbff,#eef5ff 52%,#f7f3ff)}button,input{font:inherit}button{border:0;cursor:pointer}.app-shell{position:relative;display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;overflow:hidden}.stars{position:fixed;inset:0;pointer-events:none;z-index:0}.stars span{position:absolute;left:var(--x);top:var(--y);width:3px;height:3px;border-radius:50%;background:#38bdf8b8;box-shadow:0 0 18px #38bdf8cc;animation:twinkle 4s ease-in-out infinite;animation-delay:var(--delay)}@keyframes twinkle{0%,to{opacity:.18;transform:scale(.8)}50%{opacity:.9;transform:scale(1.35)}}.sidebar{position:sticky;top:0;z-index:3;display:flex;flex-direction:column;gap:22px;height:100vh;padding:22px 16px;color:#eaf2ff;background:linear-gradient(180deg,#071832f5,#082046fa),radial-gradient(circle at 60% -10%,rgba(56,189,248,.38),transparent 36%);box-shadow:16px 0 35px #0718322e}.brand{display:flex;align-items:center;gap:12px}.brand.large{align-items:flex-start}.brand-mark{display:grid;width:42px;height:42px;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 12px 28px #2563eb57;flex:none}.brand strong{display:block;font-size:14px;line-height:1.35}.brand span{display:block;margin-top:2px;color:#eaf2ffb3;font-size:11px;line-height:1.4}.nav-list{display:grid;gap:7px}.nav-item{display:grid;grid-template-columns:22px 1fr 16px;align-items:center;gap:8px;min-height:42px;padding:0 10px;color:#eaf2ffc7;border-radius:8px;background:transparent;text-align:left}.nav-item svg:first-child{color:var(--item-color)}.nav-item svg:last-child{opacity:.38}.nav-item.active{color:#fff;background:linear-gradient(135deg,#2563ebf2,#38bdf8ad);box-shadow:0 12px 26px #2563eb52}.chevron{transition:transform .2s ease}.chevron.expanded{transform:rotate(90deg)}.nav-section-group{display:flex;flex-direction:column;gap:4px}.sub-nav-list{display:flex;flex-direction:column;gap:2px;padding-left:20px;margin-top:2px}.sub-nav-item{display:flex;align-items:center;gap:8px;min-height:36px;padding:0 10px;color:#eaf2ff99;background:transparent;border-radius:6px;font-size:13px;text-align:left;transition:all .2s}.sub-nav-item:hover{color:#eaf2ffe6;background:#ffffff0d}.sub-nav-item.active{color:#38bdf8;background:#38bdf81a}.sub-nav-dot{width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.5}.sub-nav-item.active .sub-nav-dot{opacity:1;box-shadow:0 0 6px currentColor}.sub-nav-label{flex:1}.sub-nav-badge{font-size:9px;padding:2px 6px;border-radius:9px;background:#ffffff1a;color:#ffffff80}.db-card{display:flex;gap:10px;margin-top:auto;padding:14px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#ffffff14}.db-card strong,.db-card span{display:block;line-height:1.35}.db-card strong{font-size:12px}.db-card span{margin-top:4px;color:#eaf2ffad;font-size:11px}.main{position:relative;z-index:1;min-width:0;padding:18px 22px 34px;overflow-y:auto}.topbar{position:sticky;top:0;z-index:2;display:grid;grid-template-columns:minmax(240px,1fr) auto auto auto auto;gap:12px;align-items:center;margin-bottom:18px;padding:12px;border:1px solid rgba(255,255,255,.76);border-radius:8px;background:#ffffffbd;box-shadow:0 8px 26px #0f172a0f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.searchbox,.filters label{display:flex;align-items:center;gap:8px;min-height:42px;padding:0 14px;border:1px solid var(--line);border-radius:8px;background:#ffffffdb;color:var(--muted)}.searchbox input,.filters input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--ink)}.top-action,.profile-button,.icon-button{min-height:42px;border-radius:8px;background:#ffffffdb;color:#1e293b}.top-action{display:inline-flex;align-items:center;gap:8px;padding:0 14px;border:1px solid var(--line)}.icon-button{position:relative;display:grid;width:42px;place-items:center;border:1px solid var(--line)}.icon-button i{position:absolute;right:9px;top:9px;width:8px;height:8px;border:2px solid white;border-radius:50%;background:#ef4444}.mobile-menu{display:none}.profile-button{display:grid;grid-template-columns:36px auto 18px;align-items:center;gap:9px;padding:4px 8px 4px 4px;border:1px solid var(--line);text-align:left}.profile-button>span{display:grid;width:36px;height:36px;place-items:center;color:#fff;border-radius:50%;background:linear-gradient(135deg,#38bdf8,#2563eb)}.profile-button strong,.profile-button small{display:block;line-height:1.25}.profile-button strong{font-size:12px}.profile-button small{color:var(--muted);font-size:10px}.page-stack{display:grid;gap:18px}.hero-panel,.panel,.module-board,.quick-actions{border:1px solid rgba(255,255,255,.78);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.hero-panel{display:grid;grid-template-columns:minmax(0,1fr) 220px;align-items:center;min-height:190px;padding:26px;overflow:hidden;background:radial-gradient(circle at 90% 10%,rgba(124,58,237,.22),transparent 38%),linear-gradient(135deg,#071832f5,#102a6be0);color:#fff}.system-status{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;color:#dbeafe;font-size:13px;line-height:1.45}.hero-copy h1,.section-title h1{margin:0;font-size:clamp(28px,4vw,46px);line-height:1.15;letter-spacing:0}.hero-copy p,.section-title p{margin:8px 0 0;color:#ffffffbd;line-height:1.55}.section-title{padding:2px 2px 0}.section-title h1{color:#0f172a;font-size:clamp(26px,3vw,38px)}.section-title p{color:var(--muted)}.hero-orbit{position:relative;width:180px;height:180px;justify-self:end}.orbit-core{position:absolute;inset:42px;z-index:1;display:grid;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.24);border-radius:50%;background:radial-gradient(circle,#38bdf8e0,#2563ebb8)}.orbit-core span{font-size:12px;font-weight:700}.hero-orbit i{position:absolute;inset:10px;border:1px solid rgba(125,211,252,.32);border-radius:50%}.hero-orbit i:nth-child(3){inset:25px;transform:rotate(24deg) scaleX(.68)}.hero-orbit i:nth-child(4){inset:0;transform:rotate(-28deg) scaleY(.52)}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-card{min-height:128px;padding:18px;border:1px solid rgba(255,255,255,.82);border-radius:8px;background:var(--surface-strong);box-shadow:0 12px 32px #0f172a12}.metric-icon{display:grid;width:36px;height:36px;margin-bottom:10px;place-items:center;border-radius:8px}.metric-card.blue .metric-icon{color:#2563eb;background:#dbeafe}.metric-card.green .metric-icon{color:#059669;background:#d1fae5}.metric-card.violet .metric-icon{color:#7c3aed;background:#ede9fe}.metric-card.amber .metric-icon{color:#d97706;background:#fef3c7}.metric-card span,.metric-card small{display:block;color:var(--muted);line-height:1.45}.metric-card strong{display:block;margin:5px 0 3px;font-size:28px;line-height:1.1}.dashboard-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}.chart-panel{grid-column:span 2}.panel,.module-board,.quick-actions{padding:18px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-header h2{margin:0;font-size:18px;line-height:1.3}.panel-header button,.header-actions button,.filters button,.learning-card button{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:0 12px;color:#1d4ed8;border:1px solid #dbeafe;border-radius:8px;background:#eff6ff;font-size:13px;line-height:1.3}.calendar-layout,.split-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:16px}.mini-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.mini-calendar span{display:grid;aspect-ratio:1;place-items:center;color:#334155;border-radius:8px;background:#f8fafc;font-size:12px}.mini-calendar .today{color:#fff;background:#2563eb}.mini-calendar .muted{color:#94a3b8}.event-list{display:grid;gap:10px}.event-row{display:grid;grid-template-columns:60px 1fr;gap:10px;align-items:center;min-height:46px;padding:0 12px;border-radius:8px;background:#f8fafc}.event-row strong{font-size:13px}.event-row span{line-height:1.4}.event-row.blue{border-left:4px solid #2563eb}.event-row.red{border-left:4px solid #ef4444}.event-row.amber{border-left:4px solid #f59e0b}.event-row.violet{border-left:4px solid #7c3aed}.notice-row{display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:center;padding:12px 0;border-bottom:1px solid #eef2f7}.notice-row:last-child{border-bottom:0}.notice-row>div{display:grid;width:42px;height:42px;place-items:center;color:#2563eb;border-radius:8px;background:#eff6ff}.notice-row strong,.notice-row small{display:block;line-height:1.42}.notice-row small{color:var(--muted)}.line-chart{display:grid;grid-template-columns:repeat(7,1fr);align-items:end;gap:16px;height:180px;padding:16px;border-radius:8px;background:linear-gradient(#e2e8f0 1px,transparent 1px) 0 0 / 100% 25%,#f8fafc}.line-chart i{position:relative;display:block;height:var(--height);min-height:34px;border-radius:8px 8px 3px 3px;background:linear-gradient(180deg,#38bdf8,#2563eb)}.line-chart span{position:absolute;left:50%;top:-22px;transform:translate(-50%);color:#475569;font-size:11px;font-style:normal}.action-grid{display:grid;grid-template-columns:repeat(9,minmax(90px,1fr));gap:12px}.quick-action{display:grid;min-height:92px;place-items:center;gap:8px;padding:12px;color:#1e293b;border:1px solid #e2e8f0;border-radius:8px;background:#fff;box-shadow:0 10px 24px #0f172a0d}.quick-action svg{color:#2563eb}.quick-action span{font-size:13px;font-weight:700;line-height:1.35;text-align:center}.module-grid,.learning-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.module-board.compact .module-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.module-card,.learning-card{display:grid;gap:12px;padding:16px;border:1px solid #e2e8f0;border-radius:8px;background:#fff}.module-card-top,.module-card footer,.learning-card footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.module-card h3,.learning-card h3{margin:0;font-size:17px;line-height:1.3}.module-card p,.learning-card p{margin:0;color:var(--muted);line-height:1.5}.module-card footer span,.learning-card small{color:#64748b;font-size:12px;line-height:1.4}.ready,.waiting,.external,.designing{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;font-size:12px;font-weight:700;line-height:1.2}.ready{color:#047857;background:#d1fae5}.waiting{color:#b45309;background:#fef3c7}.external{color:#4338ca;background:#e0e7ff}.designing{color:#be185d;background:#fce7f3}.filters{display:grid;grid-template-columns:minmax(180px,1fr) auto auto;gap:10px;margin-bottom:12px}.header-actions{display:flex;flex-wrap:wrap;gap:8px}.table-wrap{overflow-x:auto}table{width:100%;min-width:640px;border-collapse:collapse}th,td{padding:13px 12px;border-bottom:1px solid #eef2f7;text-align:left;line-height:1.45}th{color:#64748b;background:#f8fafc;font-size:12px}td{font-size:13px}.link-status{display:inline-flex;align-items:center;gap:5px;color:#b45309;font-weight:700}.link-status.linked{color:#047857}.schedule-grid{display:grid;grid-template-columns:repeat(5,minmax(92px,1fr));gap:6px;overflow-x:auto}.schedule-grid strong,.schedule-grid span{display:grid;min-height:52px;place-items:center;padding:8px;border-radius:8px;line-height:1.35;text-align:center}.schedule-grid strong{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed)}.schedule-grid span{background:#eef6ff}.schedule-grid .break{color:#92400e;background:#fef3c7}.learning-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.learning-card{min-height:230px;background:radial-gradient(circle at 90% 0%,rgba(236,72,153,.14),transparent 34%),#fff}.learning-icon{display:grid;width:54px;height:54px;place-items:center;color:#be185d;border-radius:8px;background:#fce7f3}.learning-card>span{color:#7c3aed;font-size:13px;font-weight:800}.integration-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.integration-strip article{display:grid;gap:8px;padding:16px;border:1px solid rgba(255,255,255,.84);border-radius:8px;background:#fff;box-shadow:0 12px 28px #0f172a0f}.integration-strip i{display:block;width:34px;height:5px;border-radius:999px}.integration-strip span{color:var(--muted);font-size:12px}.integration-strip strong{font-size:18px}.module-list{display:grid;gap:8px}.module-row{display:grid;grid-template-columns:42px minmax(0,1fr) 110px 130px;gap:12px;align-items:center;min-height:62px;padding:10px;border:1px solid #eef2f7;border-radius:8px;background:#fbfdff}.row-icon{display:grid;width:42px;height:42px;place-items:center;border-radius:8px;background:#fff}.module-row strong,.module-row small{display:block;line-height:1.4}.module-row small{color:var(--muted)}.modal-layer{position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:20px;background:#0718328a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-preview{position:relative;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);width:min(920px,100%);min-height:480px;overflow:hidden;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#fff;box-shadow:0 30px 90px #0000003d}.close-button{position:absolute;right:14px;top:14px;z-index:2;display:grid;width:44px;height:44px;place-items:center;color:#334155;border-radius:8px;background:#ffffffe0}.login-visual{display:grid;align-content:space-between;min-height:480px;padding:34px;color:#fff;background:radial-gradient(circle at 28% 24%,rgba(56,189,248,.24),transparent 20%),linear-gradient(145deg,#071832,#102a6b 64%,#28135f)}.school-scene{position:relative;min-height:230px}.school-scene>span{position:absolute;width:4px;height:4px;border-radius:50%;background:#dbeafe;box-shadow:0 0 18px #38bdf8}.school-scene>span:nth-child(1){left:14%;top:20%}.school-scene>span:nth-child(2){left:52%;top:8%}.school-scene>span:nth-child(3){right:14%;top:30%}.building{position:absolute;left:50%;bottom:12px;width:220px;height:118px;transform:translate(-50%);border:1px solid rgba(191,219,254,.5);background:linear-gradient(180deg,#1d4ed8,#0f2f6f);clip-path:polygon(0 38%,50% 0,100% 38%,100% 100%,0 100%)}.building i{position:absolute;left:50%;top:44px;width:48px;height:74px;transform:translate(-50%);background:#ffffff2e}.building b{position:absolute;top:62px;width:30px;height:28px;background:#dbeafed1}.building b:nth-child(2){left:28px}.building b:nth-child(3){right:28px}.building b:nth-child(4){left:95px;top:18px;border-radius:50%}.login-form{display:grid;align-content:center;gap:16px;padding:54px}.login-form h2{margin:0;font-size:26px}.login-form label{display:grid;gap:7px;color:#475569;font-size:13px;font-weight:700}.login-form input{min-height:44px;padding:0 12px;border:1px solid #dbe3ef;border-radius:8px;outline:0}.primary-button{min-height:46px;color:#fff;border-radius:8px;background:linear-gradient(135deg,#2563eb,#1d4ed8);font-weight:800}.backdrop{display:none}@media(max-width:1180px){.metrics-grid,.module-grid,.module-board.compact .module-grid,.learning-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.action-grid{grid-template-columns:repeat(5,minmax(90px,1fr))}.split-grid,.calendar-layout{grid-template-columns:1fr}}@media(max-width:860px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;width:min(300px,86vw);transform:translate(-105%);transition:transform .18s ease}.sidebar.open{transform:translate(0)}.backdrop{position:fixed;inset:0;z-index:2;display:block;background:#0f172a5c}.main{padding:12px}.topbar{grid-template-columns:42px minmax(0,1fr) 42px 42px}.mobile-menu{display:grid}.top-action,.profile-button{display:none}.hero-panel{grid-template-columns:1fr}.hero-orbit{display:none}.dashboard-grid,.chart-panel{grid-template-columns:1fr;grid-column:auto}.integration-strip,.metrics-grid,.module-grid,.module-board.compact .module-grid,.learning-grid{grid-template-columns:1fr}.action-grid{grid-template-columns:repeat(3,minmax(86px,1fr))}.filters{grid-template-columns:1fr}.module-row{grid-template-columns:42px 1fr}.module-row>span,.module-row>small{grid-column:2}.login-preview{grid-template-columns:1fr;max-height:92vh;overflow:auto}.login-visual{min-height:260px}}@media(max-width:520px){.hero-panel,.panel,.module-board,.quick-actions{padding:14px}.action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-header{align-items:flex-start;flex-direction:column}.header-actions{width:100%}.header-actions button{flex:1 1 auto;justify-content:center}.login-form{padding:28px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.profile-menu-container{position:relative}.profile-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;width:12rem;background:#0f172ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:.75rem;box-shadow:0 10px 25px -5px #00000080;display:flex;flex-direction:column;padding:.5rem;z-index:50;animation:slideDownFade .2s cubic-bezier(.16,1,.3,1)}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;font-size:.875rem;font-weight:600;color:#e2e8f0;background:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease;text-align:left}.dropdown-item:hover{background:#ffffff1a;color:#fff}.dropdown-divider{height:1px;background:#ffffff1a;margin:.25rem 0}.dropdown-item.logout{color:#fca5a5}.dropdown-item.logout:hover{background:#ef444433;color:#fecaca}.hero-interactive-img{width:100%;height:auto;display:block;border-radius:12px;transition:transform .4s cubic-bezier(.175,.885,.32,1.275),box-shadow .4s ease,filter .4s ease;animation:heroGlowPulse 3s infinite alternate;cursor:pointer}.hero-interactive-img:hover{transform:scale(1.015) translateY(-5px) rotateX(2deg);box-shadow:0 25px 50px #00c3ff59,0 0 30px #7c3aed80;filter:brightness(1.1) contrast(1.05)}@keyframes heroGlowPulse{0%{box-shadow:0 0 10px #00c3ff1a,0 0 5px #7c3aed33;filter:brightness(1)}to{box-shadow:0 0 30px #00c3ff4d,0 0 15px #7c3aed66;filter:brightness(1.08)}}
