.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}}.lp-own-strip{margin-top:22px;background:linear-gradient(90deg,#fffbeb,#fef3c7);border:1px solid #fde68a;color:#92400e;border-radius:12px;padding:12px 18px;font-size:14.5px;max-width:560px}.lp-ownit{background:radial-gradient(700px 360px at 90% 0%,rgba(124,58,237,.35) 0%,transparent 60%),radial-gradient(600px 320px at 0% 100%,rgba(79,70,229,.3) 0%,transparent 55%),var(--ink);color:#fff;padding:92px 0}.lp-ownit .lp-head h2{color:#fff}.lp-ownit .lp-head h2 em{font-style:normal;color:#a5b4fc}.lp-ownit .lp-head p{color:#cbd5e1}.lp-eyebrow.light{color:#a5b4fc}.lp-own-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-own-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:26px;transition:background .18s,transform .18s}.lp-own-card:hover{background:#ffffff17;transform:translateY(-4px)}.lp-own-card span{font-size:30px;display:block;margin-bottom:14px}.lp-own-card h3{font-size:17px;margin:0 0 9px;color:#fff}.lp-own-card p{margin:0;font-size:14px;line-height:1.6;color:#cbd5e1}.lp-own-card p b{color:#fff}.lp-own-cta{margin-top:44px;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}.lp-own-cta>span{font-size:17px;font-weight:700}.lp-cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.lbtn.outline-light{border:1.5px solid rgba(255,255,255,.55);color:#fff;background:transparent}.lbtn.outline-light:hover{background:#ffffff1f}@media (max-width: 1024px){.lp-own-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 860px){.lp-own-grid{grid-template-columns:1fr}.lp-ownit{padding:60px 0}}: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}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:60;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#fff;border-radius:16px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0f172a4d}.modal.wide{max-width:760px}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:1}.modal-head h3{font-size:17px}.modal-x{background:none;border:none;font-size:16px;color:var(--muted)}.modal-body{padding:20px 22px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.btn.danger{background:var(--red)}.btn.danger:hover{background:#b91c1c}.bell-wrap{position:relative}.bell{background:#f1f5f9;border:none;border-radius:50%;width:40px;height:40px;font-size:17px;position:relative}.bell-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;border-radius:999px;font-size:11px;font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0 4px}.bell-panel{position:absolute;right:0;top:48px;width:360px;max-width:88vw;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 48px #0f172a2e;z-index:40;max-height:480px;overflow-y:auto}.bell-panel-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff}.bell-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid #f1f5f9}.bell-item.unseen{background:#eef2ff66}.bell-item-icon{font-size:20px}.bell-item-title{font-weight:650;font-size:13.5px}.bell-item-msg{font-size:12.5px;color:var(--slate);margin-top:2px}.bell-item-date{font-size:11px;color:var(--muted);margin-top:3px}.popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:80;display:flex;align-items:center;justify-content:center;padding:20px}.popup-card{background:#fff;border-radius:20px;padding:34px 30px 28px;text-align:center;max-width:420px;width:100%;box-shadow:0 28px 80px #0f172a59;animation:popup-in .25s ease}@keyframes popup-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.popup-icon{font-size:52px;margin-bottom:10px}.popup-card h3{font-size:20px;margin-bottom:8px}.popup-card p{color:var(--slate);font-size:14.5px;line-height:1.6;margin:0 0 20px}.popup-card.kind-Birthday{background:linear-gradient(170deg,#fdf2f8,#fff 40%)}.popup-card.kind-Event{background:linear-gradient(170deg,#eef2ff,#fff 40%)}.popup-more{display:block;margin-top:12px;color:var(--muted)}.sigpad{display:grid;gap:10px;justify-items:start}.sig-canvas{width:100%;max-width:560px;height:170px;background:#f8fafc;border:1.5px dashed var(--line);border-radius:12px;touch-action:none;cursor:crosshair}.sig-actions{display:flex;gap:10px}.sig-hint{color:var(--muted)}.sig-image{max-width:280px;border:1px solid var(--line);border-radius:10px;background:#fff;padding:6px}.tt-grid{overflow-x:auto}.tt-grid table{min-width:640px}.tt-cell{font-size:13px}.tt-cell b{display:block}.tt-cell small{color:var(--muted)}.tt-period{color:var(--muted);font-size:12px;white-space:nowrap}.gal-albums{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px}.gal-album{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;cursor:pointer;transition:box-shadow .15s,transform .15s}.gal-album:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.gal-cover{width:100%;height:140px;object-fit:cover;display:block;background:#eef2ff}.gal-meta{padding:12px 14px}.gal-meta b{font-size:14px;display:block}.gal-meta span{font-size:12px;color:var(--muted)}.gal-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.gal-photo{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line)}.gal-photo img{width:100%;height:130px;object-fit:cover;display:block}.gal-photo .cap{font-size:12px;padding:7px 10px;color:var(--slate);background:#fff}.gal-photo .del{position:absolute;top:6px;right:6px;background:#0f172a99;color:#fff;border:none;border-radius:8px;font-size:11px;padding:3px 8px}.event-list{display:grid;gap:14px}.event-row{display:flex;gap:16px;border:1px solid var(--line);border-radius:14px;padding:14px 16px;align-items:center}.event-date-chip{background:#eef2ff;color:var(--indigo);border-radius:12px;padding:8px 12px;text-align:center;min-width:72px;font-weight:800;font-size:13px}.event-row h4{margin:0 0 3px;font-size:15px}.event-row p{margin:0;font-size:13px;color:var(--slate)}.event-row .grow{flex:1}.event-cover-thumb{width:84px;height:56px;object-fit:cover;border-radius:9px}.mini-bars{display:flex;align-items:flex-end;gap:6px;height:120px;padding:8px 0}.mini-bar{flex:1;background:linear-gradient(180deg,var(--indigo),#7c3aed);border-radius:6px 6px 0 0;min-height:4px;position:relative}.mini-bar span{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:10px;color:var(--muted);white-space:nowrap}.mini-bar i{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:10.5px;font-style:normal;font-weight:700}.progress{height:8px;background:#f1f5f9;border-radius:99px;overflow:hidden}.progress i{display:block;height:100%;background:var(--indigo);border-radius:99px}.row-actions{display:flex;gap:6px;flex-wrap:wrap}.btn.tiny{padding:4px 10px;font-size:12px;border-radius:8px}.subtabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}.upload-zone{border:1.5px dashed var(--line);border-radius:12px;padding:18px;text-align:center;color:var(--slate);font-size:13.5px;background:#f8fafc;cursor:pointer}.upload-zone:hover{border-color:var(--indigo);color:var(--indigo)}.bday-row{display:flex;align-items:center;gap:14px;padding:11px 4px;border-bottom:1px solid #f1f5f9}.bday-cake{font-size:24px}.bday-today{background:#fdf2f8;border-radius:12px;padding:11px 14px}.rc-table td,.rc-table th{padding:8px 10px}.rc-sign-box{background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:18px}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}.video-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;cursor:pointer;transition:box-shadow .15s,transform .15s}.video-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.video-thumb{position:relative;height:140px;background:#0f172a;display:flex;align-items:center;justify-content:center}.video-thumb img{width:100%;height:100%;object-fit:cover}.video-thumb-fallback{font-size:44px}.video-play{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;background:#0f172a40}.video-play:before{content:"";position:absolute;width:52px;height:52px;border-radius:50%;background:#4f46e5e6;z-index:-0}.video-play{z-index:1}.video-meta{padding:12px 14px}.video-meta b{font-size:14px;display:block;margin-bottom:6px}.video-sub{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}.video-meta small{color:var(--muted);font-size:12px}
