@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--sidebar-bg:#fff;--sidebar-text:#64748b;--sidebar-heading:#0f172a;--sidebar-hover:#f1f5f9;--sidebar-active-bg:linear-gradient(135deg,#6366f1,#8b5cf6);--sidebar-active-text:#fff;--sidebar-width:260px;--topbar-height:64px;--topbar-mobile-height:60px;--sidebar-border:#e2e8f0;--bg:#f8fafc;--surface:#fff;--surface-hover:#f1f5f9;--text:#0f172a;--text-secondary:#475569;--muted:#64748b;--line:#e2e8f0;--line-light:#f1f5f9;--brand:#6366f1;--brand-hover:#4f46e5;--brand-soft:rgba(99,102,241,.1);--brand-glow:rgba(99,102,241,.25);--success:#10b981;--success-bg:rgba(16,185,129,.1);--success-text:#065f46;--danger:#ef4444;--danger-bg:rgba(239,68,68,.1);--danger-text:#991b1b;--warning:#f59e0b;--warning-bg:rgba(245,158,11,.1);--info:#3b82f6;--info-bg:rgba(59,130,246,.1);--shadow-sm:0 1px 2px rgba(0,0,0,.04);--shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.08),0 10px 10px -5px rgba(0,0,0,.03);--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--transition:.2s cubic-bezier(.4,0,.2,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{max-width:100vw;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}.owner-shell{height:100vh;overflow-x:hidden;overflow-y:hidden}.owner-grid{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100vh}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);color:var(--sidebar-text);display:flex;flex-direction:column;height:100vh;overflow-x:hidden;overflow-y:hidden;padding:0;position:sticky;top:0;transition:transform var(--transition);z-index:40}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#00000014;border-radius:4px}.sidebar-brand{border-bottom:1px solid var(--sidebar-border);gap:12px;padding:20px}.sidebar-brand,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:var(--radius);box-shadow:0 4px 12px #6366f14d;flex-shrink:0;height:40px;justify-content:center;width:40px}.sidebar-logo-icon{color:#fff;height:22px;width:22px}.sidebar-brand-text{min-width:0}.sidebar h2{color:var(--sidebar-heading);font-size:15px;font-weight:700;letter-spacing:-.2px;line-height:1.3}.sidebar-kicker{color:var(--sidebar-text);font-size:11px;font-weight:500;letter-spacing:0;text-transform:none}.nav-list{display:flex;flex:1;flex-direction:column;gap:2px;padding:12px 10px}.nav-link{align-items:center;border-radius:var(--radius);color:var(--sidebar-text);display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 14px;position:relative;transition:all var(--transition)}.nav-link:hover{background:var(--sidebar-hover);color:#1e293b}.nav-link .nav-icon{flex-shrink:0;height:20px;opacity:.7;width:20px}.nav-link:hover .nav-icon{opacity:1}.nav-link.router-link-active{background:var(--sidebar-active-bg);box-shadow:0 4px 12px #6366f14d;color:var(--sidebar-active-text);font-weight:600}.nav-link.router-link-active .nav-icon{opacity:1}.sidebar-user-card{align-items:center;background:#f8fafc;border:1px solid var(--line);border-radius:var(--radius-lg);display:flex;gap:10px;margin:auto 10px 10px;padding:12px;transition:background var(--transition)}.sidebar-user-card:hover{background:#f1f5f9}.sidebar-user-avatar{align-items:center;background:var(--sidebar-active-bg);border-radius:var(--radius);color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:38px;justify-content:center;width:38px}.sidebar-user-meta{flex:1;min-width:0}.sidebar-user-name{color:#1e293b;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-status{align-items:center;color:var(--success);display:flex;font-size:11px;gap:4px}.sidebar-user-status:before{background:var(--success);border-radius:50%;content:"";display:inline-block;height:6px;width:6px}.logout-icon-btn{align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);color:var(--sidebar-text);cursor:pointer;display:inline-flex;flex-shrink:0;height:34px;justify-content:center;padding:0;transition:all var(--transition);width:34px}.logout-icon-btn svg{height:16px;width:16px}.logout-icon-btn:hover{background:#ef444426;border-color:#ef44444d;color:#fca5a5}.content-area{background:var(--bg);display:flex;flex-direction:column;height:100vh;min-width:0;overflow-x:hidden;overflow-y:auto}.topbar{background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);height:var(--topbar-height);justify-content:space-between;left:var(--sidebar-width);padding:0 24px;position:fixed;right:0;top:0;z-index:30}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{gap:12px}.menu-toggle{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);cursor:pointer;display:none;height:40px;justify-content:center;padding:0;position:relative;transition:all .25s ease;width:40px}.menu-toggle:active{transform:scale(.92)}.menu-toggle .hamburger{display:flex;flex-direction:column;height:14px;justify-content:space-between;position:relative;width:20px}.menu-toggle .hamburger span{background:var(--text);border-radius:2px;display:block;height:2px;transform-origin:center;transition:all .35s cubic-bezier(.4,0,.2,1);width:100%}.menu-toggle.is-active .hamburger span:first-child{transform:translateY(6px) rotate(45deg)}.menu-toggle.is-active .hamburger span:nth-child(2){opacity:0;transform:scaleX(0)}.menu-toggle.is-active .hamburger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.sidebar-backdrop{display:none}.topbar-title{color:var(--text);font-size:16px;font-weight:700;letter-spacing:-.3px}.topbar-actions{align-items:center;display:flex;gap:8px}.topbar-logout{background:var(--surface);border-color:var(--line);color:var(--muted)}.topbar-logout:hover{background:var(--danger-bg);border-color:#ef444433;color:var(--danger)}.main-wrap{flex:1;max-width:1400px;overflow-x:hidden;padding:calc(24px + var(--topbar-height)) 24px 24px;width:100%}.owner-footer{align-items:center;border-top:1px solid var(--line);color:var(--muted);display:flex;font-size:12px;font-weight:500;justify-content:center;padding:12px 24px}.card,.owner-footer{background:var(--surface)}.card{border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:box-shadow var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.page-header{color:var(--text);font-size:24px;font-weight:800;letter-spacing:-.5px;margin:0 0 6px}.page-subtitle,.settlements-subtitle{color:var(--muted);font-size:14px;margin-bottom:20px}.settlements-subtitle{margin-top:-2px}.settlements-table{margin-top:20px}.grid-2{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card{overflow:hidden;padding:20px;position:relative}.summary-card:after{border-radius:50%;content:"";height:80px;opacity:.08;position:absolute;right:0;top:0;transform:translate(20px,-20px);width:80px}.summary-label{color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.summary-value{font-size:36px;font-weight:800;letter-spacing:-1px;line-height:1}.summary-present{border-left:4px solid var(--success)}.summary-present .summary-value{color:var(--success)}.summary-present:after{background:var(--success)}.summary-absent{border-left:4px solid var(--danger)}.summary-absent .summary-value{color:var(--danger)}.summary-absent:after{background:var(--danger)}.dashboard-grid{display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;gap:14px;overflow:hidden;padding:20px;position:relative;transition:all var(--transition)}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:var(--radius);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-icon svg{height:24px;width:24px}.stat-icon.brand{background:var(--brand-soft);color:var(--brand)}.stat-icon.success{background:var(--success-bg);color:var(--success)}.stat-icon.danger{background:var(--danger-bg);color:var(--danger)}.stat-icon.warning{background:var(--warning-bg);color:var(--warning)}.stat-icon.info{background:var(--info-bg);color:var(--info)}.stat-content{flex:1;min-width:0}.stat-label{color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.stat-number{color:var(--text);font-size:28px;font-weight:800;letter-spacing:-.5px;line-height:1.1}.stat-trend{align-items:center;display:flex;font-size:12px;font-weight:600;gap:4px;margin-top:4px}.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}.quick-actions-title{color:var(--text);font-size:16px;font-weight:700;margin-bottom:14px}.quick-links{display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.quick-link-card{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;gap:10px;padding:20px 16px;text-align:center;transition:all var(--transition)}.quick-link-card:hover{border-color:var(--brand);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.quick-link-icon{align-items:center;border-radius:var(--radius);display:flex;height:44px;justify-content:center;width:44px}.quick-link-icon svg{height:22px;width:22px}.quick-link-title{color:var(--text);font-size:13px;font-weight:700}.quick-link-desc{color:var(--muted);font-size:11px;line-height:1.4}.welcome-banner{background:linear-gradient(135deg,#6366f1,#8b5cf6 50%,#a78bfa);border-radius:var(--radius-xl);color:#fff;margin-bottom:24px;max-width:100%;overflow:hidden;padding:32px;position:relative}.welcome-banner:before{background:radial-gradient(circle,hsla(0,0%,100%,.12) 0,transparent 60%);height:400px;right:-20%;top:-50%;width:400px}.welcome-banner:after,.welcome-banner:before{border-radius:50%;content:"";position:absolute}.welcome-banner:after{background:radial-gradient(circle,hsla(0,0%,100%,.08) 0,transparent 60%);bottom:-60%;height:300px;left:10%;width:300px}.welcome-banner h2{font-size:24px;font-weight:800;margin-bottom:6px;position:relative;z-index:1}.welcome-banner p{font-size:14px;max-width:500px;opacity:.85;position:relative;z-index:1}.welcome-date{font-size:13px;font-weight:500;margin-top:14px;opacity:.75;position:relative;z-index:1}.form-grid,.monthly-filter-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full{grid-column:1/-1}.form-group label{color:var(--text-secondary);font-size:13px;font-weight:600}button,input,select{font:inherit}input,select{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);font-size:14px;padding:10px 14px;transition:all var(--transition)}input:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow);outline:none}input:disabled{background:var(--line-light);color:var(--muted);cursor:not-allowed}button{border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all var(--transition)}.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-hover));box-shadow:0 4px 14px #6366f14d;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #6366f166;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:var(--surface);border:1px solid var(--line);color:var(--text)}.btn-secondary:hover{background:var(--surface-hover);border-color:#cbd5e1}.table-wrap{border-radius:var(--radius);margin-top:16px;overflow:auto}table{background:var(--surface);border-collapse:collapse;width:100%}td,th{font-size:14px;padding:12px 16px;text-align:left;white-space:nowrap}th{background:var(--line-light);border-bottom:2px solid var(--line);color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}td{border-bottom:1px solid var(--line-light)}tr:hover td{background:#6366f105}tr:last-child td{border-bottom:none}.status-pill{align-items:center;border-radius:50px;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:4px 12px}.status-present{background:var(--success-bg);color:var(--success-text)}.status-not-started{background:var(--warning-bg);color:var(--warning)}.status-absent{background:var(--danger-bg);color:var(--danger-text)}.filters{display:grid;gap:12px;grid-template-columns:2fr 1fr;margin-top:16px}.filters-date-row{grid-template-columns:minmax(0,320px);margin-top:0}.status-tabs{background:#f8fafc;border:1px solid #e2e8f0;border-radius:var(--radius);display:flex;gap:4px;margin:16px 0;max-width:100%;overflow:hidden;padding:6px}.status-filter-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:6px 12px;margin-bottom:8px;margin-top:16px}.status-filter-label{color:var(--text);font-size:13px;font-weight:700}.status-filter-hint{color:var(--muted);font-size:12px}.status-tab{align-items:center;background:#fff;border:1px solid transparent;border-radius:var(--radius-sm);color:#64748b;cursor:pointer;display:flex;flex:1;font-size:13px;font-weight:700;gap:6px;justify-content:center;min-width:0;padding:10px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.status-tab:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 2px 8px #94a3b829;color:#334155}.status-tab:focus-visible{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b838;outline:none}.status-tab.active{background:#eef2ff;border-color:#c7d2fe;box-shadow:0 4px 12px #6366f12e;color:#3730a3;font-weight:700}.status-tab-present.active{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.status-tab-absent.active{background:#fff1f2;border-color:#fecdd3;color:#be123c}.status-tab-count{background:#0000000f;border-radius:50px;color:var(--muted);font-size:11px;font-weight:700;min-width:24px;padding:2px 8px;text-align:center;transition:all .25s ease}.status-tab.active .status-tab-count{background:#fff;color:#3730a3}.status-tab-present.active .status-tab-count.present{background:#fff;color:#047857}.status-tab-absent.active .status-tab-count.absent{background:#fff;color:#be123c}.attendance-card{overflow:hidden}.attendance-mobile-list{display:none}.attendance-mobile-item{background:#6366f10a;border:1px solid rgba(99,102,241,.12);border-radius:var(--radius);margin-top:8px;padding:12px;position:relative}.attendance-mobile-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.attendance-mobile-name{color:var(--text);font-size:14px;font-weight:700}.attendance-mobile-id{color:var(--muted);font-size:11px;font-weight:500}.attendance-mobile-details{background:var(--line-light);border-radius:var(--radius-sm);display:grid;gap:2px;grid-template-columns:repeat(3,1fr);overflow:hidden}.attendance-mobile-detail{background:#ffffffb3;padding:6px 8px;text-align:center}.attendance-mobile-detail-label{color:var(--muted);font-size:10px;font-weight:600;letter-spacing:.3px;margin-bottom:2px;text-transform:uppercase}.attendance-mobile-detail-value{color:var(--text);font-size:13px;font-weight:700}.attendance-mobile-row{border-bottom:1px dashed var(--line-light);display:flex;gap:10px;justify-content:space-between;padding:6px 0}.attendance-mobile-row:last-child{border-bottom:none}.attendance-mobile-label{color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.attendance-mobile-value{font-size:13px;font-weight:600;text-align:right}.attendance-mobile-empty{padding:12px 0}.pagination{align-items:center;display:flex;justify-content:space-between;margin-top:16px}.pagination-controls{display:flex;gap:8px}.error-box{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);color:var(--danger-text)}.error-box,.success-box{font-size:14px;font-weight:500;margin-bottom:16px;padding:12px 16px}.success-box{background:var(--success-bg);border:1px solid rgba(16,185,129,.2);border-radius:var(--radius);color:var(--success-text)}.loading{align-items:center;color:var(--muted);display:flex;font-weight:600;gap:10px;padding:24px}.loading:before{animation:spin .6s linear infinite;border:2px solid var(--line);border-radius:50%;border-top-color:var(--brand);content:"";height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.muted{color:var(--muted)}.login-page{background:var(--sidebar-bg);display:grid;max-width:100vw;min-height:100vh;overflow:hidden;padding:20px;place-items:center;position:relative}.login-page:before{background:radial-gradient(circle,rgba(99,102,241,.2) 0,transparent 60%);height:600px;left:-200px;top:-200px;width:600px}.login-page:after,.login-page:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.login-page:after{background:radial-gradient(circle,rgba(139,92,246,.15) 0,transparent 60%);bottom:-150px;height:500px;right:-150px;width:500px}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-xl);box-shadow:0 25px 50px #0000004d;max-width:420px;padding:36px;position:relative;width:100%;z-index:1}.login-card .page-header{color:#f1f5f9;margin-bottom:4px}.login-card .muted{color:#94a3b8}.login-card label{color:#cbd5e1;font-size:13px;font-weight:600}.login-card input{background:#ffffff0f;border:1px solid hsla(0,0%,100%,.1);color:#f1f5f9}.login-card input::-moz-placeholder{color:#64748b}.login-card input::placeholder{color:#64748b}.login-card input:focus{background:#ffffff14;border-color:var(--brand);box-shadow:0 0 0 3px #6366f133}.login-card .btn-primary{font-size:15px;font-weight:700;padding:12px;width:100%}.login-card .error-box{background:#ef44441a;border-color:#ef444433;color:#fca5a5}.login-brand{margin-bottom:28px;text-align:center}.login-brand-icon{align-items:center;background:var(--sidebar-active-bg);border-radius:16px;box-shadow:0 8px 24px #6366f14d;display:inline-flex;height:56px;justify-content:center;margin-bottom:12px;width:56px}.login-brand-icon svg{color:#fff;height:28px;width:28px}@media(max-width:1100px){.dashboard-grid,.quick-links{grid-template-columns:repeat(2,1fr)}.quick-link-desc{display:none}}@media(max-width:900px){.owner-grid{grid-template-columns:1fr}.sidebar-backdrop{animation:fadeIn .3s ease forwards;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000080;display:block;inset:0;position:fixed;z-index:45}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar{box-shadow:8px 0 30px #0000001f;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transform:translate(-100%);transition:transform .35s cubic-bezier(.16,1,.3,1);width:min(82vw,300px);z-index:50}.sidebar.sidebar-open{transform:translate(0)}.main-wrap{padding:calc(16px + var(--topbar-mobile-height)) 16px 16px}.topbar{height:var(--topbar-mobile-height);left:0;padding:0 16px}.menu-toggle{align-items:center;display:flex;justify-content:center}.filters,.form-grid,.grid-2,.monthly-filter-grid{grid-template-columns:1fr}.summary-grid-two{gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card{padding:16px}.summary-value{font-size:28px}.table-wrap{display:none}.attendance-mobile-list{display:block;margin-top:6px}.pagination{align-items:stretch;flex-direction:column;gap:10px}.pagination .muted{text-align:center}.pagination-controls{width:100%}.pagination-controls .btn-secondary{flex:1}.filters-date-row{grid-template-columns:1fr}.dashboard-grid{gap:10px;grid-template-columns:repeat(2,1fr)}.stat-card{gap:10px;padding:12px}.stat-icon{height:36px;width:36px}.stat-icon svg{height:18px;width:18px}.stat-label{font-size:10px;margin-bottom:2px}.stat-number{font-size:20px}.quick-links{gap:10px;grid-template-columns:repeat(2,1fr)}.quick-link-card{gap:8px;padding:14px 10px}.quick-link-icon{height:38px;width:38px}.quick-link-icon svg{height:18px;width:18px}.quick-link-title{font-size:12px}.quick-link-desc{display:none}.quick-actions-title{font-size:14px;margin-bottom:10px}.welcome-banner{margin-bottom:16px;padding:18px 16px}.welcome-banner h2{font-size:17px;margin-bottom:4px}.welcome-banner p{font-size:12px}.welcome-date{font-size:11px;margin-top:8px}.owner-footer{padding:10px 16px}.login-card{max-width:100%;padding:24px 20px}button,input,select{min-height:44px}}@media(max-width:480px){.status-tabs{flex-wrap:wrap;gap:6px;padding:8px}.status-tab{flex:0 0 calc(50% - 3px);font-size:12px;min-height:40px;padding:8px 6px;white-space:normal;word-break:break-word}.status-tab-count{font-size:10px;min-width:20px;padding:2px 6px}.dashboard-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.stat-card{align-items:center;flex-direction:column;gap:6px;padding:10px;text-align:center}.stat-icon{height:32px;width:32px}.stat-icon svg{height:16px;width:16px}.stat-number{font-size:18px}.summary-card{padding:14px}.summary-value{font-size:24px}.page-header{font-size:20px}}@media(max-width:360px){.status-tabs{gap:4px;padding:6px}.status-tab{flex:0 0 calc(50% - 2px);font-size:11px;min-height:36px;padding:6px 4px}.status-tab-count{font-size:9px;min-width:18px;padding:1px 4px}}.pwa-install-banner{background:var(--surface);border-top:1px solid var(--line);bottom:0;box-shadow:0 -4px 20px #0000001a;left:0;padding:12px 16px;position:fixed;right:0;z-index:100}.pwa-install-content{align-items:center;display:flex;gap:12px;margin:0 auto;max-width:600px}.pwa-install-icon{align-items:center;background:var(--brand-soft);border-radius:var(--radius);color:var(--brand);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.pwa-install-icon svg{height:20px;width:20px}.pwa-install-text{flex:1;min-width:0}.pwa-install-text strong{color:var(--text);display:block;font-size:14px;font-weight:700}.pwa-install-text span{color:var(--muted);font-size:12px}.pwa-install-btn{background:linear-gradient(135deg,var(--brand),var(--brand-hover));border:none;border-radius:var(--radius);box-shadow:0 4px 12px #6366f14d;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:700;padding:8px 20px}.pwa-dismiss-btn{background:none;border:none;color:var(--muted);cursor:pointer;flex-shrink:0;font-size:22px;line-height:1;padding:4px 8px}.pwa-dismiss-btn:hover{color:var(--text)}.pwa-slide-enter-active{transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s ease}.pwa-slide-leave-active{transition:transform .3s ease,opacity .3s ease}.pwa-slide-enter-from,.pwa-slide-leave-to{opacity:0;transform:translateY(100%)}
