*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}html{scroll-behavior:smooth}.App{min-height:100vh}.container{margin:0 auto;max-width:1320px;padding:0 20px}.section{padding:80px 0}.section-title{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:20px;text-align:center}.section-subtitle{color:#7f8c8d;font-size:1.1rem;margin-bottom:60px;margin-left:auto;margin-right:auto;max-width:600px;text-align:center}@media (max-width:768px){.section{padding:60px 0}.section-title{font-size:2rem}.section-subtitle{font-size:1rem}}.sticky-banner{animation:slideDown .4s ease-out,gradientShift 8s ease infinite;background:linear-gradient(135deg,#fff,#fffef5 50%,#fefce8);background-size:200% 200%;border-bottom:2px solid #fef3c7;box-shadow:0 4px 12px #0000001a;left:0;position:-webkit-sticky;position:sticky;right:0;top:87px;z-index:999}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.banner-content{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto;max-width:1200px;padding:14px 20px;position:relative}.banner-icon{font-size:22px;margin-right:4px}@keyframes pulse{0%,to{transform:scale(.8)}50%{transform:scale(1.2)}}@keyframes wiggle{0%,to{transform:rotate(0deg) scale(1)}25%{transform:rotate(-10deg) scale(1.1)}75%{transform:rotate(10deg) scale(1.1)}}.banner-text{align-items:center;color:#1f2937;display:flex;flex-wrap:wrap;font-size:15px;font-weight:500;gap:8px;justify-content:center;letter-spacing:.3px;line-height:1.6;text-align:center}.banner-text strong{color:#111827;font-weight:700;white-space:nowrap}.contact-numbers{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.banner-text a{align-items:center;background:#2563eb1a;border-radius:6px;color:#2563eb;display:inline-flex;font-size:14px;font-weight:700;gap:4px;letter-spacing:.3px;padding:6px 10px;text-decoration:none;transition:all .2s ease;white-space:nowrap}.banner-text a:hover{background:#2563eb33;color:#1d4ed8}.phone-icon{animation:phoneZoom 1.5s ease-in-out infinite;display:inline-block}@keyframes phoneZoom{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}@media (max-width:768px){.sticky-banner{position:-webkit-sticky;position:sticky;top:78px}.banner-content{gap:6px;padding:10px 12px}.banner-text{font-size:12px;gap:4px}.banner-text strong{font-size:13px}.banner-text a{font-size:12px;padding:4px 7px}.banner-icon{font-size:18px}}@media (max-width:480px){.banner-content{padding:8px 10px}.banner-text{font-size:11px}.banner-text strong{font-size:12px}.banner-text a{font-size:11px;padding:3px 6px}.banner-icon{font-size:16px}.contact-numbers{gap:4px;width:100%}}.header{background:#fff;box-shadow:0 2px 10px #00000014;left:0;position:fixed;right:0;top:0;z-index:1000}.navbar{align-items:center;display:flex;justify-content:space-between;padding:1rem 0}.logo h1{color:#1f2937;font-size:1.8rem;font-weight:700;margin-bottom:0}.logo span{color:#6b7280;display:block;font-size:.75rem;font-weight:400;margin-top:-5px;min-width:219px}.menu-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;padding:0}.menu-toggle span{background:#1f2937;border-radius:2px;height:3px;margin:3px 0;transition:.3s;width:25px}.nav-menu{display:flex;list-style:none;margin:0}.nav-menu li a{border-radius:5px;color:#1f2937;cursor:pointer;font-size:1rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:color .3s}.nav-menu li a:hover{background:#f3f4f6;color:#2563eb}@media (max-width:768px){.menu-toggle{display:flex}.nav-menu{background:#fff;box-shadow:0 10px 20px #0000001a;flex-direction:column;gap:0;left:-100%;padding:2rem 0;position:fixed;text-align:center;top:70px;transition:.3s;width:100%}.nav-menu.active{left:0}.nav-menu li{padding:.5rem 0}.logo h1{font-size:1.5rem}.logo span{font-size:.65rem}}.hero{align-items:center;background:#f9fafb;display:flex;justify-content:center;margin-top:70px;min-height:100vh;overflow:hidden;position:relative}.hero-bg-image{height:100%;left:0;object-fit:cover;opacity:.39;position:absolute;top:0;width:100%;z-index:0}.hero:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%23fff' fill-opacity='.05' fill-rule='evenodd'/%3E%3C/svg%3E");content:"";opacity:.3}.hero-overlay,.hero:before{bottom:0;left:0;position:absolute;right:0;top:0}.hero-overlay{background:#00000080}.hero-content{color:#fff;padding:2rem;position:relative;text-align:center;z-index:1}.hero-title{animation:fadeInUp 1s ease;color:#fff;font-size:3.5rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px #00000080}.hero-subtitle{animation:fadeInUp 1s ease .2s backwards;color:#fff;font-size:1.5rem;margin-bottom:3rem;text-shadow:1px 1px 3px #00000080}.hero-features{animation:fadeInUp 1s ease .4s backwards;display:flex;flex-wrap:wrap;gap:3rem;justify-content:center;margin-bottom:3rem}.hero-feature{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:15px;box-shadow:0 4px 6px #00000026;color:#1f2937;display:flex;flex-direction:column;font-size:1.1rem;font-weight:500;gap:.5rem;padding:1.5rem 2rem}.feature-icon{font-size:2.5rem}.hero-buttons{animation:fadeInUp 1s ease .6s backwards;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.btn{border:none;border-radius:50px;cursor:pointer;font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:600;padding:1rem 2.5rem;transition:all .3s}.btn-primary{background:#2563eb;box-shadow:0 4px 15px #2563eb4d;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #0000004d;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid #2563eb;color:#2563eb}.btn-secondary:hover{background:#2563eb;color:#fff;transform:translateY(-2px)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.hero{margin-top:60px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.1rem}.hero-features{gap:1rem}.hero-feature{font-size:.9rem;padding:1rem 1.5rem}.feature-icon{font-size:2rem}.hero-buttons{align-items:center;flex-direction:column;width:100%}.btn{max-width:300px;width:100%}}.about-section{background-color:#fff}.about-content{margin:0 auto;max-width:900px}.about-text{line-height:1.8;text-align:left}.about-text h3{color:#1f2937;font-size:1.5rem;font-weight:600;margin-bottom:1rem;margin-top:2rem}.about-text p{text-align:justify}.about-text p,.about-text ul{color:#4b5563;font-size:1rem;margin-bottom:1.5rem}.about-text ul{padding-left:2rem}.about-text ul li{line-height:1.7;margin-bottom:.75rem}.about-text ul li strong{color:#1f2937;font-weight:600}@media (max-width:768px){.about-text h3{font-size:1.25rem}.about-text p,.about-text ul{font-size:.95rem}.about-text ul{padding-left:1.5rem}}.features-section{background:#f8f9fa}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.feature-card{background:#fff;border-radius:15px;box-shadow:0 4px 6px #00000012;padding:2.5rem 2rem;text-align:center;transition:all .3s ease}.feature-card:hover{box-shadow:0 12px 24px #0000001a;transform:translateY(-10px)}.feature-icon{animation:bounce 2s infinite;display:inline-block;font-size:4rem;margin-bottom:1.5rem}.feature-card:nth-child(2n) .feature-icon{animation-delay:.3s}.feature-title{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.feature-description{color:#7f8c8d;font-size:1rem;line-height:1.6}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width:768px){.features-grid{gap:1.5rem;grid-template-columns:1fr}.feature-card{padding:2rem 1.5rem}.feature-icon{font-size:3rem}.feature-title{font-size:1.3rem}}.gallery-section{background:#fff}.gallery-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:3rem}.gallery-item{aspect-ratio:4/3;background:#f3f4f6;border-radius:15px;cursor:pointer;overflow:hidden;position:relative;transition:transform .3s ease}.gallery-image{display:block;height:100%;object-fit:cover;width:100%}.gallery-item:hover{transform:scale(1.05)}.gallery-placeholder{align-items:center;background:#f3f4f6;border:2px solid #e5e7eb;color:#6b7280;display:flex;flex-direction:column;height:100%;justify-content:center;padding:2rem;text-align:center;width:100%}.gallery-icon{font-size:4rem;margin-bottom:1rem}.gallery-placeholder h4{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.gallery-placeholder p{font-size:.9rem;opacity:.9}.gallery-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.gallery-item:hover .gallery-overlay{opacity:1}.view-icon{color:#fff;font-size:1.5rem;font-weight:600}.modal{align-items:center;animation:fadeIn .3s ease;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:2000}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:15px;max-width:1100px;overflow:hidden;position:relative;width:100%}.modal-image{background:#000;display:block;height:auto;max-height:80vh;object-fit:contain;width:100%}.modal-caption{background:#fff;padding:2rem;text-align:center}.modal-caption h3{color:#1f2937;font-size:1.8rem;font-weight:600;margin-bottom:.5rem}.modal-caption p{color:#6b7280;font-size:1.1rem}.modal-close{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 2px 10px #0003;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:transform .2s;width:40px;z-index:10}.modal-close:hover{transform:scale(1.1)}.modal-image-placeholder{align-items:center;aspect-ratio:16/9;background:#f3f4f6;border:2px solid #e5e7eb;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:4rem;text-align:center}.modal-icon{font-size:6rem;margin-bottom:2rem}.modal-image-placeholder h3{font-size:2rem;margin-bottom:1rem}.modal-image-placeholder p{font-size:1.2rem;opacity:.9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.gallery-grid{gap:1rem;grid-template-columns:1fr}.modal{padding:1rem}.modal-image-placeholder{padding:2rem}.modal-icon{font-size:4rem}.modal-image-placeholder h3{font-size:1.5rem}.modal-image-placeholder p{font-size:1rem}}.reviews-section{background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.reviews-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-bottom:4rem;margin-top:3rem}.review-card{background:#fff;border-radius:15px;box-shadow:0 4px 6px #00000012;padding:2rem;transition:all .3s ease}.review-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-5px)}.review-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.reviewer-info{align-items:center;display:flex;gap:1rem}.reviewer-avatar{align-items:center;background:#2563eb;border-radius:50%;color:#fff;display:flex;font-size:1.3rem;font-weight:700;height:50px;justify-content:center;width:50px}.reviewer-name{color:#2c3e50;font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.review-time{color:#95a5a6;font-size:.85rem}.review-rating{font-size:1.2rem}.review-text{color:#555;font-size:1rem;line-height:1.7}.reviews-summary{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:4rem}.summary-card{background:#fff;border-radius:15px;box-shadow:0 4px 6px #00000012;padding:2.5rem;text-align:center;transition:all .3s ease}.summary-card:hover{box-shadow:0 12px 24px #0000001a;transform:scale(1.05)}.summary-number{color:#2563eb;font-size:3rem;font-weight:700;margin-bottom:1rem}.summary-stars{font-size:1.5rem;margin-bottom:.5rem}.summary-icon{font-size:2.5rem;margin-bottom:.5rem}.summary-text{color:#7f8c8d;font-size:1.1rem;font-weight:500}@media (max-width:768px){.reviews-grid{gap:1.5rem;grid-template-columns:1fr}.review-card{padding:1.5rem}.reviewer-avatar{font-size:1.1rem;height:40px;width:40px}.reviewer-name{font-size:1rem}.reviews-summary{gap:1.5rem;grid-template-columns:1fr}.summary-number{font-size:2.5rem}}.contact-section{background:#fff}.contact-content{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin-top:3rem}.contact-info h3{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:2rem}.info-item{background:#f8f9fa;border-radius:10px;display:flex;gap:1.5rem;margin-bottom:2.5rem;padding:1.5rem;transition:all .3s ease}.info-item:hover{background:#e9ecef;transform:translateX(5px)}.info-icon{flex-shrink:0;font-size:2.5rem}.info-item h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.info-item p{color:#7f8c8d;line-height:1.6;margin-bottom:.25rem}.info-item a{color:#2563eb;font-weight:500;text-decoration:none;transition:color .3s}.info-item a:hover{color:#1d4ed8;text-decoration:underline}.contact-form-wrapper{background:#f9fafb;border:1px solid #e5e7eb;border-radius:15px;box-shadow:0 10px 30px #00000014;padding:3rem}.contact-form{gap:1.5rem}.contact-form,.form-group{display:flex;flex-direction:column}.form-group label{color:#374151;font-size:1rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group textarea{background:#fff;border:none;border-radius:8px;font-family:Poppins,sans-serif;font-size:1rem;padding:1rem;transition:all .3s}.form-group input:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #ffffff4d;outline:none}.form-group textarea{min-height:100px;resize:vertical}.char-count{color:#6b7280;font-size:.875rem;margin-top:.25rem;text-align:right}.submit-btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:all .3s}.submit-btn:hover{box-shadow:0 6px 20px #0003;transform:translateY(-2px)}@media (max-width:968px){.contact-content{gap:3rem;grid-template-columns:1fr}.contact-form-wrapper{padding:2rem}.info-item{padding:1rem}.info-icon{font-size:2rem}}.footer{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:4rem 0 2rem}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.footer-section h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem}.footer-section h4{color:#ecf0f1;font-size:1.2rem;font-weight:600;margin-bottom:1rem}.footer-section p{color:#bdc3c7;line-height:1.7;margin-bottom:.5rem}.footer-rating{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.rating-badge{background:#2563eb;border-radius:20px;color:#fff;display:inline-block;font-weight:600;padding:.5rem 1rem;width:-webkit-fit-content;width:fit-content}.footer-section ul{list-style:none;padding:0}.footer-section ul li{color:#bdc3c7;line-height:1.6;margin-bottom:.75rem}.footer-section ul li a{color:#bdc3c7;cursor:pointer;text-decoration:none;transition:color .3s}.footer-section ul li a:hover{color:#93c5fd}.footer-bottom{border-top:1px solid #ffffff1a;padding-top:2rem;text-align:center}.footer-bottom p{color:#95a5a6;margin-bottom:.5rem}.footer-stats{align-items:center;display:flex;font-size:.95rem;gap:1rem;justify-content:center;margin:1rem 0}.stat-item{color:#93c5fd;font-weight:500}.stat-divider{color:#95a5a6}.admin-link-footer{color:#93c5fd;font-weight:500;text-decoration:none;transition:color .3s}.admin-link-footer:hover{color:#60a5fa;text-decoration:underline}@media (max-width:768px){.footer{padding:3rem 0 1.5rem}.footer-content{gap:2rem;grid-template-columns:1fr}.footer-section h3{font-size:1.3rem}.footer-section h4{font-size:1.1rem}}.ad-container{align-items:center;display:flex;flex-direction:column;margin:40px 0;padding:20px 0;width:100%}.ad-label{color:#9ca3af;font-size:11px;font-weight:500;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.ad-slot{align-items:center;background-color:#f9fafb;border:1px dashed #e5e7eb;border-radius:8px;display:flex;justify-content:center;overflow:hidden}.ad-slot-horizontal{max-width:728px;min-height:90px;width:100%}.ad-slot-vertical{min-height:250px;width:300px}.ad-slot-auto{max-width:970px;min-height:250px;width:100%}.ad-placeholder{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:20px;text-align:center}.ad-placeholder p{font-size:14px;font-weight:500;margin:0 0 5px}.ad-placeholder span{color:#d1d5db;font-size:12px}@media (max-width:768px){.ad-container{margin:30px 0}.ad-slot-auto,.ad-slot-horizontal{max-width:100%;min-height:200px}.ad-slot-vertical{max-width:300px;min-height:200px;width:100%}}.dashboard{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:2rem}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:16px;box-shadow:0 8px 24px #00000026;max-width:400px;padding:3rem;text-align:center;width:100%}.login-box h1{color:#1a202c;font-size:2rem;margin:0 0 .5rem}.login-box p{color:#64748b;font-size:.95rem;margin:0 0 2rem}.login-box form{display:flex;flex-direction:column;gap:1rem}.password-input{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:1rem;transition:border-color .3s}.password-input:focus{border-color:#2563eb;outline:none}.login-btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .3s ease}.login-btn:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-2px)}.auth-error{color:#dc2626;font-size:.875rem;margin:-.5rem 0 0}.back-home{color:#64748b;display:inline-block;font-size:.95rem;margin-top:1.5rem;text-decoration:none;transition:color .3s}.back-home:hover{color:#2563eb}.dashboard-header{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.dashboard-header,.header-left{align-items:center;display:flex}.header-left{gap:1.5rem}.dashboard-header h1{color:#1a202c;font-size:2rem;margin:0}.home-link{background:#f8fafc;border-radius:6px;color:#64748b;font-size:.95rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:color .3s}.home-link:hover{background:#eff6ff;color:#2563eb}.refresh-btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.refresh-btn:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-2px)}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.stat-icon{font-size:3rem;line-height:1}.stat-content{flex:1 1}.stat-content h3{color:#64748b;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.stat-number{color:#1a202c;font-size:2rem;font-weight:700;line-height:1;margin:0 0 .25rem}.stat-label{color:#94a3b8;font-size:.875rem}.analytics-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.analytics-section h2{color:#1a202c;font-size:1.5rem;margin:0 0 1.5rem}.table-container{overflow-x:auto}.analytics-table{border-collapse:collapse;width:100%}.analytics-table th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:1rem;text-align:left;text-transform:uppercase}.analytics-table td{border-bottom:1px solid #e2e8f0;color:#1e293b;padding:1rem}.analytics-table tr:hover{background:#f8fafc}.percentage-bar{align-items:center;display:flex;gap:.5rem;width:100%}.percentage-fill{background:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:4px;height:8px;transition:width .3s ease}.percentage-bar span{color:#2563eb;font-weight:600;min-width:45px}.action-detail{color:#64748b;font-size:.875rem}.interaction-badge{background:#dbeafe;color:#1e40af;font-weight:600}.device-badge,.interaction-badge{border-radius:12px;font-size:.875rem;padding:.25rem .75rem}.device-badge{display:inline-block;font-weight:500;text-transform:capitalize}.device-badge[data-device=mobile]{background:#fef3c7;color:#92400e}.device-badge[data-device=desktop]{background:#e0e7ff;color:#3730a3}.message-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.date-cell{white-space:nowrap}.dashboard-footer,.date-cell{color:#64748b;font-size:.875rem}.dashboard-footer{padding:1rem;text-align:center}.dashboard-error,.dashboard-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:50vh}.spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#2563eb;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.dashboard-error p{color:#dc2626;font-size:1.25rem}.dashboard-error button{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 2rem}.dashboard-error button:hover{background:#1d4ed8}@media (max-width:768px){.dashboard{padding:1rem}.login-box{padding:2rem 1.5rem}.login-box h1{font-size:1.5rem}.dashboard-header{flex-direction:column;gap:1rem}.header-left{flex-direction:column;gap:.75rem;width:100%}.dashboard-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-number{font-size:1.75rem}.analytics-section{padding:1rem}.analytics-section h2{font-size:1.25rem}.analytics-table td,.analytics-table th{font-size:.875rem;padding:.75rem .5rem}.message-cell{max-width:150px}}
/*# sourceMappingURL=main.216880e8.css.map*/