.lp{background:#fff;color:var(--ink);scroll-behavior:smooth}.lp-wrap{max-width:1180px;margin:0 auto;padding:0 24px}.lp-header{position:sticky;top:0;z-index:50;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s}.lp-header.scrolled{border-bottom-color:var(--line);box-shadow:0 4px 18px #0f172a0d}.lp-nav{display:flex;align-items:center;gap:28px;height:72px}.lp-brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}.lp-brand-badge{font-size:28px}.lp-brand strong{display:block;font-size:16px;line-height:1.2}.lp-brand small{color:var(--slate);font-size:11.5px}.lp-brand.foot strong{color:#fff}.lp-menu{display:flex;gap:26px;margin-left:auto}.lp-menu a{text-decoration:none;color:var(--slate);font-weight:550;font-size:14.5px;transition:color .15s}.lp-menu a:hover{color:var(--indigo)}.lp-nav-cta{display:flex;align-items:center;gap:12px}.lp-burger{display:none;background:none;border:none;font-size:24px}.lbtn{display:inline-block;text-decoration:none;font-weight:650;border-radius:11px;padding:11px 22px;font-size:14.5px;transition:transform .12s,background .15s,box-shadow .15s}.lbtn:hover{transform:translateY(-1px)}.lbtn.solid{background:var(--indigo);color:#fff;box-shadow:0 6px 18px #4f46e54d}.lbtn.solid:hover{background:var(--indigo-dark)}.lbtn.outline{border:1.5px solid var(--line);color:var(--ink);background:#fff}.lbtn.outline:hover{border-color:var(--indigo);color:var(--indigo)}.lbtn.glass{background:#ffffff29;color:#fff;border:1px solid rgba(255,255,255,.4)}.lbtn.glass:hover{background:#ffffff42}.lbtn.lg{padding:14px 30px;font-size:16px;border-radius:13px}.lp-hero{background:radial-gradient(900px 500px at 85% -10%,#ede9fe 0%,transparent 60%),radial-gradient(700px 420px at -10% 30%,#e0e7ff 0%,transparent 55%),linear-gradient(180deg,#fafaff,#fff);padding:84px 0 90px;overflow:hidden}.lp-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}.lp-pill{display:inline-block;background:#eef2ff;color:var(--indigo);font-weight:650;font-size:13px;padding:7px 16px;border-radius:999px;margin-bottom:22px}.lp-hero h1{font-size:52px;line-height:1.08;font-weight:850;letter-spacing:-.02em;margin:0 0 20px}.lp-hero h1 em{font-style:normal;background:linear-gradient(90deg,var(--indigo),#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}.lp-hero-copy>p{font-size:18px;color:var(--slate);line-height:1.65;max-width:520px;margin:0 0 30px}.lp-hero-actions{display:flex;gap:14px;flex-wrap:wrap}.lp-hero-trust{display:flex;gap:22px;margin-top:26px;color:var(--slate);font-size:13.5px;font-weight:550;flex-wrap:wrap}.lp-hero-visual{position:relative;min-height:420px}.mock{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 44px #0f172a1a;padding:18px 20px;font-size:13.5px}.mock-title{font-weight:750;margin-bottom:12px;font-size:14px}.mock-row{display:flex;justify-content:space-between;gap:14px;padding:7px 0;border-bottom:1px dashed #eef0f4}.mock-row:last-of-type{border-bottom:none}.mock-row span{color:var(--slate)}.mock-row b.ok{color:var(--emerald)}.mock-row b.warn{color:var(--amber)}.mock-bar{height:8px;background:#eef2ff;border-radius:99px;margin:12px 0 6px;overflow:hidden}.mock-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--indigo),#7c3aed);border-radius:99px}.mock small{color:var(--muted)}.mock-att{position:absolute;top:0;left:0;width:78%;z-index:2}.mock-note{position:absolute;top:47%;right:0;width:62%;z-index:3;border-left:4px solid var(--indigo);animation:lp-float 5s ease-in-out infinite}.mock-note p{margin:0;color:var(--slate)}.mock-grade{position:absolute;bottom:0;left:8%;width:58%;z-index:1}.mock-signed{margin-top:10px;background:#ecfdf5;color:var(--emerald);font-weight:650;padding:6px 12px;border-radius:9px;display:inline-block;font-size:12.5px}@keyframes lp-float{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}.lp-stats{background:var(--ink);color:#fff;padding:30px 0}.lp-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}.lp-stats-grid b{display:block;font-size:26px;font-weight:800}.lp-stats-grid span{color:#94a3b8;font-size:13.5px}.lp-section{padding:92px 0}.lp-section.alt{background:#f8fafc}.lp-head{text-align:center;max-width:660px;margin:0 auto 54px}.lp-eyebrow{display:inline-block;color:var(--indigo);font-weight:750;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}.lp-section h2{font-size:36px;font-weight:820;letter-spacing:-.015em;line-height:1.15;margin:0 0 16px}.lp-head p,.lp-lede{color:var(--slate);font-size:17px;line-height:1.65}.lp-lede{margin-bottom:26px}.lp-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.lp-feature-card{border:1px solid var(--line);border-radius:18px;padding:28px;transition:transform .18s,box-shadow .18s,border-color .18s;background:#fff}.lp-feature-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px #0f172a17;border-color:#c7d2fe}.lp-feature-icon{font-size:30px;background:#eef2ff;width:58px;height:58px;display:flex;align-items:center;justify-content:center;border-radius:15px;margin-bottom:18px}.lp-feature-card h3{font-size:18.5px;margin:0 0 10px}.lp-feature-card p{color:var(--slate);font-size:14.5px;line-height:1.6;margin:0 0 14px}.lp-feature-card ul{margin:0;padding:0;list-style:none;display:grid;gap:7px}.lp-feature-card li{font-size:13.5px;color:var(--ink);padding-left:22px;position:relative}.lp-feature-card li:before{content:"✓";position:absolute;left:0;color:var(--emerald);font-weight:800}.lp-split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}.lp-checks{margin:0;padding:0;list-style:none;display:grid;gap:11px}.lp-checks li{padding-left:30px;position:relative;font-size:15.5px;font-weight:530}.lp-checks li:before{content:"✓";position:absolute;left:0;top:0;width:21px;height:21px;border-radius:7px;background:#ecfdf5;color:var(--emerald);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}.lp-checks.small li{font-size:14px;font-weight:470}.lp-panel-visual .mock{position:static;width:100%}.mock-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}.mock-kpis>div{background:#f8fafc;border-radius:11px;padding:10px 6px;text-align:center}.mock-kpis b{display:block;font-size:17px}.mock-kpis span{font-size:11px;color:var(--muted)}.mock-popup{margin-top:14px;background:linear-gradient(90deg,#eef2ff,#f5f3ff);border:1px solid #c7d2fe;color:var(--indigo-dark);font-weight:600;border-radius:12px;padding:12px 14px;font-size:13px}.lp-group-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.lp-group-grid.two{grid-template-columns:1fr 1fr}.lp-group-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px}.lp-group-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}.lp-group-head span{font-size:22px}.lp-group-head h3{font-size:15px;margin:0}.lp-track-demo{margin-top:34px;display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap;background:#f8fafc;border:1px dashed var(--line);border-radius:14px;padding:16px 20px}.lp-track-label{font-weight:700;font-size:14px}.lp-viewpill{font-size:13px;font-weight:650;border-radius:999px;padding:7px 15px}.lp-viewpill.viewed{background:#ecfdf5;color:var(--emerald)}.lp-viewpill.notviewed{background:#fef2f2;color:var(--red)}.lp-events-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.lp-event-card{border-radius:18px;padding:26px 22px;color:#fff;min-height:170px;display:flex;flex-direction:column;justify-content:flex-end;gap:6px}.lp-event-card h3{margin:0;font-size:18px}.lp-event-card p{margin:0;font-size:13px;opacity:.92;line-height:1.5}.lp-event-tag{align-self:flex-start;background:#ffffff38;border-radius:999px;padding:4px 12px;font-size:11.5px;font-weight:700;margin-bottom:auto}.lp-event-card.g1{background:linear-gradient(150deg,#4f46e5,#7c3aed)}.lp-event-card.g2{background:linear-gradient(150deg,#059669,#0d9488)}.lp-event-card.g3{background:linear-gradient(150deg,#d97706,#ea580c)}.lp-event-card.g4{background:linear-gradient(150deg,#db2777,#9d174d)}.lp-cta{background:linear-gradient(135deg,var(--indigo-dark),var(--indigo) 60%,#7c3aed);color:#fff;padding:78px 0}.lp-cta-inner{text-align:center}.lp-cta h2{font-size:34px;margin:0 0 12px}.lp-cta p{color:#ffffffd9;font-size:17px;margin:0 0 28px}.lp-footer{background:var(--ink);color:#cbd5e1;padding:60px 0 0}.lp-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;padding-bottom:44px}.lp-footer p{font-size:14px;line-height:1.65;color:#94a3b8}.lp-footer h4{color:#fff;font-size:14px;margin:0 0 14px}.lp-footer a,.lp-footer span{display:block;color:#94a3b8;text-decoration:none;font-size:14px;margin-bottom:9px}.lp-footer a:hover{color:#fff}.lp-foot-base{border-top:1px solid rgba(255,255,255,.09);text-align:center;padding:22px;font-size:13px;color:#64748b}@media (max-width: 1024px){.lp-feature-grid,.lp-group-grid,.lp-events-grid{grid-template-columns:repeat(2,1fr)}.lp-hero h1{font-size:42px}}@media (max-width: 860px){.lp-hero-grid,.lp-split{grid-template-columns:1fr}.lp-split.reverse .lp-panel-visual{order:2}.lp-hero-visual{display:none}.lp-menu{position:fixed;top:72px;left:0;right:0;background:#fff;flex-direction:column;gap:0;border-bottom:1px solid var(--line);display:none}.lp-menu.open{display:flex}.lp-menu a{padding:16px 24px;border-top:1px solid #f1f5f9}.lp-burger{display:block}.lp-stats-grid{grid-template-columns:repeat(2,1fr)}.lp-footer-grid{grid-template-columns:1fr 1fr}.lp-hero{padding:56px 0}.lp-hero h1{font-size:34px}.lp-section{padding:60px 0}.lp-section h2{font-size:28px}.lp-group-grid,.lp-group-grid.two,.lp-feature-grid,.lp-events-grid{grid-template-columns:1fr}}:root{--indigo: #4f46e5;--indigo-dark: #3730a3;--emerald: #059669;--amber: #d97706;--red: #dc2626;--ink: #0f172a;--slate: #475569;--muted: #94a3b8;--bg: #f1f5f9;--card: #ffffff;--line: #e2e8f0;--radius: 14px;--shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 8px 24px rgba(15, 23, 42, .06)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}h1,h2,h3{margin:0}.screen-center{height:100vh;display:flex;align-items:center;justify-content:center}.screen-center.small{height:40vh}.spinner{width:42px;height:42px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--indigo);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}.login-hero{background:linear-gradient(140deg,var(--indigo-dark) 0%,var(--indigo) 55%,#6d28d9 100%);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-hero:after{content:"";position:absolute;right:-120px;top:-120px;width:380px;height:380px;border-radius:50%;background:#ffffff14}.login-hero:before{content:"";position:absolute;left:-80px;bottom:-140px;width:320px;height:320px;border-radius:50%;background:#ffffff0f}.hero-brand{display:flex;align-items:center;gap:14px;font-size:22px;font-weight:700}.hero-brand .brand-badge{font-size:30px}.hero-copy h1{font-size:40px;line-height:1.15;margin-bottom:16px;font-weight:800}.hero-copy p{font-size:17px;color:#ffffffd9;max-width:460px;line-height:1.6}.hero-points{display:grid;gap:12px;margin-top:28px}.hero-point{display:flex;gap:10px;align-items:center;color:#ffffffeb}.hero-point .dot{background:#ffffff2e;border-radius:10px;padding:6px 9px}.hero-foot{color:#fff9;font-size:13px;position:relative}.login-panel{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--card)}.login-card{width:100%;max-width:400px}.login-card h2{font-size:26px;font-weight:800;margin-bottom:6px}.login-card .sub{color:var(--slate);margin-bottom:28px}.field{margin-bottom:18px}.field label{display:block;font-size:13px;font-weight:600;color:var(--slate);margin-bottom:6px}.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font:inherit;background:#f8fafc;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--indigo);background:#fff}.btn{background:var(--indigo);color:#fff;border:none;border-radius:10px;padding:12px 20px;font-weight:600;transition:background .15s}.btn:hover{background:var(--indigo-dark)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.block{width:100%}.btn.ghost{background:#eef2ff;color:var(--indigo)}.btn.small{padding:7px 14px;font-size:13px}.form-error{background:#fef2f2;color:var(--red);border:1px solid #fecaca;padding:10px 14px;border-radius:10px;font-size:14px;margin-bottom:16px}.demo-creds{margin-top:26px;background:#f8fafc;border:1px dashed var(--line);border-radius:10px;padding:14px 16px;font-size:13px;color:var(--slate)}.demo-creds strong{color:var(--ink)}.demo-creds code{background:#eef2ff;padding:1px 6px;border-radius:6px}.shell{display:flex;min-height:100vh}.sidebar{width:248px;background:var(--ink);color:#cbd5e1;padding:22px 14px;display:flex;flex-direction:column;gap:8px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center;padding:4px 10px 20px}.brand-badge{font-size:26px}.brand-name{color:#fff;font-weight:700}.brand-sub{font-size:12px;color:var(--muted)}.side-nav{display:flex;flex-direction:column;gap:4px;flex:1}.side-link{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;color:#cbd5e1;text-align:left;padding:11px 12px;border-radius:10px;font-weight:500;transition:background .15s}.side-link:hover{background:#ffffff12;color:#fff}.side-link.active{background:var(--indigo);color:#fff}.side-link.logout{color:#fca5a5;margin-top:auto}.side-icon{width:22px;text-align:center}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:18px;padding:18px 28px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}.topbar>div:nth-child(2){flex:1}.hamburger{display:none;background:none;border:none;font-size:22px}.page-title{font-size:20px;font-weight:700}.page-subtitle{font-size:13px;color:var(--slate)}.user-chip{display:flex;align-items:center;gap:10px}.avatar{width:38px;height:38px;border-radius:50%;background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.user-name{font-weight:600;font-size:14px}.user-role{font-size:12px;color:var(--slate)}.content{padding:26px 28px;display:grid;gap:22px;align-content:start}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}.stat-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;display:flex;gap:16px;align-items:center}.stat-icon{font-size:26px;background:#eef2ff;border-radius:12px;padding:10px 12px}.tone-green .stat-icon{background:#ecfdf5}.tone-amber .stat-icon{background:#fffbeb}.tone-red .stat-icon{background:#fef2f2}.stat-value{font-size:24px;font-weight:800}.stat-label{font-size:13px;color:var(--slate)}.stat-hint{font-size:12px;color:var(--muted)}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}.card-head h2{font-size:16px;font-weight:700}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--line)}td{padding:11px 10px;border-bottom:1px solid #f1f5f9}tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge-green{background:#ecfdf5;color:var(--emerald)}.badge-amber{background:#fffbeb;color:var(--amber)}.badge-red{background:#fef2f2;color:var(--red)}.badge-indigo{background:#eef2ff;color:var(--indigo)}.badge-gray{background:#f1f5f9;color:var(--slate)}.empty{color:var(--muted);padding:18px 4px;font-size:14px}.error-box{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius);padding:18px;color:var(--red);display:grid;gap:10px;justify-items:start}.notice-list{display:grid;gap:12px}.notice{border:1px solid var(--line);border-radius:12px;padding:14px 16px}.notice-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:6px}.notice-date{color:var(--muted);font-size:12px;white-space:nowrap}.notice p{margin:4px 0 10px;color:var(--slate);font-size:14px;line-height:1.55}.att-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 4px;border-bottom:1px solid #f1f5f9;flex-wrap:wrap}.att-name{font-weight:500}.att-roll{color:var(--muted);font-size:12px;margin-left:8px}.seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}.seg button{border:none;background:#fff;padding:7px 12px;font-size:13px;color:var(--slate)}.seg button+button{border-left:1px solid var(--line)}.seg button.sel-Present{background:#ecfdf5;color:var(--emerald);font-weight:700}.seg button.sel-Late{background:#fffbeb;color:var(--amber);font-weight:700}.seg button.sel-Absent{background:#fef2f2;color:var(--red);font-weight:700}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.toolbar select{padding:9px 12px;border-radius:10px;border:1.5px solid var(--line);background:#fff}.save-note{color:var(--emerald);font-size:13px;font-weight:600}.tabs{display:flex;gap:8px;flex-wrap:wrap}.tab{border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:8px 18px;font-weight:600;color:var(--slate)}.tab.active{background:var(--indigo);border-color:var(--indigo);color:#fff}.att-chips{display:flex;gap:6px;flex-wrap:wrap}.att-chip{font-size:11px;padding:4px 8px;border-radius:8px;background:#f1f5f9;color:var(--slate)}.att-chip.Present{background:#ecfdf5;color:var(--emerald)}.att-chip.Absent{background:#fef2f2;color:var(--red)}.att-chip.Late,.att-chip.Half.Day{background:#fffbeb;color:var(--amber)}@media (max-width: 980px){.login-page{grid-template-columns:1fr}.login-hero{display:none}.grid-2{grid-template-columns:1fr}.sidebar{position:fixed;left:-260px;z-index:30;transition:left .2s;height:100vh}.sidebar.open{left:0}.hamburger{display:block}.content{padding:18px 14px}.user-meta{display:none}}
