:root{--tt-primary:#0f172a;--tt-primary-light:#1e293b;--tt-accent:#ea580c;--tt-accent-hover:#c2410c;--tt-accent-light:#ffedd5;--tt-secondary:#0ea5e9;--tt-secondary-hover:#0284c7;--tt-secondary-light:#e0f2fe;--tt-surface:#f8fafc;--tt-surface-2:#f1f5f9;--tt-surface-3:#e2e8f0;--tt-card:#fff;--tt-text:#1e293b;--tt-text-muted:#64748b;--tt-text-inverse:#fff;--tt-border:#e2e8f0;--tt-radius:12px;--tt-radius-sm:8px;--tt-shadow:0 4px 6px -1px #0f172a14,0 2px 4px -2px #0f172a0f;--tt-shadow-lg:0 10px 15px -3px #0f172a14,0 4px 6px -4px #0f172a0f;--tt-font:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;background:var(--tt-surface);color:#1e293b;color:var(--tt-text);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--tt-font)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.admin-layout{background:var(--tt-surface);display:flex;min-height:100vh}.admin-sidebar{background:var(--tt-primary);box-shadow:var(--tt-shadow);color:var(--tt-text-inverse);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:260px}.admin-sidebar-header{border-bottom:1px solid #ffffff1a;padding:24px}.admin-sidebar-header h2{font-size:1.2rem;font-weight:700;letter-spacing:-.02em;margin:0}.admin-nav{flex:1 1;padding:16px 0}.admin-layout .nav-link{align-items:center;border-left:3px solid #0000;color:#ffffffd9;display:flex;font-size:.95rem;font-weight:500;gap:10px;padding:14px 24px;text-decoration:none;transition:background .2s,color .2s}.admin-layout .nav-link:hover{background:#ffffff14;color:#fff}.admin-layout .nav-link.active{background:#ffffff1f;border-left-color:var(--tt-accent);color:#fff}.admin-sidebar-footer{border-top:1px solid #ffffff1a;padding:20px}.admin-layout .logout-button{align-items:center;background:#ef444433;border:1px solid #ef44444d;border-radius:var(--tt-radius-sm);color:#fca5a5;cursor:pointer;display:flex;font-family:var(--tt-font);font-size:.9rem;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:background .2s,border-color .2s;width:100%}.admin-layout .logout-button:hover{background:#ef44444d;border-color:#ef444480;color:#fff}.admin-main{display:flex;flex:1 1;flex-direction:column;margin-left:260px}.admin-header{background:var(--tt-card);border-bottom:1px solid var(--tt-border);box-shadow:0 1px 3px #0f172a0d;padding:20px 32px}.admin-header h1{color:var(--tt-primary);font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0}.admin-content{flex:1 1;overflow-y:auto;padding:28px 32px}@media (max-width:768px){.admin-sidebar{width:220px}.admin-main{margin-left:220px}.admin-content{padding:20px}}.customer-layout{background:var(--tt-surface);display:flex;min-height:100vh}.customer-sidebar{background:var(--tt-primary);box-shadow:var(--tt-shadow);color:var(--tt-text-inverse);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:260px}.customer-sidebar-header{border-bottom:1px solid #ffffff1a;padding:24px}.customer-sidebar-header h2{font-size:1.2rem;font-weight:700;letter-spacing:-.02em;margin:0}.customer-nav{flex:1 1;padding:16px 0}.customer-layout .nav-link{align-items:center;border-left:3px solid #0000;color:#ffffffd9;display:flex;font-size:.95rem;font-weight:500;gap:10px;padding:14px 24px;text-decoration:none;transition:background .2s,color .2s}.customer-layout .nav-link:hover{background:#ffffff14;color:#fff}.customer-layout .nav-link.active{background:#ffffff1f;border-left-color:var(--tt-accent);color:#fff}.customer-sidebar-footer{border-top:1px solid #ffffff1a;padding:20px}.customer-layout .logout-button{align-items:center;background:#ef444433;border:1px solid #ef44444d;border-radius:var(--tt-radius-sm);color:#fca5a5;cursor:pointer;display:flex;font-family:var(--tt-font);font-size:.9rem;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:background .2s,border-color .2s;width:100%}.customer-layout .logout-button:hover{background:#ef44444d;border-color:#ef444480;color:#fff}.customer-main{display:flex;flex:1 1;flex-direction:column;margin-left:260px}.customer-header{background:var(--tt-card);border-bottom:1px solid var(--tt-border);box-shadow:0 1px 3px #0f172a0d;padding:20px 32px}.customer-header h1{color:var(--tt-primary);font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0}.customer-content{flex:1 1;overflow-y:auto;padding:28px 32px}@media (max-width:768px){.customer-sidebar{width:220px}.customer-main{margin-left:220px}.customer-content{padding:20px}}.home{display:flex;flex-direction:column;min-height:100vh}.navbar{background:var(--tt-primary);box-shadow:var(--tt-shadow);color:var(--tt-text-inverse);padding:.875rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.nav-container{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.logo-wrap,.nav-container{align-items:center;display:flex}.logo-wrap{color:inherit;font-size:1.35rem;font-weight:700;gap:10px;text-decoration:none}.logo-img{height:40px;width:auto}.logo-text{letter-spacing:-.02em}.nav-links{align-items:center;display:flex;gap:1.5rem}.nav-links a{color:#ffffffe6;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover{color:#fff}.nav-btn{border-radius:var(--tt-radius-sm);font-weight:600;padding:8px 18px}.nav-btn-customer{background:var(--tt-accent);color:#fff}.nav-btn-customer:hover{background:var(--tt-accent-hover);color:#fff}.nav-btn-admin{background:#ffffff26;border:1px solid #ffffff4d}.nav-btn-admin:hover{background:#ffffff40;color:#fff}.main{flex:1 1}.hero{overflow:hidden;padding:64px 24px 80px;position:relative}.hero-bg{background:linear-gradient(135deg,var(--tt-primary) 0,var(--tt-primary-light) 50%,#0c4a6e 100%);inset:0;opacity:.97;position:absolute}.hero-inner{grid-gap:48px;align-items:center;display:grid;gap:48px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;position:relative}.hero-content{color:#fff}.hero-badge{background:#ffffff26;border-radius:999px;color:#fffffff2;display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.02em;margin-bottom:20px;padding:6px 14px}.hero-title{font-size:clamp(2rem,4vw,3.25rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:16px}.hero-title-accent{color:var(--tt-accent-light)}.hero-desc{color:#ffffffe6;font-size:1.1rem;line-height:1.65;margin-bottom:28px;max-width:520px}.hero-desc strong{color:#fff}.hero-mobile-ref{color:#ffffffd9;font-size:.95rem;margin-bottom:20px}.hero-ctas{display:flex;flex-wrap:wrap;gap:12px}.btn{align-items:center;border:none;border-radius:var(--tt-radius-sm);cursor:pointer;display:inline-flex;font-family:var(--tt-font);font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:14px 28px;text-decoration:none;transition:transform .2s,box-shadow .2s}.btn .btn-icon{flex-shrink:0}.btn-sm{font-size:.95rem;padding:10px 20px}.btn-primary{background:var(--tt-accent)}.btn-primary:hover{background:var(--tt-accent-hover);box-shadow:0 8px 20px #ea580c59;transform:translateY(-2px)}.btn-accent{background:var(--tt-accent);color:#fff}.btn-accent:hover{background:var(--tt-accent-hover);color:#fff;transform:translateY(-2px)}.btn-outline{background:#0000;border:2px solid var(--tt-primary);color:var(--tt-primary)}.btn-outline:hover{background:var(--tt-primary);color:#fff}.btn-lg{font-size:1.1rem;padding:18px 36px}.hero-visual{align-items:center;display:flex;justify-content:center}.phone-mockup{background:linear-gradient(145deg,#1e293b,#0f172a);border-radius:36px;box-shadow:0 25px 50px -12px #0006,0 0 0 1px #ffffff0d;padding:12px;width:280px}.phone-screen{align-items:stretch;aspect-ratio:9/19;background:var(--tt-surface);border-radius:28px;display:flex;justify-content:stretch;min-height:420px;overflow:hidden}.phone-screen-img{display:block;height:100%;object-fit:fill;object-position:top center}.section{padding:72px 24px}.section-residents{background:var(--tt-surface)}.section-promoters{background:var(--tt-surface-2)}.section-society{background:var(--tt-surface)}.section-cta-block{background:linear-gradient(135deg,var(--tt-primary) 0,var(--tt-primary-light) 100%);color:#fff;text-align:center}.cta-block-mobile-ref{align-items:center;display:flex;flex-direction:column;gap:12px}.cta-block-mobile-ref .cta-block-icon{opacity:.9}.cta-block-mobile-ref .section-title{margin-bottom:4px}.cta-block-mobile-ref .section-desc{margin-bottom:8px}.cta-block-badge{background:#fff3;border-radius:999px;color:#fffffff2;display:inline-block;font-size:.85rem;font-weight:600;margin-bottom:16px;padding:6px 14px}.section-contact{background:var(--tt-surface-2)}.container{margin:0 auto;max-width:1100px}.section-badge{color:var(--tt-accent);display:inline-block;font-size:.875rem;font-weight:700;letter-spacing:.08em;margin-bottom:12px;text-transform:uppercase}.section-title{color:var(--tt-primary);font-size:clamp(1.75rem,3vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin-bottom:12px}.section-title-light{color:#fff}.section-desc{color:var(--tt-text-muted);font-size:1.1rem;line-height:1.6;margin-bottom:40px;max-width:640px}.section-desc-light{color:#ffffffe6;margin-left:auto;margin-right:auto}.cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.card{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);padding:28px;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:var(--tt-shadow-lg);transform:translateY(-4px)}.card-highlight{background:linear-gradient(180deg,#fff 0,var(--tt-accent-light) 120%);border-color:var(--tt-accent-light)}.card-highlight:hover{border-color:var(--tt-accent)}.card-icon{font-size:2rem;margin-bottom:16px}.card h3{color:var(--tt-primary);font-size:1.2rem;font-weight:700;margin-bottom:8px}.card p{color:var(--tt-text-muted);font-size:.95rem;line-height:1.6;margin:0}.section-cta{margin-top:40px}.section-cta,.section-mobile-cta{display:flex;flex-wrap:wrap;gap:16px}.section-mobile-cta{align-items:center;background:var(--tt-surface-2);border:1px solid var(--tt-border);border-radius:var(--tt-radius);margin-top:32px;padding:24px}.section-mobile-cta .card-icon,.section-mobile-cta>svg:first-child{color:var(--tt-primary);flex-shrink:0}.section-mobile-cta p{color:var(--tt-text-muted);flex:1 1;font-size:1rem;margin:0;min-width:200px}.section-mobile-cta .btn{flex-shrink:0}.features-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.feature-item{align-items:center;background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius-sm);color:var(--tt-text);display:flex;font-weight:500;gap:14px;padding:20px}.feature-icon{font-size:1.5rem}.contact-info{max-width:560px}.contact-info p{color:var(--tt-text-muted);font-size:1rem;margin-bottom:10px}.contact-info a{color:var(--tt-secondary);font-weight:600;text-decoration:none}.contact-info a:hover{text-decoration:underline}.footer{background:var(--tt-primary);color:var(--tt-text-inverse);padding:28px 24px}.footer-inner{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px}.footer-left{display:flex;flex-direction:column;gap:8px}.footer-copy{color:#fffc;font-size:.9rem;margin:0}.footer-mobile-ref{align-items:center;color:#ffffffd9;display:inline-flex;font-size:.9rem;gap:6px;margin:0}.footer-mobile-ref a{color:var(--tt-accent-light);font-weight:600;text-decoration:none}.footer-mobile-ref a:hover{text-decoration:underline}.footer-links{display:flex;gap:24px}.footer-links a{color:#ffffffe6;font-size:.9rem;font-weight:500;text-decoration:none}.footer-links a:hover{color:#fff;text-decoration:underline}@media (max-width:900px){.hero-inner{grid-template-columns:1fr;text-align:center}.hero-desc{margin-left:auto;margin-right:auto}.hero-mobile-ref{text-align:center}.hero-ctas{justify-content:center}.hero-visual{order:-1}.phone-mockup{width:240px}.phone-screen{min-height:360px}}@media (max-width:768px){.nav-links{gap:.75rem}.nav-links a:not(.nav-btn){display:none}.hero{padding:48px 20px 64px}.section{padding:56px 20px}.section-cta{flex-direction:column}.section-cta .btn{width:100%}.footer-inner{flex-direction:column;text-align:center}}.privacy-policy{background:var(--tt-surface);display:flex;flex-direction:column;min-height:100vh}.privacy-policy .navbar{background:var(--tt-primary);box-shadow:var(--tt-shadow);color:var(--tt-text-inverse);padding:.875rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.privacy-policy .nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.privacy-policy .logo-wrap{align-items:center;color:inherit;display:flex;font-size:1.35rem;font-weight:700;gap:10px;text-decoration:none}.privacy-policy .logo-img{height:40px;width:auto}.privacy-policy .logo-text{letter-spacing:-.02em}.privacy-policy .nav-links{align-items:center;display:flex;gap:1.5rem}.privacy-policy .nav-links a{color:#ffffffe6;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}.privacy-policy .nav-links a:hover{color:#fff}.privacy-policy .nav-btn{border-radius:var(--tt-radius-sm);font-weight:600;padding:8px 18px}.privacy-policy .nav-btn-customer{background:var(--tt-accent);color:#fff}.privacy-policy .nav-btn-customer:hover{color:#fff}.privacy-policy .nav-btn-admin{background:#ffffff26;border:1px solid #ffffff4d}.privacy-policy .nav-btn-admin:hover{background:#ffffff40;color:#fff}.policy-content{flex:1 1;padding:40px 24px}.policy-content .container{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);margin:0 auto;max-width:900px;padding:40px}.policy-content h1{border-bottom:3px solid var(--tt-accent);color:var(--tt-primary);font-size:1.75rem;font-weight:800;margin-bottom:12px;padding-bottom:12px}.last-updated{color:var(--tt-text-muted);font-size:.95rem;font-style:italic;margin-bottom:32px}.policy-content section{margin-bottom:40px}.policy-content h2{color:var(--tt-primary);font-size:1.4rem;font-weight:700;margin-bottom:12px;margin-top:32px}.policy-content h3{color:var(--tt-primary-light);font-size:1.15rem;font-weight:600;margin-bottom:10px;margin-top:20px}.policy-content p{color:var(--tt-text);font-size:1rem;line-height:1.75;margin-bottom:14px}.policy-content ol,.policy-content ul{line-height:1.75;margin:14px 0;padding-left:28px}.policy-content li{color:var(--tt-text);margin:8px 0}.policy-content a{color:var(--tt-secondary);font-weight:600;text-decoration:none}.policy-content a:hover{text-decoration:underline}.policy-content .contact-info{background:var(--tt-surface-2);border:1px solid var(--tt-border);border-radius:var(--tt-radius-sm);margin-top:20px;padding:24px}.policy-content .contact-info p{margin:10px 0}.privacy-policy .footer{background:var(--tt-primary);color:var(--tt-text-inverse);margin-top:auto;padding:28px 24px;text-align:center}.privacy-policy .footer .container{align-items:center;background:#0000;border:none;box-shadow:none;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0}.privacy-policy .footer p{color:#fffc;font-size:.9rem;margin:0}.privacy-policy .footer .footer-links{display:flex;gap:24px;margin-top:0}.privacy-policy .footer .footer-links a{color:#ffffffe6;font-size:.9rem;font-weight:500;text-decoration:none}.privacy-policy .footer .footer-links a:hover{color:#fff;text-decoration:underline}@media (max-width:768px){.policy-content .container{padding:24px}.policy-content h1{font-size:1.5rem}.policy-content h2{font-size:1.25rem}.privacy-policy .nav-links a:not(.nav-btn){font-size:.9rem}}.delete-account{background:var(--tt-surface);display:flex;flex-direction:column;min-height:100vh}.delete-account .navbar{background:var(--tt-primary);box-shadow:var(--tt-shadow);color:var(--tt-text-inverse);padding:.875rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.delete-account .nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.delete-account .logo-wrap{align-items:center;color:inherit;display:flex;font-size:1.35rem;font-weight:700;gap:10px;text-decoration:none}.delete-account .logo-img{height:40px;width:auto}.delete-account .logo-text{letter-spacing:-.02em}.delete-account .nav-links{align-items:center;display:flex;gap:1.5rem}.delete-account .nav-links a{color:#ffffffe6;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}.delete-account .nav-links a:hover{color:#fff}.delete-account .nav-btn{border-radius:var(--tt-radius-sm);font-weight:600;padding:8px 18px}.delete-account .nav-btn-customer{background:var(--tt-accent);color:#fff}.delete-account .nav-btn-customer:hover{color:#fff}.delete-account .nav-btn-admin{background:#ffffff26;border:1px solid #ffffff4d}.delete-account .nav-btn-admin:hover{background:#ffffff40;color:#fff}.delete-content{flex:1 1;padding:40px 24px}.delete-content .container{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);margin:0 auto;max-width:700px;padding:40px}.delete-content h1{border-bottom:3px solid var(--tt-accent);color:var(--tt-primary);font-size:1.75rem;font-weight:800;margin-bottom:20px;padding-bottom:12px}.intro-text{color:var(--tt-text-muted);font-size:1.05rem;line-height:1.65;margin-bottom:28px}.delete-form{margin-top:28px}.delete-account .form-group{margin-bottom:24px}.delete-account .form-group label{color:var(--tt-text);display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.delete-account .form-group input[type=email],.delete-account .form-group textarea{border:2px solid var(--tt-border);border-radius:var(--tt-radius-sm);box-sizing:border-box;font-family:var(--tt-font);font-size:1rem;padding:12px 14px;transition:border-color .2s;width:100%}.delete-account .form-group input[type=email]:focus,.delete-account .form-group textarea:focus{border-color:var(--tt-primary);outline:none}.delete-account .form-group small{color:var(--tt-text-muted);display:block;font-size:.875rem;margin-top:6px}.checkbox-group{margin:28px 0}.checkbox-label{align-items:flex-start;gap:12px}.checkbox-label input[type=checkbox]{height:20px;margin-top:4px;width:20px}.checkbox-label span{color:var(--tt-text);line-height:1.6}.warning-box{background:#fffbeb;border:2px solid #f59e0b;border-radius:var(--tt-radius-sm);margin:28px 0;padding:20px}.warning-box strong{color:#b45309;display:block;font-size:1rem;margin-bottom:10px}.warning-box ul{color:#b45309;margin:10px 0 0 20px}.warning-box li{line-height:1.5;margin:8px 0}.submit-btn{background:#dc2626;border:none;border-radius:var(--tt-radius-sm);color:#fff;cursor:pointer;font-family:var(--tt-font);font-size:1.05rem;font-weight:600;margin-top:20px;padding:14px;transition:background .2s,transform .2s;width:100%}.submit-btn:hover{background:#b91c1c;transform:translateY(-1px)}.submit-btn:active{transform:translateY(0)}.success-message{padding:32px 0;text-align:center}.success-message h2{align-items:center;color:#059669;display:flex;font-weight:700;gap:10px;justify-content:center;margin-bottom:20px}.success-message p{color:var(--tt-text);line-height:1.75;margin-bottom:14px}.success-message a{color:var(--tt-secondary);font-weight:600;text-decoration:none}.success-message a:hover{text-decoration:underline}.back-link{background:var(--tt-primary);border-radius:var(--tt-radius-sm);color:#fff;display:inline-block;font-family:var(--tt-font);font-weight:600;margin-top:24px;padding:14px 28px;text-decoration:none;transition:background .2s,transform .2s}.back-link:hover{background:var(--tt-primary-light);color:#fff;transform:translateY(-1px)}.alternative-method{border-top:2px solid var(--tt-border);margin-top:40px;padding-top:28px}.alternative-method h3{color:var(--tt-primary);font-weight:700;margin-bottom:12px}.alternative-method p{color:var(--tt-text-muted);line-height:1.65;margin-bottom:10px}.alternative-method a{color:var(--tt-secondary);font-weight:600;text-decoration:none}.alternative-method a:hover{text-decoration:underline}.delete-account .footer{background:var(--tt-primary);color:var(--tt-text-inverse);margin-top:auto;padding:28px 24px;text-align:center}.delete-account .footer .container{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px}.delete-account .footer p{color:#fffc;font-size:.9rem;margin:0}.delete-account .footer .footer-links{display:flex;gap:24px;margin-top:0}.delete-account .footer .footer-links a{color:#ffffffe6;font-size:.9rem;font-weight:500;text-decoration:none}.delete-account .footer .footer-links a:hover{color:#fff;text-decoration:underline}@media (max-width:768px){.delete-content .container{padding:24px}.delete-content h1{font-size:1.5rem}.delete-account .nav-links a:not(.nav-btn){font-size:.9rem}}.admin-login-container{align-items:center;background:linear-gradient(135deg,var(--tt-primary) 0,var(--tt-primary-light) 50%,#0c4a6e 100%);display:flex;justify-content:center;min-height:100vh;padding:24px}.admin-login-card{background:var(--tt-card);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow-lg),0 0 0 1px #0f172a0d;max-width:400px;padding:40px;width:100%}.admin-login-header{margin-bottom:32px;text-align:center}.admin-login-header h1{color:var(--tt-primary);font-size:1.75rem;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.admin-login-header p{color:var(--tt-text-muted);font-size:.95rem;margin:0}.admin-login-form{display:flex;flex-direction:column;gap:20px}.admin-login-form .form-group{display:flex;flex-direction:column;gap:8px}.admin-login-form .form-group label{color:var(--tt-text);font-size:.9rem;font-weight:600}.admin-login-form .form-group input{border:2px solid var(--tt-border);border-radius:var(--tt-radius-sm);font-family:var(--tt-font);font-size:1rem;padding:12px 14px;transition:border-color .2s}.admin-login-form .form-group input:focus{border-color:var(--tt-primary);outline:none}.admin-login-form .error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--tt-radius-sm);color:#b91c1c;font-size:.9rem;padding:12px}.admin-login-form .login-button{background:var(--tt-primary);border:none;border-radius:var(--tt-radius-sm);color:#fff;cursor:pointer;font-family:var(--tt-font);font-size:1rem;font-weight:600;padding:14px;transition:background .2s,transform .2s}.admin-login-form .login-button:hover:not(:disabled){background:var(--tt-primary-light);transform:translateY(-1px)}.admin-login-form .login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.admin-dashboard{max-width:1200px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:20px;padding:24px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-icon{font-size:40px}.stat-content h3{color:#666;font-size:14px;font-weight:500;margin:0 0 8px}.stat-value{color:#333;font-size:32px;font-weight:700;margin:0}.recent-promotions{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.recent-promotions h2{color:#333;font-size:20px;margin:0 0 20px}.promotions-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.promo-card{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:12px;gap:8px;padding:20px}.promo-title{color:#333;font-size:16px;font-weight:600;line-height:1.3;margin:0}.promo-category{color:#666;flex:1 1;font-size:13px;margin:0}.promo-card .status-badge{align-self:flex-start;margin-top:4px}.form-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.form-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.form-modal-inline{border:1px solid #e0e0e0;box-shadow:none;max-height:none}.form-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:24px}.form-header h2{color:#333;font-size:20px;margin:0}.close-button{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;height:32px;justify-content:center;line-height:1;padding:0;width:32px}.close-button:hover{color:#333}.promotion-form{padding:24px}.form-section{border-bottom:1px solid #e8e8e8;margin-bottom:32px;padding-bottom:24px}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section-title{color:#333;font-size:1.1rem;font-weight:700;margin:0 0 6px}.form-section-desc{color:#666;font-size:.9rem;line-height:1.4;margin:0 0 16px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.form-group label{color:#333;font-size:14px;font-weight:500}.form-group input:not([type=checkbox]),.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:10px;transition:border-color .3s}.form-group input:not([type=checkbox]):focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.checkbox-group{background:#f9f9f9;border-radius:8px;display:flex;flex-wrap:wrap;gap:14px 20px;padding:14px 16px}.checkbox-label{font-size:14px;gap:14px;min-height:26px;padding:2px 0}.checkbox-label input[type=checkbox]{border-radius:4px;cursor:pointer;flex-shrink:0;height:18px;margin:0;min-width:18px;padding:0;width:18px}.checkbox-inline{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:14px;min-height:26px;padding:2px 0}.checkbox-inline input[type=checkbox]{border-radius:4px;cursor:pointer;flex-shrink:0;height:18px;margin:0;min-width:18px;padding:0;width:18px}.error-message{font-size:14px;padding:12px}.form-actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.cancel-button,.save-button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.cancel-button{background:#f5f5f5;color:#666}.cancel-button:hover{background:#e0e0e0}.save-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.save-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.save-button:disabled{cursor:not-allowed;opacity:.6}.image-upload-row{align-items:flex-start;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:10px;margin-bottom:16px;padding:12px}.image-input-section{display:flex;flex:1 1;flex-direction:column;gap:12px}.image-preview{border:2px solid #ddd;border-radius:8px;max-width:200px;overflow:hidden;position:relative;width:100%}.image-preview img{display:block;height:auto;width:100%}.remove-preview-btn{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;position:absolute;right:4px;top:4px;width:24px}.remove-preview-btn:hover{background:#000000e6}.image-input-group{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.file-input{display:none}.upload-button{align-items:center;background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s;white-space:nowrap}.upload-button:hover:not(.disabled):not(.uploading){background:#1976d2;transform:translateY(-1px)}.upload-button.uploading{background:#999;cursor:not-allowed}.upload-button.disabled{background:#ccc;cursor:not-allowed;opacity:.6}.icon-spin{animation:icon-spin 1s linear infinite}@keyframes icon-spin{to{transform:rotate(1turn)}}.or-divider{color:#999;font-size:12px;font-weight:500}.image-url-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:14px;min-width:200px;padding:8px 12px}.cover-photo-upload-section{display:flex;flex-direction:column;gap:12px}.cover-photo-preview{border:2px solid #ddd;border-radius:8px;max-width:300px;overflow:hidden;position:relative;width:100%}.cover-photo-preview img{display:block;height:auto;width:100%}.cover-photo-input-group{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.remove-image-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.remove-image-btn:hover{background:#d32f2f}.add-image-btn{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-top:10px;padding:10px 20px}.add-image-btn:hover{background:#45a049}.create-category-btn{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px}.create-category-btn:hover{background:#1976d2}.create-category-form{background:#f5f5f5}.save-category-btn{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.save-category-btn:hover{background:#45a049}.form-hint{color:#666;font-size:12px;margin-top:5px}.promotion-preview{position:-webkit-sticky;position:sticky;top:24px}.preview-title{color:#333;font-size:18px;font-weight:600;margin:0 0 16px}.preview-card{background:#fff;border:1px solid #e8e8e8;border-radius:12px;box-shadow:0 2px 12px #00000014;max-width:360px;overflow:hidden}.preview-image-wrap{aspect-ratio:16/10;background:#f0f0f0;overflow:hidden;width:100%}.preview-image{height:100%;object-fit:cover;width:100%}.preview-body{padding:16px}.preview-type-badge{background:#e8f5e9;border-radius:6px;color:#2e7d32;display:inline-block;font-size:11px;font-weight:600;margin-bottom:8px;padding:4px 8px}.preview-card-title{color:#333;font-size:18px;font-weight:600;margin:0 0 6px}.preview-brand{color:#666;font-size:14px;margin:0 0 8px}.preview-desc{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#555;display:-webkit-box;font-size:13px;line-height:1.4;margin:0 0 12px;overflow:hidden}.preview-offers{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.preview-discount{background:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:13px;font-weight:600;padding:4px 8px}.preview-coupon{background:#f5f5f5;border-radius:6px;color:#666;font-size:12px;padding:4px 8px}.preview-dates{color:#888;font-size:12px;margin:0 0 6px}.preview-contact,.preview-location{align-items:center;color:#555;display:flex;font-size:13px;gap:6px;margin:0}.admin-promotions{max-width:1400px}.promotions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.promotions-header h2{color:#333;font-size:24px;margin:0}.add-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:transform .2s,box-shadow .2s}.add-button:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.admin-promotions .create-with-preview{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 380px;margin-bottom:24px}.admin-promotions .create-form-column,.admin-promotions .create-preview-column{min-width:0}.promotions-table-container{-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;overflow-y:visible}.promotions-table{min-width:900px}.promotions-table thead{background:#f8f9fa}.promotions-table th{border-bottom:2px solid #e0e0e0;color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.promotions-table td{border-bottom:1px solid #f0f0f0;color:#666;font-size:14px;padding:16px}.promotions-table tbody tr:hover{background:#f9f9f9}.title-cell{color:#333;font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pricing-cell{color:#555;font-size:12px;max-width:180px}.coupon-code-badge,.type-badge{font-size:12px;padding:4px 12px}.coupon-code-badge{background:#e8f5e9;border-radius:12px;color:#2e7d32;font-family:Courier New,monospace;font-weight:600;letter-spacing:1px}.mobile-badge{background:#e3f2fd;color:#1976d2;font-size:12px}.location-badge,.mobile-badge{border-radius:12px;font-weight:500;padding:4px 10px}.location-badge{align-items:center;background:#fff3e0;color:#f57c00;display:inline-flex;display:inline-block;font-size:11px;gap:6px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:6px 12px}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.delete-button,.edit-button{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s}.edit-button{background:#e3f2fd;color:#1976d2}.edit-button:hover{background:#bbdefb}.delete-button{background:#ffebee;color:#c62828}.delete-button:hover{background:#ffcdd2}.empty-state{color:#999;padding:40px}.select-customer-step{margin-bottom:24px}.select-customer-box{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:480px;padding:24px}.select-customer-box h3{color:#333;font-size:18px;margin:0 0 8px}.select-customer-box p{color:#666;font-size:14px;margin:0 0 16px}.select-customer-box .form-group{margin-bottom:16px}.select-customer-box .form-group label{display:block;font-size:14px;font-weight:500;margin-bottom:6px}.select-customer-box select{border:1px solid #ddd;border-radius:8px;font-size:14px;padding:10px 12px;width:100%}.select-customer-box .hint{color:#f57c00;font-size:13px;margin-bottom:12px}.step-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.step-actions .cancel-button{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;padding:10px 20px}.step-actions .cancel-button:hover{background:#e8e8e8}.approval-badge{display:inline-block;font-size:12px;padding:4px 10px}.approval-badge.pending{background:#fff3e0;color:#e65100}.approval-badge.approved{background:#e8f5e9;color:#2e7d32}.approval-badge.rejected{background:#ffebee;color:#c62828}.approval-actions{display:flex;gap:6px;margin-top:6px}.approve-btn-small,.reject-btn-small{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:4px 10px}.approve-btn-small{background:#2e7d32;border-color:#2e7d32;color:#fff}.approve-btn-small:hover:not(:disabled){background:#1b5e20}.reject-btn-small{background:#fff;border-color:#c62828;color:#c62828}.reject-btn-small:hover:not(:disabled){background:#ffebee}.approve-btn-small:disabled,.reject-btn-small:disabled{cursor:not-allowed;opacity:.7}.admin-statistics{max-width:1400px}.admin-statistics h2{color:#333;font-size:24px;margin:0 0 24px}.stats-table-container{box-shadow:0 2px 8px #0000001a;overflow:hidden}.stats-table thead{background:#f8f9fa}.stats-table th{border-bottom:2px solid #e0e0e0;font-size:14px;padding:16px;text-align:left}.stats-table td{border-bottom:1px solid #f0f0f0;color:#666;padding:16px}.stats-table tbody tr:hover{background:#f9f9f9}.promotion-title{color:#333;font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ctr-badge{border-radius:12px;display:inline-block;padding:4px 12px}.ctr-badge.high{background:#d4edda;color:#155724}.ctr-badge.medium{background:#fff3cd;color:#856404}.ctr-badge.low{background:#f8d7da;color:#721c24}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.summary-card{box-shadow:0 2px 8px #0000001a;padding:24px}.summary-card h3{margin:0 0 12px}.summary-value{color:#333;font-size:32px}.empty-state,.loading{background:#fff;border-radius:12px;color:#999;padding:40px;text-align:center}.admin-society-overview{max-width:1400px}.overview-header{margin-bottom:32px}.overview-header h2{color:#333;font-size:28px;margin:0 0 8px}.overview-header .subtitle{color:#666;font-size:14px;margin:0}.societies-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.society-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px;transition:transform .2s,box-shadow .2s}.society-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.society-card-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.society-card-header h3{color:#333;font-size:20px;font-weight:600;margin:0}.promotion-count-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;font-size:12px;font-weight:600;padding:6px 12px}.no-promotions{color:#999;font-style:italic;padding:40px 20px}.promotions-list{display:flex;flex-direction:column;gap:16px}.promotion-item{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:16px}.promotion-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.promotion-header h4{color:#333;flex:1 1;font-size:16px;font-weight:600;margin:0}.type-badge{border-radius:12px;font-size:11px;margin-left:12px;padding:4px 10px}.type-badge.type-story{background:#e3f2fd;color:#1976d2}.type-badge.type-spotlight{background:#fff3e0;color:#f57c00}.type-badge.type-category{background:#f3e5f5;color:#7b1fa2}.promotion-details{display:flex;flex-direction:column;gap:8px}.detail-item{align-items:center;display:flex;font-size:13px}.detail-label{color:#666;font-weight:600;margin-right:8px;min-width:70px}.detail-value{color:#333}.detail-value.coupon-code,.detail-value.discount{color:#2e7d32;font-weight:600}.detail-value.coupon-code{background:#e8f5e9;border-radius:4px;font-family:Courier New,monospace;font-size:12px;letter-spacing:.5px;padding:2px 8px}.empty-state{box-shadow:0 2px 8px #0000001a}.empty-state p{color:#999;font-size:16px;margin:0}.loading{color:#666;font-size:16px;padding:40px}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin-bottom:20px;padding:16px}@media (max-width:768px){.societies-grid{grid-template-columns:1fr}.society-card-header{align-items:flex-start;flex-direction:column;gap:12px}.promotion-header{flex-direction:column;gap:8px}}.admin-customers{max-width:1400px}.admin-customers-loading{color:#666;padding:24px}.admin-customers-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.admin-customers-header h2{color:#333;font-size:24px;margin:0}.admin-customers-actions{align-items:center;display:flex;gap:12px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px}.btn-primary:hover{opacity:.95}.btn-secondary{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:14px;padding:10px 20px}.btn-secondary:hover{background:#e8e8e8}.badge-pending{background:#e74c3c;border-radius:10px;color:#fff;font-size:12px;margin-left:6px;padding:2px 8px}.admin-customers-table-wrap{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.admin-customers-table{border-collapse:collapse;width:100%}.admin-customers-table thead{background:#f8f9fa}.admin-customers-table th{border-bottom:2px solid #e0e0e0;color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.admin-customers-table td{border-bottom:1px solid #f0f0f0;color:#666;font-size:14px;padding:16px}.admin-customers-table tbody tr:hover{background:#f9f9f9}.admin-customers-table tbody tr.customer-row-clickable{cursor:pointer}.admin-customers-table .empty-state{color:#999;padding:32px;text-align:center}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.credits-btn,.edit-btn,.history-btn{border:none;border-radius:6px;cursor:pointer;font-size:13px;padding:6px 12px}.edit-btn{background:#3498db;color:#fff}.credits-btn{background:#27ae60;color:#fff}.history-btn{background:#95a5a6;color:#fff}.credits-btn:hover,.edit-btn:hover,.history-btn:hover{opacity:.9}.modal-overlay{background:#00000080}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:560px;overflow-y:auto;padding:24px;width:90%}.modal-content h3{color:#333;font-size:20px;margin:0 0 16px}.modal-actions{margin-top:20px}.form-error{background:#fee;border-radius:8px;color:#c00;margin-bottom:12px;padding:10px}.form-row{margin-bottom:14px}.form-row label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:4px}.form-row input[type=email],.form-row input[type=number],.form-row input[type=password],.form-row input[type=text]{border:1px solid #ddd;border-radius:8px;font-size:14px;padding:10px 12px;width:100%}.form-row.two-cols{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-row small{color:#666;display:block;font-size:12px;margin-top:4px}.societies-row .form-hint{color:#666;font-size:13px;font-weight:400;margin:0 0 8px}.society-checkboxes{background:#fafafa;border:1px solid #ddd;border-radius:8px;display:flex;flex-wrap:wrap;gap:10px;max-height:200px;min-height:80px;overflow-y:auto;padding:12px}.no-societies-msg{color:#856404;font-size:14px;margin:0;padding:8px 0;width:100%}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:6px;white-space:nowrap}.checkbox-label input{margin:0}.add-credits-form p,.credit-requests-modal p,.transactions-modal p{color:#666;margin-bottom:12px}.credit-requests-list{margin-bottom:16px}.credit-request-item{align-items:center;border:1px solid #eee;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:8px;padding:12px}.approve-btn{background:#27ae60;margin-right:8px}.approve-btn,.reject-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;padding:6px 14px}.reject-btn{background:#e74c3c}.mini-table{border-collapse:collapse;font-size:14px;width:100%}.mini-table td,.mini-table th{border-bottom:1px solid #eee;padding:10px;text-align:left}.mini-table th{color:#333;font-weight:600}.transactions-modal .transactions-list{max-height:300px;overflow-y:auto}.stat-pricing-modal .form-hint{color:#666;font-size:13px;margin-bottom:16px}.stat-pricing-list{margin-bottom:20px}.stat-pricing-row{align-items:center;display:flex;gap:12px;margin-bottom:12px}.stat-pricing-row .stat-param-label{color:#333;font-weight:500;min-width:140px}.stat-pricing-row input{border:1px solid #ddd;border-radius:6px;padding:8px 10px;width:100px}.pricing-btn,.stat-pricing-row .btn-small{font-size:13px;padding:6px 12px}.pricing-btn{background:#7b1fa2;border:none;border-radius:6px;color:#fff;cursor:pointer}.pricing-btn:hover{background:#6a1b9a}.admin-customer-detail{max-width:1200px}.customer-detail-error,.customer-detail-loading{color:#666;padding:48px 24px;text-align:center}.customer-detail-error p{margin:0 0 16px}.customer-detail-header{margin-bottom:24px}.customer-detail-header .btn-back{background:#0000;border:none;color:#667eea;cursor:pointer;font-size:14px;margin-bottom:12px;padding:0}.customer-detail-header .btn-back:hover{text-decoration:underline}.customer-detail-header h2{color:#333;font-size:24px;margin:0}.customer-detail-card{background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:32px;padding:24px}.customer-detail-card h3{color:#333;font-size:20px;margin:0 0 8px}.customer-detail-card .business-name{color:#666;font-size:14px;margin:0 0 20px}.customer-detail-dl{grid-gap:8px 24px;display:grid;font-size:14px;gap:8px 24px;grid-template-columns:auto 1fr;margin:0}.customer-detail-dl dt{color:#555;font-weight:600;margin:0}.customer-detail-dl dd{color:#333;margin:0}.customer-promotions-section{background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.customer-promotions-section h3{color:#333;font-size:18px;margin:0 0 20px}.customer-promotions-section .no-promotions{color:#666;font-style:italic;margin:0}.customer-promotions-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.customer-promotions-table{border-collapse:collapse;min-width:700px;width:100%}.customer-promotions-table thead{background:#f8f9fa}.customer-promotions-table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:13px;font-weight:600;padding:12px 16px;text-align:left}.customer-promotions-table td{border-bottom:1px solid #f0f0f0;color:#666;font-size:14px;padding:12px 16px}.customer-promotions-table tbody tr:hover{background:#f9f9f9}.customer-promotions-table .type-badge{border-radius:8px;font-size:12px;font-weight:600;padding:4px 10px}.customer-promotions-table .type-story{background:#e3f2fd;color:#1976d2}.customer-promotions-table .type-spotlight{background:#fff3e0;color:#f57c00}.customer-promotions-table .type-category{background:#f3e5f5;color:#7b1fa2}.customer-promotions-table .status-badge{border-radius:8px;font-size:12px;font-weight:600;padding:4px 10px}.customer-promotions-table .status-badge.active{background:#e8f5e9;color:#2e7d32}.customer-promotions-table .status-badge.inactive{background:#ffebee;color:#c62828}.customer-promotions-table .btn-edit-sm{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px}.customer-promotions-table .btn-edit-sm:hover{opacity:.9}.btn-back{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:14px;padding:10px 20px}.btn-back:hover{background:#e8e8e8}.customer-login-container{align-items:center;background:linear-gradient(135deg,var(--tt-primary) 0,var(--tt-primary-light) 50%,#0c4a6e 100%);display:flex;justify-content:center;min-height:100vh;padding:24px}.customer-login-card{background:var(--tt-card);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow-lg),0 0 0 1px #0f172a0d;max-width:400px;padding:40px;width:100%}.customer-login-header{margin-bottom:32px;text-align:center}.customer-login-header h1{color:var(--tt-primary);font-size:1.75rem;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.customer-login-header p{color:var(--tt-text-muted);font-size:.95rem;margin:0}.customer-login-form{display:flex;flex-direction:column;gap:20px}.customer-login-form .form-group{display:flex;flex-direction:column;gap:8px}.customer-login-form .form-group label{color:var(--tt-text);font-size:.9rem;font-weight:600}.customer-login-form .form-group input{border:2px solid var(--tt-border);border-radius:var(--tt-radius-sm);font-family:var(--tt-font);font-size:1rem;padding:12px 14px;transition:border-color .2s}.customer-login-form .form-group input:focus{border-color:var(--tt-accent);outline:none}.customer-login-form .error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--tt-radius-sm);color:#b91c1c;font-size:.9rem;padding:12px}.customer-login-form .login-button{background:var(--tt-accent);border:none;border-radius:var(--tt-radius-sm);color:#fff;cursor:pointer;font-family:var(--tt-font);font-size:1rem;font-weight:600;padding:14px;transition:background .2s,transform .2s}.customer-login-form .login-button:hover:not(:disabled){background:var(--tt-accent-hover);transform:translateY(-1px)}.customer-login-form .login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.customer-login-form .register-link{color:var(--tt-text-muted);font-size:.95rem;margin:0;text-align:center}.customer-login-form .register-link a{color:var(--tt-accent);font-weight:600;text-decoration:none}.customer-login-form .register-link a:hover{text-decoration:underline}.customer-dashboard{max-width:1400px}.dashboard-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.dashboard-header h2{color:var(--tt-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0}.btn-add{align-items:center;background:var(--tt-accent);border:none;border-radius:var(--tt-radius-sm);color:#fff;cursor:pointer;display:inline-flex;font-family:var(--tt-font);font-size:.95rem;font-weight:600;justify-content:center;padding:12px 24px;text-decoration:none;transition:background .2s,transform .2s}.btn-add:hover{background:var(--tt-accent-hover);color:#fff;transform:translateY(-1px)}.loading{color:var(--tt-text-muted);font-weight:500;padding:48px;text-align:center}.empty-state{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);padding:64px 24px}.empty-state p{color:var(--tt-text-muted);font-size:1.05rem;margin:0 0 20px}.credits-merged{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);margin-bottom:28px;overflow:hidden}.credits-card.credits-header{align-items:center;background:linear-gradient(135deg,var(--tt-primary) 0,var(--tt-primary-light) 100%);border-radius:0;box-shadow:none;color:#fff;display:flex;flex-wrap:wrap;gap:20px;padding:24px 28px}.credits-panels-row{display:flex;gap:0;height:320px;min-height:0}.credits-panel{border-top:1px solid var(--tt-border);display:flex;flex:1 1;flex-direction:column;min-width:0}.credits-panel:first-child{border-right:1px solid var(--tt-border)}.credits-panel h3{background:var(--tt-surface);color:var(--tt-primary);flex-shrink:0;font-size:1.1rem;font-weight:700;margin:0;padding:16px 20px}.credits-panel-scroll{flex:1 1;min-height:0;overflow-y:auto;padding:0 20px 16px}.credits-panel-empty{color:var(--tt-text-muted);font-size:.95rem;margin:0;padding:24px 0;text-align:center}.credits-card{align-items:center;background:linear-gradient(135deg,var(--tt-primary) 0,var(--tt-primary-light) 100%);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow-lg);color:#fff;display:flex;flex-wrap:wrap;gap:20px;padding:24px 28px}.credits-label{font-size:.9rem;font-weight:500;opacity:.9}.credits-value{font-size:2rem;font-weight:800;letter-spacing:-.02em;margin-right:auto}.btn-request-credits{background:#ffffff26;border:1px solid #ffffff4d;border-radius:var(--tt-radius-sm);color:#fff;cursor:pointer;font-family:var(--tt-font);font-size:.9rem;font-weight:600;padding:12px 20px;transition:background .2s,border-color .2s}.btn-request-credits:hover{background:#ffffff40;border-color:#ffffff80}.modal-overlay{align-items:center;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.request-credits-modal{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow-lg);max-width:400px;padding:28px;width:100%}.request-credits-modal h3{color:var(--tt-primary);font-size:1.25rem;font-weight:700;margin:0 0 20px}.request-credits-modal label{color:var(--tt-text);display:block;font-size:.9rem;font-weight:600;margin-bottom:12px}.request-credits-modal input{border:2px solid var(--tt-border);border-radius:var(--tt-radius-sm);box-sizing:border-box;display:block;font-family:var(--tt-font);font-size:1rem;margin-top:6px;padding:12px 14px;transition:border-color .2s;width:100%}.request-credits-modal input:focus{border-color:var(--tt-accent);outline:none}.form-error{color:#b91c1c;font-size:.875rem;margin:8px 0}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-actions button{border-radius:var(--tt-radius-sm);cursor:pointer;font-family:var(--tt-font);font-size:.95rem;font-weight:600;padding:12px 20px;transition:background .2s,transform .2s}.modal-actions button[type=button]{background:var(--tt-surface);border:2px solid var(--tt-border);color:var(--tt-text)}.modal-actions button[type=submit]{background:var(--tt-accent);border:none;color:#fff}.modal-actions button[type=submit]:hover:not(:disabled){background:var(--tt-accent-hover);transform:translateY(-1px)}.modal-actions button:disabled{cursor:not-allowed;opacity:.6;transform:none}.credits-table{border-collapse:collapse;font-size:.9rem;table-layout:fixed;width:100%}.credits-table thead{background:var(--tt-surface);box-shadow:0 1px 0 var(--tt-border);position:-webkit-sticky;position:sticky;top:0;z-index:1}.credits-table th{color:var(--tt-primary);font-size:.8rem;font-weight:700;letter-spacing:.02em;padding:10px 12px;text-align:left;text-transform:uppercase}.credits-table td{border-bottom:1px solid var(--tt-border);padding:10px 12px;vertical-align:middle}.credits-table tbody tr:last-child td{border-bottom:none}.credits-table tbody tr:hover{background:var(--tt-surface)}.credit-requests-table .col-amount{width:22%}.credit-requests-table .col-status{width:28%}.credit-requests-table .col-date{width:50%}.credit-history-table .col-amount,.credit-history-table .col-type{width:18%}.credit-history-table .col-date{width:28%}.credit-history-table .col-details{width:36%}.credits-table .col-amount{color:var(--tt-primary);font-weight:700;white-space:nowrap}.credits-table .col-date,.credits-table .col-details{color:var(--tt-text-muted);font-size:.85rem;white-space:nowrap}.credits-table .col-details{overflow:hidden;text-overflow:ellipsis}.req-status{border-radius:6px;display:inline-block;font-size:.8rem;font-weight:600;padding:4px 10px;text-transform:capitalize}.req-pending{background:#fffbeb;color:#b45309}.req-approved{background:#ecfdf5;color:#059669}.req-rejected{background:#fef2f2;color:#b91c1c}.tx-type{color:var(--tt-text);font-weight:600;text-transform:capitalize}.credits-negative-banner{background:#fffbeb;border:1px solid #fcd34d;border-radius:var(--tt-radius-sm);color:#b45309}.credits-error-banner,.credits-negative-banner{font-size:.95rem;font-weight:600;margin-bottom:20px;padding:14px 20px}.credits-error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--tt-radius-sm);color:#b91c1c}.promotions-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.promo-card{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);display:flex;flex-direction:column;min-width:0;padding:24px;transition:box-shadow .2s,transform .2s}.promo-card:hover{box-shadow:var(--tt-shadow-lg);transform:translateY(-2px)}.promo-card-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:10px;min-width:0}.promo-card-header h3{color:var(--tt-primary);flex:1 1 auto;font-size:1.15rem;font-weight:700;line-height:1.3;margin:0;min-width:0;overflow-wrap:break-word}.promo-badges{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:8px}.type-badge{white-space:nowrap}.approval-badge{border-radius:6px;font-size:.75rem;font-weight:600;padding:5px 10px}.approval-pending{background:#fffbeb;color:#b45309}.approval-rejected{background:#fef2f2;color:#b91c1c}.promo-brand{font-size:.9rem;margin:0 0 8px}.promo-brand,.promo-dates{color:var(--tt-text-muted);flex-shrink:0}.promo-dates{font-size:.875rem;margin:0;padding-bottom:16px}.promo-pricing{color:var(--tt-accent);flex-shrink:0;font-size:.8rem;margin:0 0 8px}.promo-card-actions{border-top:1px solid var(--tt-border);display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;margin-top:auto;padding-top:16px}.btn-pause,.btn-resume{background:var(--tt-surface);border:2px solid var(--tt-border);border-radius:var(--tt-radius-sm);color:var(--tt-text);cursor:pointer;font-family:var(--tt-font);font-size:.875rem;font-weight:600;padding:10px 16px;transition:background .2s,border-color .2s}.btn-pause:hover,.btn-resume:hover{background:var(--tt-surface-2);border-color:var(--tt-surface-3)}.btn-resume{background:#ecfdf5;border-color:#a7f3d0;color:#059669}.btn-resume:hover{background:#d1fae5;border-color:#6ee7b7}.btn-edit,.btn-stats{border:none;border-radius:var(--tt-radius-sm);cursor:pointer;font-family:var(--tt-font);font-size:.875rem;font-weight:600;padding:10px 16px;text-decoration:none;transition:background .2s,transform .2s}.btn-edit{background:var(--tt-accent);color:#fff}.btn-edit:hover{background:var(--tt-accent-hover);color:#fff;transform:translateY(-1px)}.btn-stats{background:var(--tt-surface);border:2px solid var(--tt-border);color:var(--tt-text)}.btn-stats:hover{background:var(--tt-surface-2);border-color:var(--tt-surface-3);color:var(--tt-text)}@media (max-width:640px){.dashboard-header{align-items:stretch;flex-direction:column}.btn-add{width:100%}.credits-card.credits-header{align-items:flex-start;flex-direction:column;gap:16px}.credits-value{margin-right:0}.credits-panels-row{flex-direction:column;height:auto;max-height:420px}.credits-panel:first-child{border-bottom:1px solid var(--tt-border);border-right:none}.credits-panel{max-height:50%;min-height:160px}.promotions-grid{grid-template-columns:1fr}.promo-card-actions{flex-direction:column}.promo-card-actions .btn-edit,.promo-card-actions .btn-pause,.promo-card-actions .btn-resume,.promo-card-actions .btn-stats{text-align:center;width:100%}}.customer-promotions{max-width:1200px}.customer-promotions-loading{color:var(--tt-text-muted);font-weight:500;padding:48px;text-align:center}.customer-promotions-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.customer-promotions-header h2{color:var(--tt-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0}.btn-add-promo{background:var(--tt-accent);border:none;border-radius:var(--tt-radius-sm);color:#fff;cursor:pointer;font-family:var(--tt-font);font-size:.95rem;font-weight:600;padding:12px 24px;transition:background .2s,transform .2s}.btn-add-promo:hover{background:var(--tt-accent-hover);transform:translateY(-1px)}.create-with-preview{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 380px}.create-form-column,.create-preview-column{min-width:0}.no-promotions{background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);padding:64px 24px;text-align:center}.no-promotions p{color:var(--tt-text-muted);font-size:1.05rem;margin:0 0 20px}.promotions-list-wrap{-webkit-overflow-scrolling:touch;background:var(--tt-card);border:1px solid var(--tt-border);border-radius:var(--tt-radius);box-shadow:var(--tt-shadow);overflow-x:auto;overflow-y:visible}.promotions-table{border-collapse:collapse;min-width:800px;width:100%}.promotions-table td,.promotions-table th{border-bottom:1px solid var(--tt-border);padding:16px 20px;text-align:left}.promotions-table th{background:var(--tt-surface);color:var(--tt-primary);font-size:.85rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.promotions-table td{color:var(--tt-text);font-size:.95rem;vertical-align:middle}.promotions-table tbody tr{transition:background .15s}.promotions-table tbody tr:hover{background:var(--tt-surface)}.promotions-table tbody tr:last-child td{border-bottom:none}.pricing-cell{color:var(--tt-text-muted);font-size:.85rem;max-width:200px;white-space:normal;word-break:break-word}.type-badge{border-radius:6px;display:inline-block;font-size:.75rem;font-weight:600;padding:5px 10px}.type-story{background:var(--tt-secondary-light);color:var(--tt-secondary-hover)}.type-spotlight{background:#f3e8ff;color:#7c3aed}.type-category{background:var(--tt-accent-light);color:var(--tt-accent-hover)}.promotions-table .btn-delete-sm,.promotions-table .btn-edit-sm{border:none;border-radius:var(--tt-radius-sm);cursor:pointer;font-family:var(--tt-font);font-size:.85rem;font-weight:600;margin-right:8px;padding:8px 14px;transition:background .2s,transform .2s}.btn-edit-sm{background:var(--tt-accent);color:#fff}.btn-edit-sm:hover{background:var(--tt-accent-hover);transform:translateY(-1px)}.btn-delete-sm{background:var(--tt-surface);border:2px solid #fecaca;color:#b91c1c}.btn-delete-sm:hover{background:#fef2f2;border-color:#f87171}.preview-placeholder{color:var(--tt-text-muted);font-size:.95rem;padding:40px 20px;text-align:center}@media (max-width:1024px){.create-with-preview{grid-template-columns:1fr}}@media (max-width:768px){.customer-promotions-header{align-items:stretch;flex-direction:column}.btn-add-promo{width:100%}.promotions-list-wrap{overflow-x:auto}.promotions-table{min-width:600px}.promotions-table td,.promotions-table th{padding:12px 14px}}.customer-statistics{max-width:1200px}.customer-stats-loading{color:#666;padding:40px;text-align:center}.customer-stats-header{align-items:center;display:flex;gap:12px;margin-bottom:24px}.customer-stats-header h2{color:#333;font-size:22px;margin:0}.live-badge{background:#e8f5e9;border-radius:20px;color:#2e7d32;font-size:12px;font-weight:500;padding:4px 10px}.empty-state{color:#666;font-size:16px;padding:60px 20px;text-align:center}.empty-state,.stats-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.stats-table-container{margin-bottom:24px;overflow-x:auto}.stats-table{border-collapse:collapse;width:100%}.stats-table td,.stats-table th{border-bottom:1px solid #eee;padding:14px 16px;text-align:left}.stats-table th{background:#f8f8f8;color:#333;font-size:13px;font-weight:600}.stats-table td{color:#333;font-size:14px}.stats-table .promotion-title{color:#3a5a40;font-weight:500}.ctr-badge{border-radius:6px;font-size:12px;font-weight:600;padding:4px 8px}.ctr-badge.high{background:#e8f5e9;color:#2e7d32}.ctr-badge.medium{background:#fff3e0;color:#e65100}.ctr-badge.low{background:#fce4ec;color:#c2185b}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.summary-card{background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.summary-card h3{color:#666;font-size:14px;font-weight:500;margin:0 0 8px}.summary-value{color:#3a5a40;font-size:24px;font-weight:700;margin:0}
/*# sourceMappingURL=main.c50957aa.css.map*/