.lp{--lp-primary: #5b21b6;--lp-primary-h: #4c1d95;--lp-accent: #f59e0b;--lp-accent-h: #d97706;--lp-text: #1a1535;--lp-muted: #6b7280;--lp-border: #e5e1f0;--lp-surface: #ffffff;--lp-bg: #f7f5ff;--lp-radius: 14px;--lp-shadow: 0 2px 16px rgba(91, 33, 182, .08);--lp-shadow-md: 0 8px 32px rgba(91, 33, 182, .12);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;color:var(--lp-text);background:#fff;line-height:1.6;overflow-x:hidden}.lp-container{max-width:1100px;margin:0 auto;padding:0 24px}.lp-logo{font-size:20px;font-weight:800;color:var(--lp-primary);letter-spacing:-.3px;font-style:normal}.lp-logo em{font-style:normal;color:var(--lp-accent)}.lp-nav{position:sticky;top:0;z-index:200;display:flex;align-items:center;gap:24px;padding:0 40px;height:62px;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--lp-border)}.lp-nav-links{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}.lp-nav-links button{background:none;border:none;padding:7px 14px;border-radius:8px;font-size:14px;font-weight:500;color:var(--lp-muted);cursor:pointer;transition:color .15s,background .15s}.lp-nav-links button:hover{color:var(--lp-primary);background:var(--lp-bg)}.lp-nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.lp-btn-outline{padding:8px 18px;border:1.5px solid var(--lp-border);background:transparent;color:var(--lp-text);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.lp-btn-outline:hover{border-color:var(--lp-primary);color:var(--lp-primary)}.lp-btn-nav-login{padding:8px 20px;background:var(--lp-primary);color:#fff;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;white-space:nowrap;display:inline-block;transition:background .15s}.lp-btn-nav-login:hover{background:var(--lp-primary-h);text-decoration:none}.lp-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}.lp-hamburger span{display:block;width:22px;height:2px;background:var(--lp-primary);border-radius:2px}.lp-nav-mobile-ctas{display:none}@media (max-width: 820px){.lp-nav{padding:0 20px}.lp-nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;padding:12px 20px 20px;border-bottom:1px solid var(--lp-border);gap:2px;box-shadow:0 8px 24px #00000014;z-index:199}.lp-nav-links.lp-nav-open{display:flex}.lp-nav-links button{padding:11px 8px;font-size:15px;width:100%;text-align:left}.lp-nav-mobile-ctas{display:flex;flex-direction:column;gap:8px;width:100%;padding-top:12px;border-top:1px solid var(--lp-border);margin-top:8px}.lp-nav-mobile-ctas .lp-btn-outline,.lp-nav-mobile-ctas .lp-btn-nav-login{width:100%;text-align:center}.lp-nav-right{display:none}.lp-hamburger{display:flex}}.lp-hero{background:var(--lp-bg);padding:80px 40px 60px;display:flex;align-items:center;justify-content:center;gap:64px;min-height:calc(100vh - 62px)}.lp-hero-content{max-width:520px;display:flex;flex-direction:column;gap:22px}.lp-hero-eyebrow{font-size:13px;font-weight:700;color:var(--lp-primary);letter-spacing:.08em;text-transform:uppercase}.lp-hero-content h1{font-size:clamp(36px,5vw,54px);font-weight:900;line-height:1.1;letter-spacing:-1.5px;color:var(--lp-text);margin:0}.lp-hero-accent-line{display:block;color:var(--lp-primary);position:relative}.lp-hero-accent-line:after{content:"";display:block;width:72px;height:4px;background:var(--lp-accent);border-radius:2px;margin-top:10px}.lp-hero-sub{font-size:17px;color:var(--lp-muted);line-height:1.75;margin:0}.lp-hero-actions{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-top:4px}.lp-btn-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 26px;background:var(--lp-primary);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s,transform .15s,box-shadow .15s;text-decoration:none;white-space:nowrap}.lp-btn-cta:hover{background:var(--lp-primary-h);transform:translateY(-1px);box-shadow:0 6px 20px #5b21b640}.lp-btn-cta-sm{padding:11px 22px;font-size:14px}.lp-btn-cta-accent{background:var(--lp-accent);color:#fff}.lp-btn-cta-accent:hover{background:var(--lp-accent-h);box-shadow:0 6px 20px #f59e0b4d}.lp-store-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.lp-store-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--lp-text);border-radius:10px;color:#fff;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;cursor:pointer}.lp-store-badge:hover{opacity:.85;text-decoration:none}.lp-hero-phone{flex-shrink:0}.lp-phone{width:230px;border-radius:38px;background:var(--lp-text);border:7px solid #2a2045;box-shadow:0 0 0 1px #ffffff14,0 32px 72px #1a153538,0 8px 24px #1a15351f;padding:8px 6px 16px;display:flex;flex-direction:column;position:relative}.lp-phone-notch{width:64px;height:18px;background:var(--lp-text);border-radius:0 0 12px 12px;margin:0 auto 6px;flex-shrink:0}.lp-phone-screen{background:#fff;border-radius:28px;overflow:hidden;display:flex;flex-direction:column;min-height:380px}.lp-pscreen-top{background:var(--lp-primary);padding:14px;display:flex;align-items:center;justify-content:center}.lp-pscreen-logo{font-size:13px;font-weight:800;color:#fff;letter-spacing:-.2px}.lp-pscreen-selfie{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px 14px;background:var(--lp-bg)}.lp-selfie-ring{width:56px;height:56px;border-radius:50%;border:2px dashed #c4b5fd;display:flex;align-items:center;justify-content:center;font-size:24px;background:#fff}.lp-pscreen-selfie p{font-size:11px;font-weight:600;color:var(--lp-primary);margin:0}.lp-pscreen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:3px;background:#f3f4f6;flex:1}.lp-pthumb{aspect-ratio:1;border-radius:4px}.lp-pthumb-0{background:linear-gradient(135deg,#ddd6fe,#a78bfa)}.lp-pthumb-1{background:linear-gradient(135deg,#fde68a,#fbbf24)}.lp-pthumb-2{background:linear-gradient(135deg,#fce7f3,#f9a8d4)}.lp-pthumb-3{background:linear-gradient(135deg,#bbf7d0,#6ee7b7)}.lp-pthumb-4{background:linear-gradient(135deg,#bfdbfe,#93c5fd)}.lp-pthumb-5{background:linear-gradient(135deg,#fed7aa,#fb923c)}.lp-pscreen-badge{padding:10px;text-align:center;background:#fff}.lp-pscreen-badge span{font-size:11px;font-weight:700;color:#059669;background:#d1fae5;padding:4px 12px;border-radius:100px}.lp-phone-home{width:56px;height:4px;background:#ffffff26;border-radius:2px;margin:8px auto 0}.lp-phone-wrap{position:relative}.lp-float-card{position:absolute;left:-80px;bottom:80px;background:#fff;border-radius:12px;padding:12px 16px;box-shadow:0 8px 32px #5b21b626;display:flex;align-items:center;gap:10px;white-space:nowrap;border:1px solid var(--lp-border)}.lp-float-icon{font-size:22px}.lp-float-card strong{font-size:13px;font-weight:700;color:var(--lp-text);display:block}.lp-float-card span{font-size:11px;color:var(--lp-muted)}@media (max-width: 880px){.lp-hero{flex-direction:column;min-height:auto;padding:60px 24px 48px;gap:40px}.lp-hero-content{max-width:100%}.lp-float-card{display:none}}@media (max-width: 480px){.lp-hero-phone{display:none}}.lp-stats-bar{display:flex;justify-content:center;flex-wrap:wrap;background:var(--lp-text);padding:0 24px}.lp-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:28px 48px;border-right:1px solid rgba(255,255,255,.08);flex:1;min-width:150px}.lp-stat:last-child{border-right:none}.lp-stat strong{font-size:26px;font-weight:900;color:#fff;line-height:1;letter-spacing:-.5px}.lp-stat span{font-size:13px;color:#ffffff80;font-weight:400}@media (max-width: 600px){.lp-stats-bar{flex-direction:column}.lp-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08);padding:18px 24px;flex-direction:row;justify-content:center;gap:16px}.lp-stat:last-child{border-bottom:none}}.lp-section{padding:88px 0}.lp-section-alt{background:var(--lp-bg)}.lp-section-head{text-align:center;max-width:560px;margin:0 auto 56px;display:flex;flex-direction:column;gap:12px}.lp-section-head h2{font-size:clamp(26px,3.5vw,38px);font-weight:800;letter-spacing:-.6px;line-height:1.15;color:var(--lp-text);margin:0}.lp-section-head p{font-size:16px;color:var(--lp-muted);margin:0;line-height:1.7}.lp-tag{display:inline-block;padding:4px 14px;background:#5b21b614;color:var(--lp-primary);border-radius:100px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.lp-tag-accent{background:#f59e0b1a;color:var(--lp-accent-h)}.lp-steps{display:flex;align-items:flex-start;justify-content:center;gap:0}.lp-step{flex:1;max-width:300px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:0 28px;position:relative}.lp-step:not(:last-child):after{content:"";position:absolute;top:22px;right:-1px;width:calc(100% - 72px);height:1px;background:var(--lp-border);left:calc(50% + 22px)}.lp-step-num{width:44px;height:44px;border-radius:50%;background:var(--lp-primary);color:#fff;font-size:17px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}.lp-step-emoji{font-size:36px;line-height:1}.lp-step h3{font-size:16px;font-weight:700;color:var(--lp-text);margin:0}.lp-step p{font-size:14px;color:var(--lp-muted);margin:0;line-height:1.7}.lp-steps-cta{text-align:center;margin-top:52px}@media (max-width: 720px){.lp-steps{flex-direction:column;align-items:center;gap:36px}.lp-step:after{display:none}.lp-step{max-width:100%;padding:0 8px}}.lp-benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.lp-benefit-card{background:#fff;border:1px solid var(--lp-border);border-radius:var(--lp-radius);padding:24px 22px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .15s,transform .15s}.lp-benefit-card:hover{box-shadow:var(--lp-shadow-md);transform:translateY(-2px)}.lp-benefit-icon{font-size:28px;line-height:1}.lp-benefit-card h3{font-size:15px;font-weight:700;color:var(--lp-text);margin:0}.lp-benefit-card p{font-size:14px;color:var(--lp-muted);margin:0;line-height:1.65}@media (max-width: 860px){.lp-benefits-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 520px){.lp-benefits-grid{grid-template-columns:1fr}}.lp-split{display:flex;align-items:center;gap:64px}.lp-split-text{flex:1;display:flex;flex-direction:column;gap:18px}.lp-split-text h2{font-size:clamp(24px,3vw,36px);font-weight:800;letter-spacing:-.5px;line-height:1.2;margin:0;color:var(--lp-text)}.lp-split-text p{font-size:15px;color:var(--lp-muted);margin:0;line-height:1.75}.lp-feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.lp-feature-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--lp-text);line-height:1.5}.lp-check{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--lp-primary);color:#fff;font-size:10px;font-weight:700;flex-shrink:0;margin-top:1px}.lp-feature-tiles{flex-shrink:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:300px}.lp-feature-tile{background:#fff;border:1px solid var(--lp-border);border-radius:var(--lp-radius);padding:22px 18px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;box-shadow:var(--lp-shadow);transition:box-shadow .15s,transform .15s}.lp-feature-tile:hover{box-shadow:var(--lp-shadow-md);transform:translateY(-2px)}.lp-tile-icon{font-size:28px}.lp-feature-tile strong{font-size:13px;font-weight:700;color:var(--lp-text)}.lp-feature-tile span{font-size:12px;color:var(--lp-muted)}@media (max-width: 820px){.lp-split{flex-direction:column;gap:36px}.lp-feature-tiles{width:100%}}.lp-testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-testimonial{background:#fff;border:1px solid var(--lp-border);border-radius:var(--lp-radius);padding:24px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--lp-shadow);transition:box-shadow .15s,transform .15s}.lp-testimonial:hover{box-shadow:var(--lp-shadow-md);transform:translateY(-2px)}.lp-stars{color:var(--lp-accent);font-size:14px;letter-spacing:2px}.lp-quote{font-size:14px;color:var(--lp-text);line-height:1.75;margin:0;flex:1}.lp-author{display:flex;align-items:center;gap:12px}.lp-author-avatar{width:36px;height:36px;border-radius:50%;background:var(--lp-primary);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lp-author-info{display:flex;flex-direction:column;gap:2px}.lp-author-info strong{font-size:13px;font-weight:700;color:var(--lp-text)}.lp-author-info span{font-size:12px;color:var(--lp-muted)}@media (max-width: 860px){.lp-testimonials{grid-template-columns:1fr}}@media (min-width: 560px) and (max-width: 860px){.lp-testimonials{grid-template-columns:repeat(2,1fr)}}.lp-faqs{max-width:680px;margin:0 auto}.lp-faq-item{border-bottom:1px solid var(--lp-border)}.lp-faq-item:first-child{border-top:1px solid var(--lp-border)}.lp-faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;padding:18px 0;background:none;border:none;font-size:15px;font-weight:600;color:var(--lp-text);text-align:left;cursor:pointer;transition:color .15s}.lp-faq-q:hover,.lp-faq-open .lp-faq-q{color:var(--lp-primary)}.lp-faq-chevron{font-size:20px;font-weight:300;color:var(--lp-primary);flex-shrink:0}.lp-faq-a{font-size:14px;color:var(--lp-muted);line-height:1.75;padding:0 0 18px;margin:0}.lp-cta-banner{background:var(--lp-bg);border-top:1px solid var(--lp-border);border-bottom:1px solid var(--lp-border);padding:88px 32px;text-align:center}.lp-cta-inner{display:flex;flex-direction:column;align-items:center;gap:16px}.lp-cta-inner h2{font-size:clamp(26px,3.5vw,40px);font-weight:800;color:var(--lp-text);letter-spacing:-.6px;margin:0}.lp-cta-inner p{font-size:16px;color:var(--lp-muted);max-width:480px;margin:0;line-height:1.7}.lp-footer{background:var(--lp-text);color:#ffffff80;font-size:14px;padding:40px 24px 24px}.lp-footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08)}.lp-footer-brand{display:flex;flex-direction:column;gap:6px}.lp-footer-brand .lp-logo{color:#fff}.lp-footer-brand .lp-logo em{color:var(--lp-accent)}.lp-footer-brand p{font-size:13px;color:#fff6}.lp-footer-links{display:flex;align-items:center;flex-wrap:wrap;gap:4px}.lp-footer-links button,.lp-footer-links a{background:none;border:none;color:#ffffff80;font-size:14px;cursor:pointer;padding:6px 12px;border-radius:6px;transition:color .15s;text-decoration:none}.lp-footer-links button:hover,.lp-footer-links a:hover{color:#fff;text-decoration:none}.lp-footer-copy{max-width:1100px;margin:16px auto 0;font-size:12px;color:#ffffff40}.lp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a15358c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500;padding:24px;animation:lp-fade .18s ease}@keyframes lp-fade{0%{opacity:0}to{opacity:1}}.lp-modal{background:#fff;border-radius:18px;width:100%;max-width:440px;box-shadow:0 20px 60px #0003;position:relative;animation:lp-up .22s ease;overflow:hidden}@keyframes lp-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.lp-modal-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:#f3f4f6;border:none;color:#6b7280;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:1}.lp-modal-close:hover{background:#e5e7eb;color:#111}.lp-modal-head{padding:28px 28px 0;display:flex;flex-direction:column;gap:6px}.lp-modal-icon{font-size:32px;line-height:1}.lp-modal-head h2{font-size:20px;font-weight:800;color:var(--lp-text);margin:0;letter-spacing:-.3px}.lp-modal-head p{font-size:14px;color:var(--lp-muted);margin:0;line-height:1.6}.lp-modal-form{padding:20px 28px 28px;display:flex;flex-direction:column;gap:14px}.lp-form-row{display:flex;flex-direction:column;gap:5px}.lp-form-row label{font-size:13px;font-weight:600;color:var(--lp-text)}.lp-field-note{font-size:12px;font-weight:400;color:var(--lp-muted)}.lp-form-row input{padding:10px 13px;border:1.5px solid var(--lp-border);border-radius:9px;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit;color:var(--lp-text)}.lp-form-row input:focus{border-color:var(--lp-primary);box-shadow:0 0 0 3px #5b21b61a}.lp-form-row input::placeholder{color:#c4c4d4}.lp-form-error{font-size:13px;color:#dc2626;padding:8px 12px;background:#fef2f2;border-radius:8px;border:1px solid #fecaca;margin:0}.lp-btn-submit{width:100%;justify-content:center;margin-top:2px}.lp-btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.lp-form-note{font-size:12px;color:var(--lp-muted);text-align:center;margin:0}.lp-modal-success{padding:44px 28px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.lp-success-emoji{font-size:48px;line-height:1}.lp-modal-success h2{font-size:20px;font-weight:800;color:var(--lp-text);margin:0}.lp-modal-success p{font-size:14px;color:var(--lp-muted);line-height:1.65;max-width:300px;margin:0}@media (max-width: 600px){.lp-section{padding:60px 0}.lp-section-head{margin-bottom:36px}.lp-cta-banner{padding:60px 24px}.lp-modal-head{padding:24px 22px 0}.lp-modal-form{padding:18px 22px 24px}.lp-modal-success{padding:36px 22px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#1a1a1a;background:#f7f7f8;line-height:1.5}a{color:#4f46e5;text-decoration:none}a:hover{text-decoration:underline}.muted{color:#888}.required{color:#dc2626}.char-hint{color:#888;font-size:12px}.text-error{color:#dc2626}.loading-screen{display:flex;align-items:center;justify-content:center;gap:10px;height:100vh;font-size:16px;color:#555}.loading-inline{display:flex;align-items:center;gap:8px;padding:24px 0;color:#555}.empty-state{padding:48px 0;text-align:center;color:#888;display:flex;flex-direction:column;gap:12px;align-items:center}.spinner{display:inline-block;width:16px;height:16px;border:2px solid #ddd;border-top-color:#4f46e5;border-radius:50%;animation:spin .6s linear infinite}.spinner-sm{width:12px;height:12px}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:background .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-secondary{background:#e5e7eb;color:#1a1a1a}.btn-secondary:hover:not(:disabled){background:#d1d5db}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:#4f46e5}.btn-ghost:hover:not(:disabled){background:#eef2ff}.btn-sm{padding:5px 10px;font-size:13px}.btn-lg{padding:12px 24px;font-size:16px}.btn-icon{background:none;border:none;cursor:pointer;font-size:16px;color:#888;padding:4px 8px;border-radius:4px}.btn-icon:hover{background:#f3f4f6}.btn-google{width:100%;justify-content:center;background:#fff;border:1px solid #d1d5db;color:#1a1a1a;padding:11px 16px;font-size:15px;border-radius:8px}.btn-google:hover:not(:disabled){background:#f9fafb}.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:60px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000f;position:sticky;top:0;z-index:100}.navbar-logo{display:flex;align-items:center;gap:8px;font-size:19px;font-weight:800;color:#4f46e5;text-decoration:none;letter-spacing:-.01em}.navbar-logo:hover{text-decoration:none}.navbar-logo-icon{font-size:20px}.navbar-right{display:flex;align-items:center;gap:12px}.navbar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.navbar-user-info{display:flex;flex-direction:column;line-height:1.3}.navbar-user-name{font-size:13px;font-weight:600;color:#1a1a1a}.navbar-user-company{font-size:11px;color:#888}.navbar-signout{font-size:12px;color:#6b7280}.navbar-user{color:#555;font-size:13px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f7f7f8}.auth-card{background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:40px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:16px}.auth-card .logo{font-size:22px;font-weight:700;color:#4f46e5}.auth-card h1{font-size:22px;font-weight:700}.auth-sub{color:#555;line-height:1.6}.auth-note{font-size:12px;color:#888}.no-access-icon{font-size:40px}.error-msg{color:#dc2626;font-size:13px}.login-split-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}@media (max-width: 768px){.login-split-page{grid-template-columns:1fr}.login-left{display:none}}.login-left{background:linear-gradient(145deg,#4f46e5,#7c3aed);display:flex;flex-direction:column;padding:40px;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.login-logo{font-size:22px;font-weight:800;color:#fff;text-decoration:none;position:relative;z-index:1;display:flex;align-items:center;gap:8px}.login-left-content{flex:1;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;max-width:400px}.login-left-content h2{font-size:28px;font-weight:800;color:#fff;margin-bottom:8px}.login-left-sub{color:#fffc;font-size:15px;margin-bottom:28px;line-height:1.6}.login-lead-form{display:flex;flex-direction:column;gap:14px}.login-lead-form .form-row label{color:#ffffffe6;font-size:13px;font-weight:500}.login-lead-form input{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:8px;padding:10px 14px;font-size:14px;outline:none}.login-lead-form input::placeholder{color:#ffffff73}.login-lead-form input:focus{border-color:#fff9;background:#ffffff2e}.login-lead-form .btn-primary{background:#fff;color:#4f46e5;font-weight:700;border-radius:8px;padding:11px 20px;font-size:15px}.login-lead-form .btn-primary:hover:not(:disabled){background:#f0f0ff}.login-lead-form .error-msg{color:#fca5a5}.login-form-success{display:flex;align-items:center;gap:14px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:10px;padding:20px;color:#fff;font-size:16px}.login-success-icon{width:36px;height:36px;border-radius:50%;background:#22c55e;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.login-right{background:#f7f7f8;display:flex;align-items:center;justify-content:center;padding:40px 24px}.login-right-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;padding:44px 40px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:18px;box-shadow:0 4px 24px #0000000f}.login-right-icon{font-size:36px}.login-right-card h2{font-size:22px;font-weight:800;color:#1a1a1a}.login-right-sub{color:#555;font-size:14px;line-height:1.6}.login-right-note{font-size:12px;color:#9ca3af;text-align:center;line-height:1.6}.landing{display:flex;flex-direction:column;min-height:100vh}.landing-header{display:flex;align-items:center;justify-content:space-between;padding:16px 48px;background:#fff;border-bottom:1px solid #e5e7eb}.landing-header .logo{font-size:20px;font-weight:700;color:#2563eb}.landing-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px;gap:16px}.landing-hero h1{font-size:42px;font-weight:800;line-height:1.2;max-width:600px}.landing-hero p{font-size:18px;color:#555;max-width:480px}.landing-placeholder{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;padding:48px;background:#fff;border-top:1px solid #e5e7eb}.placeholder-card{padding:24px;border:1px solid #e5e7eb;border-radius:10px}.placeholder-card h2{font-size:16px;margin-bottom:8px}.placeholder-card p{color:#666;font-size:14px}.landing-footer{padding:24px;text-align:center;color:#888;font-size:13px;border-top:1px solid #e5e7eb}.page-container{max-width:1280px;margin:0 auto;padding:32px 28px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:16px}.page-header h1{font-size:26px;font-weight:800;color:#1a1a1a}.page-sub{color:#666;margin-top:4px}.breadcrumb{font-size:13px;color:#9ca3af;margin-bottom:20px;display:flex;align-items:center;gap:6px}.breadcrumb a{color:#4f46e5;font-weight:500}.breadcrumb a:hover{text-decoration:underline}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;gap:16px}.dashboard-title{font-size:27px;font-weight:800;color:#1a1a1a}.dashboard-sub{color:#6b7280;margin-top:4px;font-size:14px}.event-header-bar{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:28px;flex-wrap:wrap}.event-header-title{font-size:24px;font-weight:800;margin:4px 0 2px}.event-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px;flex-shrink:0}@media (max-width: 640px){.event-header-bar{flex-direction:column}.event-header-right{align-items:flex-start;width:100%}}.join-code-card{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:14px;padding:16px 20px;min-width:260px;max-width:320px;box-shadow:0 4px 20px #4f46e559}.join-code-label{font-size:11px;font-weight:700;letter-spacing:.06em;color:#fffc;text-transform:uppercase;margin-bottom:8px}.join-code-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.join-code-value{font-size:30px;font-weight:900;letter-spacing:.18em;color:#fff;font-family:Courier New,monospace;flex:1}.join-code-copy{background:#fff3;border:1px solid rgba(255,255,255,.35);color:#fff;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.join-code-copy:hover{background:#ffffff52}.join-code-hint{font-size:11px;color:#ffffffbf;line-height:1.5}.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.event-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px;cursor:pointer;transition:box-shadow .18s,border-color .18s,transform .18s;display:flex;flex-direction:column;gap:6px}.event-card:hover{box-shadow:0 8px 24px #4f46e51f;border-color:#a5b4fc;transform:translateY(-2px)}.event-card h3{font-size:16px;font-weight:700}.event-card-badge{font-size:10px;font-weight:700;letter-spacing:.07em;color:#4f46e5;text-transform:uppercase}.event-card-sub{color:#666;font-size:13px}.event-card-date{color:#888;font-size:12px}.event-card-id{color:#bbb;font-size:11px;font-family:monospace}.event-type-badge{font-size:11px;font-weight:700;letter-spacing:.08em;color:#4f46e5;text-transform:uppercase;margin-bottom:4px}.status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#f3f4f6;color:#6b7280}.event-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}@media (max-width: 640px){.event-layout{grid-template-columns:1fr}}.album-sidebar{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;position:sticky;top:72px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-weight:600;font-size:13px;border-bottom:1px solid #f3f4f6}.album-list{list-style:none;padding:8px 0}.uploader{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px;margin-bottom:20px}.uploader-title{font-weight:600;font-size:14px;margin-bottom:12px}.uploader-actions{display:flex;gap:10px;flex-wrap:wrap}.upload-progress-panel{display:flex;flex-direction:column;gap:10px}.upload-summary{display:flex;justify-content:space-between;font-size:13px;color:#555}.upload-overall-pct{font-weight:700;color:#4f46e5}.progress-bar-track{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:#4f46e5;transition:width .2s;border-radius:3px}.upload-file-list{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.upload-file-row{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;border-radius:4px;font-size:12px}.upload-uploading{background:#f0f9ff}.upload-done{background:#f0fdf4}.upload-error{background:#fef2f2}.upload-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px}.upload-file-pct{color:#4f46e5;font-weight:600}.upload-tick{color:#16a34a;font-weight:700}.upload-err{color:#dc2626;font-weight:700}.upload-done-panel{display:flex;align-items:center;gap:16px;font-size:14px;color:#166534}.grid-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:12px}.grid-count{font-size:13px;color:#555}.grid-toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.select-sm{padding:5px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;background:#fff;cursor:pointer}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.photo-card{position:relative;border-radius:6px;overflow:hidden;border:2px solid transparent;cursor:pointer;background:#f3f4f6;transition:border-color .12s,box-shadow .12s;aspect-ratio:1}.photo-card:hover{border-color:#93c5fd}.photo-card-selected{border-color:#4f46e5;box-shadow:0 0 0 1px #4f46e5}.photo-thumb{width:100%;height:100%;object-fit:cover;display:block}.photo-check{position:absolute;top:6px;right:6px;background:#4f46e5;color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.load-more{text-align:center;padding:20px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:#fff;border-radius:12px;width:100%;max-width:500px;box-shadow:0 20px 60px #00000026;max-height:90vh;display:flex;flex-direction:column}.modal-sm{max-width:380px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.modal-header h2{font-size:18px;font-weight:700}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:8px;flex-shrink:0}.form-row{display:flex;flex-direction:column;gap:6px}.form-row label{font-size:13px;font-weight:500}.form-row input,.form-row select,.form-row textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;outline:none;transition:border-color .15s;font-family:inherit}.form-row input:focus,.form-row select:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #e0e7ff}.section-title{font-size:16px;font-weight:600;margin-bottom:16px;color:#333}.processing-badge{position:absolute;top:6px;left:6px;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700;display:flex;align-items:center;gap:3px}.badge-queued{background:#fef9c3;color:#854d0e}.badge-processing{background:#e0e7ff;color:#3730a3}.badge-done{background:#dcfce7;color:#166534}.badge-error{background:#fee2e2;color:#991b1b}.face-count{font-size:10px;opacity:.8}.btn-process{background:#7c3aed;color:#fff}.btn-process:hover:not(:disabled){background:#6d28d9}.event-card{position:relative;cursor:default}.event-card-cover{width:100%;height:120px;object-fit:cover;border-radius:8px 8px 0 0;display:block;margin:-20px -20px 12px;width:calc(100% + 40px)}.event-card-body{cursor:pointer}.event-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.event-card-code{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:#4f46e5;background:#eef2ff;border-radius:6px;padding:3px 9px;letter-spacing:.04em;font-family:Courier New,monospace}.event-card-code-icon{font-size:11px}.event-card-edit{position:absolute;top:12px;right:12px;font-size:12px}.event-header-left{display:flex;align-items:flex-start;gap:16px}.event-header-cover{width:80px;height:80px;object-fit:cover;border-radius:8px;border:1px solid #e5e7eb;flex-shrink:0}.cover-upload-row{display:flex;align-items:center;gap:12px}.cover-preview{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid #e5e7eb}.locked-fields{display:flex;gap:16px;flex-wrap:wrap;padding:10px 12px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.locked-item{font-size:12px;color:#6b7280}.locked-item code{font-family:monospace;color:#374151}.locked-item strong{color:#374151;letter-spacing:.05em}.toggle-row{display:flex;align-items:center}.toggle{display:flex;align-items:center;gap:8px;cursor:pointer}.toggle input{width:16px;height:16px;cursor:pointer}.toggle-label{font-size:14px}.photo-card{position:relative;overflow:hidden}.photo-hover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000b8,#0000 55%);display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:8px;opacity:0;transition:opacity .18s ease;pointer-events:none}.photo-card:hover .photo-hover-overlay{opacity:1;pointer-events:auto}.view-full-btn{background:#ffffff2e;border:1px solid rgba(255,255,255,.4);color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:4px;cursor:pointer;margin-bottom:4px;transition:background .15s}.view-full-btn:hover{background:#ffffff52}.hover-filename{font-size:10px;color:#ffffffd9;line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000eb;display:flex;align-items:center;justify-content:center}.lightbox-close{position:absolute;top:16px;right:20px;z-index:1001;background:#ffffff1f;border:none;color:#fff;font-size:20px;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.lightbox-close:hover{background:#ffffff40}.lightbox-content{display:flex;flex-direction:column;align-items:center;max-width:92vw;max-height:92vh}.lightbox-img{max-width:88vw;max-height:82vh;object-fit:contain;border-radius:4px;box-shadow:0 8px 40px #0009}.lightbox-footer{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 4px 0;color:#ffffffb3;font-size:12px}.lightbox-filename{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.confirm-modal-box{max-width:420px}.confirm-modal-box .modal-body p{color:#374151;font-size:14px;line-height:1.6}.grid-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:999;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:0 4px 16px #0000002e;pointer-events:none;animation:toast-in .2s ease}.grid-toast-success{background:#16a34a;color:#fff}.grid-toast-error{background:#dc2626;color:#fff}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.album-item{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;transition:background .12s;position:relative;-webkit-user-select:none;user-select:none}.album-item:hover{background:#f3f4f6}.album-active{background:#eef2ff!important;color:#4338ca;font-weight:600}.album-icon{flex-shrink:0}.album-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-count{flex-shrink:0;font-size:11px;font-weight:600;background:#e5e7eb;color:#6b7280;border-radius:10px;padding:1px 7px;min-width:22px;text-align:center}.album-active .album-count{background:#c7d2fe;color:#4338ca}.album-actions{display:none;align-items:center;gap:2px;flex-shrink:0}.album-item:hover .album-actions{display:flex}.album-action-btn{background:none;border:none;padding:3px 5px;border-radius:4px;cursor:pointer;font-size:13px;line-height:1;transition:background .12s}.album-action-btn:hover{background:#e5e7eb}.album-action-delete:hover{background:#fee2e2}.album-rename-input{flex:1;border:1px solid #4f46e5;border-radius:4px;padding:2px 6px;font-size:13px;outline:none;background:#fff;min-width:0}.processing-banner{display:flex;align-items:center;gap:8px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;padding:8px 14px;font-size:13px;color:#4338ca;margin-bottom:12px}.filter-bar{display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px;padding:10px 0 14px;border-bottom:1px solid #f3f4f6;margin-bottom:12px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.filter-chips{display:flex;flex-wrap:wrap;gap:5px}.filter-chip{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid #e5e7eb;background:#fff;color:#374151;cursor:pointer;transition:all .12s}.filter-chip:hover{border-color:#9ca3af;background:#f9fafb}.filter-chip-active{background:#4f46e5;border-color:#4f46e5;color:#fff}.filter-chip-active:hover{background:#4338ca;border-color:#4338ca}.filter-clear{align-self:flex-end;margin-left:auto;color:#6b7280}.visibility-options{display:flex;flex-direction:column;gap:8px;margin-top:4px}.vis-option{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:8px;border:1.5px solid #e5e7eb;cursor:pointer;transition:border-color .12s,background .12s;position:relative}.vis-option input[type=radio]{position:absolute;opacity:0;pointer-events:none}.vis-option:hover{border-color:#a5b4fc;background:#f5f3ff}.vis-selected{border-color:#4f46e5!important;background:#eef2ff!important}.vis-title{font-size:13px;font-weight:600;color:#1a1a1a}.vis-desc{font-size:12px;color:#6b7280;line-height:1.4}.photo-card-public{outline:2px solid #4f46e5;outline-offset:-2px}.public-badge{position:absolute;top:6px;left:50%;transform:translate(-50%);z-index:3;font-size:13px;line-height:1;background:#4f46e5d9;color:#fff;border-radius:4px;padding:2px 5px;pointer-events:none;white-space:nowrap}.hover-actions{display:flex;flex-direction:column;gap:6px;width:100%}.public-toggle-btn{width:100%;padding:5px 8px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid rgba(255,255,255,.35);background:#00000073;color:#fff;transition:background .15s,border-color .15s}.public-toggle-btn:hover{background:#000000a6}.public-toggle-btn.is-public{background:#4f46e5bf;border-color:#4f46e5e6}.public-toggle-btn.is-public:hover{background:#4338cae6}.btn-public{background:#4f46e5;color:#fff;border:none}.btn-public:hover{background:#4338ca}
