:root{--color-primary:#0f172a;--color-primary-light:#1e293b;--color-secondary:#3b82f6;--color-secondary-hover:#2563eb;--color-accent:#10b981;--color-accent-hover:#059669;--color-white:#fff;--color-gray-50:#f8fafc;--color-gray-100:#f1f5f9;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e1;--color-gray-400:#94a3b8;--color-gray-500:#64748b;--color-gray-600:#475569;--color-gray-700:#334155;--color-gray-800:#1e293b;--color-gray-900:#0f172a;--color-success:#10b981;--color-success-bg:#ecfdf5;--color-error:#ef4444;--color-error-bg:#fef2f2;--color-warning:#f59e0b;--color-warning-bg:#fffbeb;--color-info:#3b82f6;--color-info-bg:#eff6ff;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--transition-fast:150ms ease;--transition-normal:200ms ease;--transition-slow:300ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:#f8fafc;background-color:var(--color-gray-50);color:#334155;color:var(--color-gray-700);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:.9375rem;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1 1;width:100%}.container{margin:0 auto;max-width:1280px;padding:0 1.5rem;padding:0 var(--space-6);width:100%}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}h1,h2,h3,h4,h5,h6{color:#0f172a;color:var(--color-gray-900);font-weight:600;line-height:1.3}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.875rem}p{margin-bottom:1rem;margin-bottom:var(--space-4)}a{color:#3b82f6;color:var(--color-secondary);text-decoration:none;transition:color .15s ease;transition:color var(--transition-fast)}a:hover{color:#2563eb;color:var(--color-secondary-hover)}.btn{border:1px solid #0000;border-radius:.5rem;border-radius:var(--radius-lg);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:.875rem;gap:.5rem;gap:var(--space-2);justify-content:center;line-height:1.5;padding:.75rem 1.25rem;padding:var(--space-3) var(--space-5);transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:#0f172a;background-color:var(--color-gray-900);color:var(--color-white)}.btn-primary:hover:not(:disabled){background-color:#1e293b;background-color:var(--color-gray-800)}.btn-secondary{background-color:#fff;background-color:var(--color-white);border-color:#cbd5e1;border-color:var(--color-gray-300);color:#334155;color:var(--color-gray-700)}.btn-secondary:hover:not(:disabled){background-color:#f8fafc;background-color:var(--color-gray-50);border-color:#94a3b8;border-color:var(--color-gray-400)}.btn-accent{background-color:#3b82f6;background-color:var(--color-secondary);color:#fff;color:var(--color-white)}.btn-accent:hover:not(:disabled){background-color:#2563eb;background-color:var(--color-secondary-hover)}.btn-success{background-color:#10b981;background-color:var(--color-accent);color:#fff;color:var(--color-white)}.btn-success:hover:not(:disabled){background-color:#059669;background-color:var(--color-accent-hover)}.btn-danger{background-color:#ef4444;background-color:var(--color-error);color:var(--color-white)}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-ghost{background-color:initial;color:#475569;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background-color:#f1f5f9;background-color:var(--color-gray-100)}.btn-sm{font-size:.8125rem;padding:.5rem .75rem;padding:var(--space-2) var(--space-3)}.btn-lg{font-size:1rem;padding:1rem 1.5rem;padding:var(--space-4) var(--space-6)}.btn-block{width:100%}.btn-icon{height:36px;padding:.5rem;padding:var(--space-2);width:36px}.form-group{margin-bottom:1.25rem}.form-label{color:#334155;color:var(--color-gray-700);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{background-color:#fff;background-color:var(--color-white);border:1px solid #cbd5e1;border:1px solid var(--color-gray-300);border-radius:.5rem;border-radius:var(--radius-lg);color:#0f172a;color:var(--color-gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:.9375rem;padding:.75rem 1rem;padding:var(--space-3) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;border-color:var(--color-secondary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input::placeholder{color:#94a3b8;color:var(--color-gray-400)}.form-input.error{border-color:#ef4444;border-color:var(--color-error)}.form-input.error:focus{box-shadow:0 0 0 3px #ef44441a}.form-error{color:#ef4444;color:var(--color-error)}.form-error,.form-hint{font-size:.8125rem;margin-top:.5rem;margin-top:var(--space-2)}.form-hint{color:#64748b;color:var(--color-gray-500)}.card{background-color:#fff;background-color:var(--color-white);border:1px solid #e2e8f0;border:1px solid var(--color-gray-200);border-radius:.75rem;border-radius:var(--radius-xl);overflow:hidden}.card-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-gray-200);padding:1.25rem 1.5rem;padding:var(--space-5) var(--space-6)}.card-body{padding:1.5rem;padding:var(--space-6)}.card-footer{background-color:#f8fafc;background-color:var(--color-gray-50);border-top:1px solid #e2e8f0;border-top:1px solid var(--color-gray-200);padding:1rem 1.5rem;padding:var(--space-4) var(--space-6)}.alert{border-radius:.5rem;border-radius:var(--radius-lg);font-size:.875rem;padding:1rem;padding:var(--space-4)}.alert-success{background-color:#ecfdf5;background-color:var(--color-success-bg);border:1px solid #a7f3d0;color:#065f46}.alert-error{background-color:#fef2f2;background-color:var(--color-error-bg);color:#991b1b}.alert-warning{background-color:#fffbeb;background-color:var(--color-warning-bg);border:1px solid #fde68a;color:#92400e}.alert-info{background-color:#eff6ff;background-color:var(--color-info-bg);border:1px solid #bfdbfe;color:#1e40af}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:500;padding:.25rem .5rem;padding:var(--space-1) var(--space-2)}.badge-success{background-color:#ecfdf5;background-color:var(--color-success-bg);color:#065f46}.badge-error{background-color:#fef2f2;background-color:var(--color-error-bg);color:#991b1b}.badge-warning{background-color:#fffbeb;background-color:var(--color-warning-bg);color:#92400e}.badge-info{background-color:#eff6ff;background-color:var(--color-info-bg);color:#1e40af}.badge-neutral{background-color:#f1f5f9;background-color:var(--color-gray-100);color:#334155;color:var(--color-gray-700)}.table{border-collapse:collapse;width:100%}.table td,.table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-gray-200);padding:.75rem 1rem;padding:var(--space-3) var(--space-4);text-align:left}.table th{color:#475569;color:var(--color-gray-600);font-size:.8125rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.table tbody tr:hover,.table th{background-color:#f8fafc;background-color:var(--color-gray-50)}.divider{background-color:#e2e8f0;background-color:var(--color-gray-200);height:1px;margin:1.5rem 0;margin:var(--space-6) 0}.grid{grid-gap:1.5rem;grid-gap:var(--space-6);display:grid;gap:1.5rem;gap:var(--space-6)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:.5rem;gap:var(--space-2)}.gap-3{gap:.75rem;gap:var(--space-3)}.gap-4{gap:1rem;gap:var(--space-4)}.gap-6{gap:1.5rem;gap:var(--space-6)}.m-0{margin:0}.mt-2{margin-top:.5rem;margin-top:var(--space-2)}.mt-4{margin-top:1rem;margin-top:var(--space-4)}.mt-6{margin-top:1.5rem;margin-top:var(--space-6)}.mt-8{margin-top:2rem;margin-top:var(--space-8)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--space-2)}.mb-4{margin-bottom:1rem;margin-bottom:var(--space-4)}.mb-6{margin-bottom:1.5rem;margin-bottom:var(--space-6)}.mb-8{margin-bottom:2rem;margin-bottom:var(--space-8)}.p-4{padding:1rem;padding:var(--space-4)}.p-6{padding:1.5rem;padding:var(--space-6)}.p-8{padding:2rem;padding:var(--space-8)}.px-4{padding-left:1rem;padding-left:var(--space-4);padding-right:1rem;padding-right:var(--space-4)}.px-6{padding-left:1.5rem;padding-left:var(--space-6);padding-right:1.5rem;padding-right:var(--space-6)}.py-4{padding-bottom:1rem;padding-bottom:var(--space-4);padding-top:1rem;padding-top:var(--space-4)}.py-6{padding-bottom:1.5rem;padding-bottom:var(--space-6);padding-top:1.5rem;padding-top:var(--space-6)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#64748b;color:var(--color-gray-500)}.text-success{color:#10b981;color:var(--color-success)}.text-error{color:#ef4444;color:var(--color-error)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.hidden{display:none}.empty-state{color:#64748b;color:var(--color-gray-500);padding:3rem 1.5rem;padding:var(--space-12) var(--space-6)}.empty-state-icon{color:#cbd5e1;color:var(--color-gray-300);height:64px;margin:0 auto 1rem;margin:0 auto var(--space-4);width:64px}.empty-state-title{color:#334155;color:var(--color-gray-700);font-size:1.125rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--space-2)}.empty-state-description{color:#64748b;color:var(--color-gray-500);margin-bottom:1.5rem;margin-bottom:var(--space-6)}.spinner{animation:spin .8s linear infinite;border:2px solid #e2e8f0;border-top-color:#3b82f6;border:2px solid var(--color-gray-200);border-radius:50%;border-top-color:var(--color-secondary);height:24px;width:24px}.spinner-lg{border-width:3px;height:40px;width:40px}.overlay{align-items:center;background-color:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;padding:var(--space-4);position:fixed;z-index:1000}.modal{background-color:#fff;background-color:var(--color-white);border-radius:.75rem;border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-gray-200);padding:1.25rem 1.5rem;padding:var(--space-5) var(--space-6)}.modal-body{padding:1.5rem;padding:var(--space-6)}.modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-gray-200);gap:.75rem;padding:1rem 1.5rem;padding:var(--space-4) var(--space-6)}.dropdown{position:relative}.dropdown-menu{background-color:#fff;background-color:var(--color-white);border:1px solid #e2e8f0;border:1px solid var(--color-gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);margin-top:.5rem;margin-top:var(--space-2);min-width:200px;position:absolute;right:0;top:100%;z-index:100}.dropdown-item{color:#334155;display:block;padding:.75rem 1rem;text-align:left;transition:background-color .15s ease}.dropdown-item:hover{background-color:#f8fafc}.dropdown-divider{background-color:#e2e8f0;margin:.5rem 0;margin:var(--space-2) 0}.tabs{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-gray-200);display:flex;gap:.25rem;gap:var(--space-1)}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--color-gray-500);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:.75rem 1rem;padding:var(--space-3) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast)}.tab:hover{color:#334155;color:var(--color-gray-700)}.tab.active{border-bottom-color:#0f172a;border-bottom-color:var(--color-gray-900);color:#0f172a;color:var(--color-gray-900)}.progress{background-color:#e2e8f0;background-color:var(--color-gray-200);border-radius:9999px;border-radius:var(--radius-full);height:8px;overflow:hidden;width:100%}.progress-bar{background-color:#3b82f6;background-color:var(--color-secondary);height:100%;transition:width .3s ease;transition:width var(--transition-slow)}.avatar{align-items:center;background-color:#e2e8f0;background-color:var(--color-gray-200);border-radius:9999px;border-radius:var(--radius-full);color:#475569;color:var(--color-gray-600);display:flex;font-size:.875rem;font-weight:600;height:40px;justify-content:center;width:40px}.avatar-sm{font-size:.75rem;height:32px;width:32px}.avatar-lg{font-size:1.125rem;height:56px;width:56px}.stat-card{padding:1.25rem}.stat-label{margin-bottom:.25rem;margin-bottom:var(--space-1)}.stat-value{color:#0f172a}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.container{padding:0 1rem;padding:0 var(--space-4)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}h1{font-size:1.5rem}h2{font-size:1.25rem}.hide-mobile{display:none}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9;background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--color-gray-300);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--color-gray-400)}.error-boundary{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.error-boundary-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;max-width:600px;padding:3rem;text-align:center;width:100%}.error-icon{font-size:4rem;margin-bottom:1rem}.error-title{color:#333;font-size:2rem;font-weight:700;margin:0 0 1rem}.error-message{font-size:1.1rem;margin:0 0 2rem}.error-details{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin:2rem 0;padding:1rem;text-align:left}.error-summary{color:#667eea;cursor:pointer;font-size:.95rem;font-weight:600;padding:.5rem;-webkit-user-select:none;user-select:none}.error-summary:hover{color:#764ba2}.error-stack{border-top:1px solid #dee2e6;margin-top:1rem;padding-top:1rem}.error-stack p{color:#495057;font-size:.9rem;margin:0 0 1rem}.error-stack pre{word-wrap:break-word;background:#fff;border:1px solid #dee2e6;border-radius:4px;color:#dc3545;font-size:.85rem;overflow-x:auto;padding:1rem;white-space:pre-wrap}.error-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.error-button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s}.error-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.error-button.primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.error-button.secondary{background:#f8f9fa;border:2px solid #667eea;color:#667eea}.error-button.secondary:hover{background:#667eea;color:#fff}.error-help{border-top:1px solid #eee;padding-top:2rem}.error-help p{color:#666;font-size:.9rem;margin:0}.error-help a{color:#667eea;font-weight:600;text-decoration:none}.error-help a:hover{text-decoration:underline}@media (max-width:768px){.error-boundary-content{padding:2rem}.error-title{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column}.error-button{width:100%}}.navbar{background-color:var(--color-white);border-bottom:1px solid var(--color-gray-200);position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-container{height:64px;justify-content:space-between;margin:0 auto;max-width:1280px;padding:0 var(--space-6)}.navbar-container,.navbar-left{align-items:center;display:flex}.navbar-left{gap:var(--space-8)}.navbar-brand{align-items:center;display:flex;font-size:1.125rem;font-weight:600;gap:var(--space-3);text-decoration:none}.navbar-brand,.navbar-brand svg{color:var(--color-gray-900)}.navbar-logo{height:32px;object-fit:contain;width:32px}.navbar-nav{align-items:center;display:flex;gap:var(--space-1)}.nav-link{border-radius:var(--radius-md);color:var(--color-gray-600);font-size:.875rem;font-weight:500;padding:var(--space-2) var(--space-3);text-decoration:none;transition:all var(--transition-fast)}.nav-link.active,.nav-link:hover{background-color:var(--color-gray-100);color:var(--color-gray-900)}.navbar-right{align-items:center;display:flex;gap:var(--space-4)}.navbar-user{position:relative}.user-trigger{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-2);transition:all var(--transition-fast)}.user-trigger:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-200)}.user-avatar{align-items:center;background-color:var(--color-gray-900);border-radius:var(--radius-full);color:var(--color-white);display:flex;font-size:.8125rem;font-weight:600;height:36px;justify-content:center;width:36px}.user-info{align-items:flex-start;display:flex;flex-direction:column;text-align:left}.user-name{color:var(--color-gray-900);font-size:.875rem;font-weight:500;line-height:1.2}.user-email{color:var(--color-gray-500);font-size:.75rem;line-height:1.2}.chevron{color:var(--color-gray-400)}.user-dropdown{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-width:240px;overflow:hidden;position:absolute;right:0;top:calc(100% + var(--space-2));z-index:200}.dropdown-header{align-items:center;background-color:var(--color-gray-50);display:flex;gap:var(--space-3);padding:var(--space-4)}.dropdown-avatar{align-items:center;background-color:var(--color-gray-900);border-radius:var(--radius-full);color:var(--color-white);display:flex;height:40px;justify-content:center;width:40px}.dropdown-avatar,.dropdown-name{font-size:.875rem;font-weight:600}.dropdown-name{color:var(--color-gray-900)}.dropdown-email{color:var(--color-gray-500);font-size:.75rem}.dropdown-divider{background-color:var(--color-gray-200);height:1px}.dropdown-item{align-items:center;background:none;border:none;color:var(--color-gray-700);cursor:pointer;display:flex;font-size:.875rem;gap:var(--space-3);padding:var(--space-3) var(--space-4);text-decoration:none;transition:background-color var(--transition-fast);width:100%}.dropdown-item:hover{background-color:var(--color-gray-50)}.dropdown-item svg{color:var(--color-gray-400)}.dropdown-item.logout,.dropdown-item.logout svg{color:var(--color-error)}.dropdown-item.admin-link{background:#f5f3ff;color:#7c3aed}.dropdown-item.admin-link:hover{background:#ede9fe}.dropdown-item.admin-link svg{color:#7c3aed}.mobile-menu-item.admin-link{background:#f5f3ff;color:#7c3aed;font-weight:500}.mobile-menu-btn{background:none;border:none;color:var(--color-gray-600);cursor:pointer}.mobile-menu,.mobile-menu-btn{display:none;padding:var(--space-2)}.mobile-menu{border-top:1px solid var(--color-gray-200)}.mobile-menu-item{border-radius:var(--radius-md);color:var(--color-gray-700);display:block;font-size:.9375rem;padding:var(--space-3) var(--space-4);text-decoration:none}.mobile-menu-item:hover{background-color:var(--color-gray-100)}.hide-mobile{display:flex}.show-mobile{display:none}@media (max-width:768px){.navbar-container{padding:0 var(--space-4)}.hide-mobile{display:none!important}.mobile-menu-btn,.show-mobile{display:flex}.mobile-menu{display:block}.user-trigger{padding:var(--space-1)}}.footer{background:linear-gradient(135deg,#2d3748,#1a202c);color:#e2e8f0;margin-top:auto}.footer-container{margin:0 auto;max-width:1400px;padding:3rem 2rem 1rem}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.footer-section{display:flex;flex-direction:column;gap:1rem}.footer-brand{align-items:center;display:flex;gap:.75rem}.footer-logo{height:40px;object-fit:contain;width:40px}.footer-title{color:#fff;font-size:1.25rem;font-weight:700;margin:0}.footer-description{color:#cbd5e0;font-size:.9rem;line-height:1.5;margin:0}.footer-heading{color:#fff;font-size:1rem;font-weight:600;margin:0}.footer-links{display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0;padding:0}.footer-links li a{color:#cbd5e0;font-size:.9rem;text-decoration:none;transition:color .2s}.footer-links li a:hover{color:#667eea}.footer-bottom{align-items:center;border-top:1px solid #4a5568;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding-top:2rem}.footer-copyright p{color:#cbd5e0;font-size:.9rem;margin:0}.footer-social{display:flex;gap:1.5rem}.social-link{color:#cbd5e0;font-size:.9rem;text-decoration:none;transition:color .2s}.social-link:hover{color:#667eea}@media (max-width:768px){.footer-container{padding:2rem 1rem 1rem}.footer-content{gap:1.5rem;grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}}.loading-spinner-fullscreen{background:#fffffff2;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:9999}.loading-spinner-container,.loading-spinner-fullscreen{align-items:center;display:flex;flex-direction:column;justify-content:center}.loading-spinner-container{padding:2rem}.spinner{display:inline-block;position:relative}.spinner-small{height:30px;width:30px}.spinner-medium{height:50px;width:50px}.spinner-large{height:80px;width:80px}.spinner-ring{animation:spin 1.5s cubic-bezier(.68,-.55,.265,1.55) infinite;border:3px solid #0000;border-radius:50%;border-top-color:#667eea;height:100%;position:absolute;width:100%}.spinner-ring:nth-child(2){animation-delay:-.375s;border-top-color:#764ba2}.spinner-ring:nth-child(3){animation-delay:-.75s;border-top-color:#f093fb}.spinner-ring:nth-child(4){animation-delay:-1.125s;border-top-color:#4facfe}.loading-message{color:#667eea;font-size:1rem;font-weight:500;margin-top:1.5rem;text-align:center}.auth-page{background-color:var(--color-gray-50);justify-content:center;min-height:100vh;padding:var(--space-6)}.auth-container,.auth-page{align-items:center;display:flex}.auth-container{gap:var(--space-16);max-width:900px;width:100%}.auth-card{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);flex:1 1;max-width:400px;padding:var(--space-8)}.auth-header{margin-bottom:var(--space-8);text-align:center}.auth-logo{align-items:center;display:inline-flex;height:80px;justify-content:center;margin-bottom:var(--space-4);width:80px}.auth-logo img{height:100%;object-fit:contain;width:100%}.auth-header h1{color:var(--color-gray-900);font-size:1.5rem;font-weight:600;margin-bottom:var(--space-2)}.auth-header p{color:var(--color-gray-500);font-size:.9375rem;margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.auth-form .form-group{margin-bottom:0}.auth-form .alert{align-items:center;display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.auth-form .alert svg{flex-shrink:0}.auth-footer{border-top:1px solid var(--color-gray-200);margin-top:var(--space-6);padding-top:var(--space-6);text-align:center}.auth-footer p{color:var(--color-gray-500);font-size:.875rem;margin:0}.auth-footer a{color:var(--color-gray-900);font-weight:500}.auth-footer a:hover{color:var(--color-secondary)}.auth-features{display:flex;flex:1 1;flex-direction:column;gap:var(--space-6)}.feature-item{align-items:flex-start;gap:var(--space-4)}.feature-item svg{color:var(--color-gray-400)}.feature-item h4{color:var(--color-gray-900);font-size:1rem;font-weight:600;margin-bottom:var(--space-1)}.feature-item p{color:var(--color-gray-500);font-size:.875rem;line-height:1.5;margin:0}.auth-form .btn{position:relative}.auth-form .btn .spinner{border-width:2px;height:18px;width:18px}.form-row .form-group{margin-bottom:0}.form-divider{margin:var(--space-2) 0}.form-divider:after,.form-divider:before{border-bottom:1px solid var(--color-gray-200);content:"";flex:1 1}.form-divider span{color:var(--color-gray-400);font-size:.8125rem;padding:0 var(--space-4)}@media (max-width:768px){.auth-container{flex-direction:column;gap:var(--space-8)}.auth-card{max-width:100%}.auth-features{display:none}.form-row{grid-template-columns:1fr}}@media (max-width:480px){.auth-page{padding:var(--space-4)}.auth-card{padding:var(--space-6)}}.dashboard{margin:0 auto;max-width:1280px;padding:var(--space-6)}.dashboard-loading{align-items:center;display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;min-height:60vh}.dashboard-loading p{color:var(--color-gray-500);font-size:.9375rem}.page-header{margin-bottom:var(--space-6)}.page-header-content{align-items:flex-start;display:flex;gap:var(--space-4);justify-content:space-between}.page-title-section h1{color:var(--color-gray-900);font-size:1.75rem;font-weight:600;margin:0 0 var(--space-1) 0}.page-subtitle{color:var(--color-gray-500);font-size:.9375rem;margin:0}.page-actions{display:flex;gap:var(--space-3)}.connection-indicator{align-items:center;background-color:var(--color-gray-50);border-radius:var(--radius-full);display:inline-flex;gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-2) var(--space-3)}.status-dot{border-radius:var(--radius-full);height:8px;width:8px}.status-dot.connected{background-color:var(--color-success);box-shadow:0 0 0 2px #10b98133}.status-dot.disconnected{background-color:var(--color-gray-400)}.status-text{color:var(--color-gray-600);font-size:.75rem;font-weight:500}.stories-link-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-xl);color:#fff;margin-bottom:var(--space-6);padding:var(--space-5)}.stories-link-header{align-items:flex-start;display:flex;gap:var(--space-4);margin-bottom:var(--space-4)}.stories-link-icon{align-items:center;background:#fff3;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stories-link-info h3{font-size:1.125rem;font-weight:600;margin:0 0 var(--space-1) 0}.stories-link-info p{font-size:.875rem;margin:0;opacity:.9}.stories-link-content{display:flex;flex-direction:column;gap:var(--space-3)}.stories-link-input{background:#ffffff26;border-radius:var(--radius-lg);display:flex;gap:var(--space-2);padding:var(--space-2)}.stories-link-input input{background:#0000;border:none;color:#fff;flex:1 1;font-size:.9375rem;outline:none;padding:var(--space-2) var(--space-3)}.stories-link-input input::selection{background:#ffffff4d}.btn-copy{align-items:center;background:#fff;border-radius:var(--radius-md);color:#667eea;display:flex;font-size:.875rem;gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);white-space:nowrap}.btn-copy:hover{background:#ffffffe6;transform:scale(1.02)}.btn-copy.copied{background:#10b981;color:#fff}.stories-preview-link{align-items:center;color:#ffffffe6;display:inline-flex;font-size:.875rem;gap:var(--space-2);text-decoration:none;transition:all var(--transition-fast)}.stories-preview-link:hover{color:#fff;text-decoration:underline}.stats-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-8)}.stat-card{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);gap:var(--space-4);padding:var(--space-5)}.stat-icon{background-color:var(--color-gray-100);border-radius:var(--radius-lg);color:var(--color-gray-600)}.stat-icon-success{background-color:#10b9811a;color:var(--color-success)}.stat-icon-primary{background-color:#3b82f61a;color:var(--color-secondary)}.stat-icon-info{background-color:#6366f11a;color:#6366f1}.stat-content{display:flex;flex-direction:column}.stat-value{color:var(--color-gray-900);font-size:1.5rem;font-weight:600;line-height:1.2}.stat-label{color:var(--color-gray-500);font-size:.8125rem;margin-top:var(--space-1)}.section{margin-bottom:var(--space-8)}.section-header{margin-bottom:var(--space-4)}.section-header h2{color:var(--color-gray-900);font-size:1.125rem;font-weight:600}.section-link{align-items:center;color:var(--color-secondary);display:flex;font-size:.875rem;font-weight:500;gap:var(--space-1);text-decoration:none;transition:color var(--transition-fast)}.section-link:hover{color:var(--color-gray-900)}.events-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(3,1fr)}.event-card{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--space-5);transition:all var(--transition-fast)}.event-card:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md)}.event-card-header{margin-bottom:var(--space-3)}.event-card-title{align-items:flex-start;display:flex;gap:var(--space-3);justify-content:space-between}.event-card-title h3{color:var(--color-gray-900);font-size:1rem;font-weight:600;line-height:1.4;margin:0}.event-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-gray-500);display:-webkit-box;font-size:.875rem;line-height:1.5;margin:0 0 var(--space-4) 0;overflow:hidden}.event-meta{border-bottom:1px solid var(--color-gray-100);display:flex;gap:var(--space-4);margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.meta-item{align-items:center;color:var(--color-gray-500);display:flex;font-size:.8125rem;gap:var(--space-2)}.meta-item svg{color:var(--color-gray-400)}.event-card-actions{display:flex;gap:var(--space-2)}.quick-actions{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr)}.quick-action-card{align-items:center;background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);text-decoration:none;transition:all var(--transition-fast)}.quick-action-card:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-action-icon{align-items:center;background-color:var(--color-gray-100);border-radius:var(--radius-xl);color:var(--color-gray-600);display:flex;height:56px;justify-content:center;transition:all var(--transition-fast);width:56px}.quick-action-card:hover .quick-action-icon{background-color:var(--color-gray-900);color:var(--color-white)}.quick-action-card span{color:var(--color-gray-700);font-size:.875rem;font-weight:500}.empty-state{background-color:var(--color-white);border:1px dashed var(--color-gray-300);border-radius:var(--radius-xl);padding:var(--space-12)}.empty-icon{background-color:var(--color-gray-100);border-radius:var(--radius-full);color:var(--color-gray-400);margin-bottom:var(--space-4)}.empty-state h3{color:var(--color-gray-900);font-size:1.125rem;margin:0 0 var(--space-2) 0}.empty-state p{color:var(--color-gray-500);font-size:.9375rem;margin:0 0 var(--space-6) 0;max-width:320px}@media (max-width:1024px){.events-grid,.quick-actions,.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard{padding:var(--space-4)}.page-header-content{align-items:stretch;flex-direction:column}.page-actions{width:100%}.page-actions .btn{justify-content:center;width:100%}.stories-link-card{padding:var(--space-4)}.stories-link-header{gap:var(--space-3)}.stories-link-header,.stories-link-input{flex-direction:column}.stories-link-input input{font-size:.8125rem}.btn-copy{justify-content:center}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-4)}.events-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,1fr)}.quick-action-card{padding:var(--space-4)}.quick-action-icon{height:48px;width:48px}}@media (max-width:480px){.page-title-section h1{font-size:1.5rem}.quick-actions{grid-template-columns:1fr}}.events-page{margin:0 auto;max-width:1280px;padding:var(--space-6)}.events-loading{align-items:center;display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;min-height:60vh}.events-loading p{color:var(--color-gray-500);font-size:.9375rem}.alert-close{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;justify-content:center;margin-left:auto;opacity:.7;padding:var(--space-1);transition:opacity var(--transition-fast)}.alert-close:hover{opacity:1}.events-table-container{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);overflow:hidden}.events-table{border-collapse:collapse;width:100%}.events-table th{background-color:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-500);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:var(--space-4);text-align:left;text-transform:uppercase}.events-table td{border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700);font-size:.875rem;padding:var(--space-4);vertical-align:middle}.events-table tbody tr:last-child td{border-bottom:none}.events-table tbody tr:hover{background-color:var(--color-gray-50)}.event-cell{display:flex;flex-direction:column;gap:var(--space-1)}.event-name{color:var(--color-gray-900);font-weight:500}.event-desc{-webkit-line-clamp:1;-webkit-box-orient:vertical;color:var(--color-gray-500);display:-webkit-box;font-size:.8125rem;overflow:hidden}.photo-count{color:var(--color-gray-900)}.date-text,.time-text{color:var(--color-gray-500)}.time-text{font-size:.8125rem;white-space:nowrap}.ftp-folder{background-color:var(--color-gray-100);border-radius:var(--radius-sm);color:var(--color-gray-600);font-family:var(--font-mono);font-size:.75rem;padding:var(--space-1) var(--space-2)}.table-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.btn-danger-outline{border-color:var(--color-error);color:var(--color-error)}.btn-danger-outline:hover{background-color:var(--color-error);color:var(--color-white)}.input-group{display:flex;gap:var(--space-2)}.input-group .form-input{flex:1 1}.form-divider{align-items:center;display:flex;margin:var(--space-6) 0 var(--space-4) 0}.form-divider span{background-color:var(--color-white);color:var(--color-gray-500);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:0 var(--space-3) 0 0;text-transform:uppercase}.form-divider:after{background-color:var(--color-gray-200);content:"";flex:1 1;height:1px}.form-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:1fr 1fr}.info-box{align-items:flex-start;border-radius:var(--radius-lg);display:flex;font-size:.8125rem;gap:var(--space-3);line-height:1.5;margin-top:var(--space-4);padding:var(--space-3) var(--space-4)}.info-box svg{flex-shrink:0;margin-top:2px}.info-box-tip{background-color:#e0f2fe;border:1px solid #7dd3fc;color:#0369a1}.info-box-tip svg{color:#0ea5e9}.event-info-box{background-color:var(--color-gray-50);border-radius:var(--radius-lg);margin-top:var(--space-6);padding:var(--space-4)}.event-info-box h4{color:var(--color-gray-700);font-size:.875rem;font-weight:600;margin:0 0 var(--space-3) 0}.info-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.info-item{display:flex;flex-direction:column;gap:var(--space-1)}.info-label{color:var(--color-gray-500);font-size:.75rem;font-weight:500}.info-value{color:var(--color-gray-900);font-size:.875rem;font-weight:500}.spinner-sm{border-width:2px;height:16px;width:16px}@media (max-width:1024px){.events-table td:nth-child(5),.events-table td:nth-child(6),.events-table th:nth-child(5),.events-table th:nth-child(6){display:none}.form-row{grid-template-columns:1fr}}@media (max-width:768px){.events-page{padding:var(--space-4)}.page-header-content{align-items:stretch;flex-direction:column}.page-actions{width:100%}.page-actions .btn{justify-content:center;width:100%}.events-table-container{overflow-x:auto}.events-table{min-width:500px}.events-table td,.events-table th{padding:var(--space-3)}.table-actions{flex-wrap:wrap}.modal{margin:var(--space-4);max-height:calc(100vh - var(--space-8))}.info-grid{grid-template-columns:1fr}}@media (max-width:480px){.events-table td:nth-child(3),.events-table th:nth-child(3){display:none}}.ftp-settings-container{background:#f7fafc;min-height:100vh}.ftp-settings-header{background:#fff;box-shadow:0 1px 3px #0000001a;padding:16px 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.ftp-settings-header .header-content{align-items:center;display:flex;justify-content:space-between}.ftp-settings-header h1{color:#1a202c;font-size:24px;font-weight:700;margin:0}.ftp-settings-main{padding:32px 0}.settings-content{margin:0 auto;max-width:800px}.alert{padding:16px 20px}.alert h3{font-size:16px;font-weight:600;margin:0 0 8px}.alert p{font-size:14px;line-height:1.5;margin:0}.alert-info{background:#bee3f8;border:1px solid #90cdf4;color:#2c5282}.alert-warning{background:#feebc8;border:1px solid #fbd38d;color:#744210}.alert-warning h4{font-size:14px;font-weight:600;margin:0 0 12px}.alert-warning ul{margin:0;padding-left:20px}.alert-warning li{font-size:13px;line-height:1.5;margin-bottom:8px}.settings-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin-bottom:32px}.setting-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px}.setting-card.full-width{grid-column:1/-1}.setting-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.setting-header label{color:#718096;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.btn-copy{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s}.btn-copy:hover{background:#5a67d8}.setting-value{color:#2d3748;font-size:16px}.setting-value code{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:block;font-family:Courier New,monospace;font-size:14px;padding:8px 12px;word-break:break-all}.setting-hint{color:#718096;display:block;font-size:12px;line-height:1.4;margin-top:8px}.advanced-settings{margin-bottom:32px}.advanced-settings h3{color:#2d3748;font-size:18px;font-weight:600;margin:0 0 16px}.settings-actions{display:flex;gap:12px;justify-content:flex-end;margin-bottom:32px}@media (max-width:768px){.settings-grid{grid-template-columns:1fr}.setting-card.full-width{grid-column:1}.settings-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.event-stats-container{background:#f7fafc;min-height:100vh}.event-stats-header{background:#fff;box-shadow:0 1px 3px #0000001a;padding:16px 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.event-stats-header .header-content{align-items:center;display:flex;justify-content:space-between}.event-stats-header h1{color:#1a202c;font-size:24px;font-weight:700;margin:0 0 4px}.event-description{color:#718096;font-size:14px;margin:0}.event-stats-main{padding:32px 0}.stats-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.connection-status{align-items:center;background:#fff;border-radius:20px;color:#2d3748;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px}.status-dot{border-radius:50%;height:10px;width:10px}.status-dot.connected{background:#48bb78;box-shadow:0 0 8px #48bb7880}.status-dot.disconnected{background:#718096}.stats-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.stat-card{padding:24px}.stat-icon{background:#f0f4ff;color:#667eea;flex-shrink:0;height:56px;width:56px}.stat-icon svg{height:28px;width:28px}.stat-content h3{color:#718096;font-size:14px;font-weight:500;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-value{color:#2d3748;margin:0}.stat-value.active{color:#48bb78}.stat-value.inactive{color:#e53e3e}.stat-value-small{color:#2d3748;font-size:14px;font-weight:600;margin:0;word-break:break-all}.photos-section{margin-top:40px}.photos-section h2{color:#1a202c;font-size:24px;font-weight:700;margin:0 0 24px}.empty-state,.loading-state{background:#fff;border-radius:12px;padding:60px 20px;text-align:center}.empty-state p{color:#718096;margin:0}.photos-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.photo-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;cursor:pointer;overflow:hidden;transition:all .2s}.photo-card:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-4px)}.photo-thumbnail{background:#e2e8f0;padding-bottom:100%;position:relative;width:100%}.photo-thumbnail img{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.photo-info{padding:12px}.photo-filename{color:#2d3748;font-size:13px;margin:0 0 4px}.photo-date{color:#718096;font-size:11px;margin:0}.photo-modal{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.photo-modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:1000px;overflow:auto;position:relative;width:100%}.modal-close{background:#fff;border-radius:50%;box-shadow:0 2px 8px #0003;color:#2d3748;font-size:24px;height:40px;transition:all .2s;width:40px;z-index:10}.modal-close:hover{background:#e53e3e;color:#fff}.modal-image{align-items:center;background:#000;display:flex;justify-content:center;width:100%}.modal-image img{height:auto;max-height:60vh;object-fit:contain;width:100%}.modal-info{padding:24px}.modal-info h3{color:#2d3748;font-size:18px;font-weight:600;margin:0 0 16px;word-break:break-all}.modal-details{grid-gap:12px;background:#f7fafc;border-radius:8px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px;padding:16px}.modal-details p{color:#2d3748;font-size:14px;margin:0}.modal-details strong{color:#718096;font-weight:500}.btn-secondary{padding:10px 20px;text-decoration:none}.btn-danger{background:#e53e3e;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.btn-danger:hover{background:#c53030}.alert{font-size:14px;margin-bottom:24px}.alert-error{background:#fed7d7;border:1px solid #fc8181;color:#742a2a}@media (max-width:768px){.stats-cards{grid-template-columns:1fr}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.modal-actions{flex-direction:column}.btn-danger,.btn-secondary{width:100%}}.pricing-plans{margin:0 auto;max-width:1000px;padding:20px 15px}.pricing-header{margin-bottom:20px;text-align:center}.pricing-header h2{color:#333;font-size:1.75rem;margin-bottom:6px}.pricing-header p{color:#666;font-size:.95rem;margin-bottom:15px}.pricing-toggle{background:#f5f5f5;border-radius:50px;display:inline-flex;gap:3px;padding:3px}.pricing-toggle button{background:#0000;border:none;border-radius:50px;color:#666;cursor:pointer;font-size:.85rem;padding:6px 16px;transition:all .3s}.pricing-toggle button.active{background:#007bff;color:#fff}.discount-badge{background:#28a745;border-radius:10px;color:#fff;font-size:.7rem;margin-left:4px;padding:2px 6px}.pricing-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);margin-top:20px}.pricing-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;display:flex;flex-direction:column;padding:16px;position:relative;transition:all .3s}.pricing-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-3px)}.pricing-card.highlighted{border-color:#007bff;box-shadow:0 4px 15px #007bff33}.pricing-card.current{border-color:#28a745}.current-badge,.popular-badge{background:#007bff;border-radius:15px;color:#fff;font-size:.7rem;font-weight:600;left:50%;padding:3px 12px;position:absolute;top:-10px;transform:translateX(-50%);white-space:nowrap}.current-badge{background:#28a745}.plan-header{margin-bottom:12px;text-align:center}.plan-header h3{color:#333;font-size:1.1rem;margin-bottom:8px}.plan-price{align-items:baseline;display:flex;gap:3px;justify-content:center}.price-amount{color:#007bff;font-size:1.75rem;font-weight:700}.price-period{color:#666;font-size:.85rem}.plan-features{flex:1 1;margin-bottom:12px}.plan-features ul{list-style:none;margin:0;padding:0}.plan-features li{align-items:center;border-bottom:1px solid #f0f0f0;color:#555;display:flex;font-size:.85rem;gap:8px;padding:6px 0}.plan-features li:last-child{border-bottom:none}.feature-icon{align-items:center;display:flex;justify-content:center}.feature-icon svg{height:14px;width:14px}.plan-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px;transition:all .3s;width:100%}.plan-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.plan-button:disabled{background:#ccc;cursor:not-allowed}.plan-button.highlighted{background:linear-gradient(135deg,#007bff,#0056b3);box-shadow:0 3px 10px #007bff4d}.pricing-footer{color:#666;font-size:.85rem;margin-top:25px;text-align:center}.pricing-footer p{margin:6px 0}.pricing-footer a{color:#007bff;text-decoration:none}.pricing-footer a:hover{text-decoration:underline}.pricing-loading{color:#666;padding:60px 20px;text-align:center}@media (max-width:900px){.pricing-grid{gap:10px;grid-template-columns:repeat(3,1fr)}.pricing-card{padding:12px}.plan-features li{font-size:.8rem}}@media (max-width:700px){.pricing-grid{grid-template-columns:1fr;margin-left:auto;margin-right:auto;max-width:350px}.price-amount,.pricing-header h2{font-size:1.5rem}}.billing-dashboard{margin:0 auto;max-width:1200px;padding:40px 20px}.billing-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.billing-header h2{color:#333;font-size:2rem;margin:0}.btn-manage-billing{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:all .3s}.btn-manage-billing:hover:not(:disabled){background:#0056b3;transform:translateY(-2px)}.btn-manage-billing:disabled{background:#ccc;cursor:not-allowed}.billing-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:30px}.billing-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.billing-card h3{color:#333;font-size:1.5rem;margin-bottom:20px}.plan-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.plan-name{color:#007bff;font-size:2rem;font-weight:700}.status-badge{font-size:.85rem;padding:6px 16px;text-transform:uppercase}.status-badge.success{background:#d4edda;color:#155724}.status-badge.info{background:#d1ecf1;color:#0c5460}.status-badge.danger{background:#f8d7da;color:#721c24}.cancel-notice,.status-badge.warning{background:#fff3cd;color:#856404}.cancel-notice{border-radius:8px;margin-bottom:20px;padding:12px;text-align:center}.plan-details{border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0;margin-bottom:20px;padding:20px 0}.detail-row{color:#666;display:flex;justify-content:space-between;padding:8px 0}.detail-row span:first-child{font-weight:500}.plan-actions{display:flex;gap:10px}.btn-cancel,.btn-reactivate{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;padding:12px;transition:all .3s}.btn-cancel{background:#dc3545;color:#fff}.btn-cancel:hover:not(:disabled){background:#c82333}.btn-reactivate{background:#28a745;color:#fff}.btn-reactivate:hover:not(:disabled){background:#218838}.no-subscription{padding:40px 20px;text-align:center}.no-subscription p{color:#666;margin-bottom:20px}.btn-upgrade{background:#007bff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;padding:12px 30px;transition:all .3s}.btn-upgrade:hover{background:#0056b3}.usage-list{gap:20px}.usage-item,.usage-list{display:flex;flex-direction:column}.usage-item{gap:8px}.usage-header{align-items:center;display:flex;justify-content:space-between}.usage-label{color:#333;font-weight:500}.usage-value{color:#666;font-size:.9rem}.usage-bar{background:#e0e0e0;border-radius:4px;height:8px;overflow:hidden}.usage-fill{background:linear-gradient(90deg,#007bff,#0056b3);height:100%;transition:width .3s ease}.usage-fill.warning{background:linear-gradient(90deg,#ffc107,#ff9800)}.invoices-table{overflow-x:auto}.invoices-table table{border-collapse:collapse;width:100%}.invoices-table td,.invoices-table th{border-bottom:1px solid #e0e0e0;padding:12px;text-align:left}.invoices-table th{background:#f8f9fa;color:#333;font-weight:600}.invoices-table td{color:#666}.invoice-link{color:#007bff;text-decoration:none}.invoice-link:hover{text-decoration:underline}.no-invoices{color:#666;padding:40px 20px;text-align:center}.billing-loading{color:#666;padding:100px 20px;text-align:center}@media (max-width:768px){.billing-grid{grid-template-columns:1fr}.billing-header{align-items:flex-start;flex-direction:column;gap:15px}.btn-manage-billing{width:100%}.plan-info{align-items:flex-start;flex-direction:column;gap:10px}.detail-row{gap:5px}.detail-row,.plan-actions{flex-direction:column}.invoices-table{font-size:.9rem}.invoices-table td,.invoices-table th{padding:8px}}.preset-manager{margin:0 auto;max-width:1200px;padding:var(--space-6)}.preset-manager-loading{flex-direction:column;justify-content:center;min-height:400px}.preset-header,.preset-manager-loading{align-items:center;display:flex;gap:var(--space-4)}.preset-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--space-6)}.preset-header-info h1{color:var(--color-text);font-size:1.75rem;font-weight:700;margin-bottom:var(--space-1)}.preset-header-info p{color:var(--color-text-secondary);font-size:.9375rem}.btn-add-preset{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-5);transition:all .2s ease}.btn-add-preset:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.btn-add-preset:disabled{cursor:not-allowed;opacity:.5}.preset-error{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:var(--radius-lg);color:#ef4444;display:flex;justify-content:space-between;margin-bottom:var(--space-6);padding:var(--space-4)}.preset-error button{background:none;border:none;color:#ef4444;cursor:pointer;padding:var(--space-1)}.preset-upgrade-banner{background:linear-gradient(135deg,var(--color-bg-secondary) 0,var(--color-bg) 100%);border:1px solid var(--color-border);border-radius:var(--radius-xl);margin:var(--space-8) auto;max-width:600px;padding:var(--space-8);text-align:center}.upgrade-icon{color:var(--color-primary);margin-bottom:var(--space-4)}.preset-upgrade-banner h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-3)}.upgrade-description{color:var(--color-text-secondary);font-size:1rem;line-height:1.6;margin-bottom:var(--space-6)}.upgrade-features{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6);margin-left:auto;margin-right:auto;max-width:320px;text-align:left}.feature-item{align-items:center;color:var(--color-text);display:flex;gap:var(--space-3)}.feature-item svg{color:#22c55e;flex-shrink:0}.current-plan-info{background:var(--color-bg);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--space-5);padding:var(--space-3) var(--space-4)}.current-plan-info strong{color:var(--color-text);text-transform:capitalize}.btn-upgrade{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,#7c3aed 100%);border-radius:var(--radius-lg);color:#fff;display:inline-flex;font-weight:600;gap:var(--space-2);padding:var(--space-4) var(--space-6);text-decoration:none;transition:all .2s ease}.btn-upgrade:hover{box-shadow:0 8px 24px #6366f166;transform:translateY(-2px)}.preset-empty{background:var(--color-bg-secondary);border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);text-align:center}.preset-empty .empty-icon{color:var(--color-text-muted);margin-bottom:var(--space-4)}.preset-empty h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-2)}.preset-empty p{color:var(--color-text-secondary);margin-bottom:var(--space-5)}.btn-add-first{background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-weight:600;padding:var(--space-3) var(--space-5);transition:all .2s ease}.btn-add-first:hover{background:var(--color-primary-dark)}.preset-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:var(--space-6)}.preset-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all .2s ease}.preset-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a}.preset-card.default{border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f133}.preset-card.inactive{opacity:.6}.preset-preview{align-items:center;aspect-ratio:16/10;background:var(--color-bg);display:flex;justify-content:center;position:relative}.preset-preview img{height:100%;object-fit:cover;width:100%}.preset-preview-placeholder{color:var(--color-text-muted)}.preset-badge{border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;padding:var(--space-1) var(--space-2);position:absolute;right:var(--space-2);top:var(--space-2)}.default-badge{background:var(--color-primary);color:#fff}.inactive-badge{background:#0009;color:#fff}.preset-info{padding:var(--space-4)}.preset-info h3{font-size:1rem;font-weight:600;margin-bottom:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-info p{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-text-secondary);display:-webkit-box;font-size:.875rem;margin-bottom:var(--space-2);overflow:hidden}.preset-file{color:var(--color-text-muted);font-family:monospace;font-size:.75rem}.preset-actions{background:var(--color-bg);border-top:1px solid var(--color-border);display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4)}.preset-actions button{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;padding:var(--space-2);transition:all .2s ease}.preset-actions button:hover{background:var(--color-bg-secondary);color:var(--color-text)}.btn-set-default:hover{border-color:#f59e0b!important;color:#f59e0b!important}.btn-toggle-active.active{color:#22c55e}.btn-delete-preset:hover{border-color:#ef4444!important;color:#ef4444!important}.preset-info-box{background:#6366f11a;border:1px solid #6366f133;border-radius:var(--radius-lg);display:flex;gap:var(--space-4);padding:var(--space-4)}.preset-info-box svg{color:var(--color-primary);flex-shrink:0}.preset-info-box strong{color:var(--color-text);display:block;margin-bottom:var(--space-1)}.preset-info-box p{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5;margin:0}.preset-modal-overlay{background:#00000080;padding:var(--space-4);z-index:1000}.preset-modal{background:var(--color-bg);border-radius:var(--radius-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-5)}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{background:none;color:var(--color-text-secondary);padding:var(--space-1)}.modal-close:hover{color:var(--color-text)}.modal-body{padding:var(--space-5)}.form-group{margin-bottom:var(--space-5)}.form-group label{color:var(--color-text);margin-bottom:var(--space-2)}.form-group input,.form-group textarea{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.9375rem;padding:var(--space-3);width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.file-drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-8) var(--space-4);text-align:center;transition:all .2s ease}.file-drop-zone:hover{background:#6366f10d;border-color:var(--color-primary)}.file-drop-zone.has-file{background:#6366f10d;border-color:var(--color-primary);border-style:solid}.file-drop-zone svg{color:var(--color-text-muted);margin-bottom:var(--space-3)}.file-drop-zone p{color:var(--color-text-secondary);margin-bottom:var(--space-1)}.file-types{color:var(--color-text-muted);font-size:.75rem}.selected-file{align-items:center;display:flex;flex-direction:column;gap:var(--space-2)}.selected-file svg{color:var(--color-primary)}.selected-file span{font-weight:500;word-break:break-all}.modal-footer{border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-5)}.btn-cancel{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);padding:var(--space-3) var(--space-5)}.btn-cancel:hover{background:var(--color-bg-secondary)}.btn-upload{align-items:center;background:var(--color-primary);border-radius:var(--radius-lg);display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-5);transition:all .2s ease}.btn-upload:hover:not(:disabled){background:var(--color-primary-dark)}.btn-upload:disabled{cursor:not-allowed;opacity:.6}.spinner-small{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:768px){.preset-manager{padding:var(--space-4)}.preset-header{align-items:stretch;flex-direction:column}.btn-add-preset{justify-content:center}.preset-grid{grid-template-columns:1fr}.preset-upgrade-banner{padding:var(--space-6)}}.photo-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));padding:20px}.photo-grid-item{aspect-ratio:1;background-color:#f0f0f0;border-radius:8px;cursor:pointer;overflow:hidden;position:relative;transition:transform .2s,box-shadow .2s}.photo-grid-item:hover{box-shadow:0 8px 16px #0003;transform:translateY(-4px)}.photo-grid-item.selected{outline:3px solid #007bff;outline-offset:2px}.photo-grid-item-inner{height:100%;position:relative;width:100%}.photo-grid-item img{display:block;height:100%;object-fit:cover;width:100%}.photo-grid-placeholder{animation:loading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;height:100%;width:100%}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.photo-grid-checkbox{left:10px;position:absolute;top:10px;z-index:10}.photo-grid-checkbox input[type=checkbox]{cursor:pointer;height:20px;width:20px}.photo-grid-overlay{background:linear-gradient(0deg,#000000b3,#0000);bottom:0;left:0;opacity:0;padding:15px;position:absolute;right:0;transition:opacity .2s}.photo-grid-item:hover .photo-grid-overlay{opacity:1}.photo-grid-info{display:flex;flex-direction:column;gap:4px}.photo-filename{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-date{color:#fffc;font-size:12px}.photo-grid-empty{color:#666;font-size:18px;grid-column:1/-1;padding:60px 20px;text-align:center}@media (max-width:768px){.photo-grid{gap:8px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:10px}.photo-filename{font-size:12px}.photo-date{font-size:10px}}.photo-viewer-overlay{align-items:center;background-color:#000000f2;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.photo-viewer{color:#fff;display:flex;flex-direction:column;height:100%;width:100%}.photo-viewer-header{align-items:center;background-color:#00000080;display:flex;justify-content:space-between;padding:20px}.photo-viewer-title{align-items:center;display:flex;gap:15px}.photo-viewer-title h3{font-size:18px;font-weight:500;margin:0}.photo-viewer-counter{color:#ffffffb3;font-size:14px}.photo-viewer-actions{display:flex;gap:10px}.viewer-btn{background-color:#ffffff1a;border:1px solid #fff3;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:8px 15px;transition:all .2s}.viewer-btn:hover{background-color:#fff3}.viewer-close{font-size:24px;padding:5px 12px}.photo-viewer-content{flex:1 1;overflow:hidden;position:relative}.photo-viewer-content,.photo-viewer-image-container{align-items:center;display:flex;justify-content:center}.photo-viewer-image-container{max-height:90%;max-width:90%}.photo-viewer-image-container img{max-height:85vh;max-width:100%;object-fit:contain}.photo-viewer-error,.photo-viewer-loading{color:#fff;font-size:18px;text-align:center}.photo-viewer-nav{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:48px;height:60px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s;width:60px}.photo-viewer-nav:hover{background-color:#fff3;transform:translateY(-50%) scale(1.1)}.photo-viewer-prev{left:20px}.photo-viewer-next{right:20px}.photo-viewer-info{background-color:#000c;max-height:200px;overflow-y:auto;padding:20px}.photo-info-section h4{font-size:16px;font-weight:500;margin:0 0 15px}.photo-info-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.photo-info-item{display:flex;flex-direction:column;gap:5px}.info-label{color:#fff9;font-size:12px;text-transform:uppercase}.info-value{color:#fff;font-size:14px}@media (max-width:768px){.photo-viewer-header{padding:10px}.photo-viewer-title h3{font-size:14px}.photo-viewer-counter{font-size:12px}.viewer-btn{font-size:14px;padding:6px 10px}.photo-viewer-nav{font-size:32px;height:45px;width:45px}.photo-viewer-prev{left:10px}.photo-viewer-next{right:10px}.photo-info-grid{grid-template-columns:1fr}}.share-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1001}.share-modal{background-color:#fff;border-radius:12px;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}.share-modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.share-modal-header h2{font-size:20px;font-weight:600;margin:0}.share-modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s;width:30px}.share-modal-close:hover{background-color:#f0f0f0;color:#333}.share-modal-content{flex:1 1;overflow-y:auto;padding:20px}.share-tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:10px;margin-bottom:20px}.share-tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-2px;padding:10px 20px;transition:all .2s}.share-tab:hover{color:#333}.share-tab.active{border-bottom-color:#007bff;color:#007bff}.share-section{animation:fadeIn .3s}.share-url-container{display:flex;gap:10px;margin-bottom:15px}.share-url-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-family:monospace;font-size:14px;padding:12px}.share-copy-btn{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s;white-space:nowrap}.share-copy-btn:hover{background-color:#0056b3}.share-copy-btn.copied{background-color:#28a745}.share-description{color:#666;font-size:14px;margin:0}.share-qrcode-section{text-align:center}.share-qrcode-container{display:flex;justify-content:center;margin:20px 0}.share-qrcode{background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:10px}.share-download-qr-btn{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;margin-top:15px;padding:10px 20px;transition:all .2s}.share-download-qr-btn:hover{background-color:#0056b3}.share-social-buttons{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.share-social-btn{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;justify-content:center;padding:12px;transition:all .2s}.share-social-btn:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.share-social-btn.whatsapp{border-color:#25d366;color:#25d366}.share-social-btn.whatsapp:hover{background-color:#25d366;color:#fff}.share-social-btn.email{border-color:#ea4335;color:#ea4335}.share-social-btn.email:hover{background-color:#ea4335;color:#fff}.share-social-btn.facebook{border-color:#1877f2;color:#1877f2}.share-social-btn.facebook:hover{background-color:#1877f2;color:#fff}.share-social-btn.twitter{border-color:#1da1f2;color:#1da1f2}.share-social-btn.twitter:hover{background-color:#1da1f2;color:#fff}.social-icon{font-size:20px}@media (max-width:768px){.share-modal{margin:10px;max-width:100%}.share-url-container{flex-direction:column}.share-social-buttons{grid-template-columns:1fr}.share-tabs{gap:5px}.share-tab{font-size:12px;padding:8px 12px}}.public-gallery{background-color:#f5f5f5;min-height:100vh}.gallery-header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:30px 20px}.gallery-header-content{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin:0 auto 20px;max-width:1400px}.gallery-info h1{color:#333;font-size:32px;font-weight:600;margin:0 0 10px}.gallery-description{color:#666;font-size:16px;margin:0 0 15px;max-width:600px}.gallery-stats{display:flex;flex-wrap:wrap;gap:20px}.stat-item{color:#666;font-size:14px}.stat-item strong{color:#333;font-weight:600}.gallery-actions{display:flex;gap:10px}.gallery-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin:0 auto;max-width:1400px}.gallery-search{flex:1 1;min-width:250px}.search-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 15px;transition:all .2s;width:100%}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.gallery-filters{align-items:center;display:flex;gap:10px}.sort-select{background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:10px 15px;transition:all .2s}.sort-select:focus{border-color:#007bff;outline:none}.view-mode-toggle{background-color:#fff;border:1px solid #ddd;border-radius:6px;display:flex;gap:5px;padding:2px}.view-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:18px;padding:8px 12px;transition:all .2s}.view-btn:hover{background-color:#f0f0f0}.view-btn.active{background-color:#007bff;color:#fff}.gallery-content{margin:0 auto;max-width:1400px}.gallery-empty,.gallery-loading{padding:60px 20px;text-align:center}.gallery-loading .spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:50px;margin:0 auto 20px;width:50px}.gallery-loading p{color:#666;font-size:16px}.gallery-empty p{color:#999;font-size:16px}.btn{align-items:center;display:inline-flex;font-size:14px;gap:8px;padding:10px 20px}@media (max-width:768px){.gallery-header{padding:20px 15px}.gallery-header-content{flex-direction:column}.gallery-info h1{font-size:24px}.gallery-description{font-size:14px}.gallery-controls{align-items:stretch;flex-direction:column}.gallery-search{width:100%}.gallery-filters{flex-wrap:wrap}.sort-select{flex:1 1}}.gallery-page{background-color:#f5f5f5;min-height:100vh}.gallery-page.error,.gallery-page.loading{align-items:center;display:flex;justify-content:center}.error-container,.loading-container{max-width:600px;padding:40px;text-align:center}.loading-container .spinner{animation:spin 1s linear infinite;border:5px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:60px;margin:0 auto 20px;width:60px}.loading-container p{color:#666;font-size:18px;margin:0}.error-container{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:60px 40px}.error-container h1{color:#dc3545;font-size:48px;margin:0 0 20px}.error-message{color:#666;font-size:18px;line-height:1.6;margin:0 0 30px}.access-request-form{background-color:#f8f9fa;border-radius:8px;margin:30px 0;padding:30px}.access-request-form h2{color:#333;font-size:20px;margin:0 0 10px}.access-request-form p{color:#666;font-size:14px;margin:0 0 20px}.access-request-form form{display:flex;flex-direction:column;gap:15px}.access-email-input{border:1px solid #ddd;border-radius:6px;font-size:16px;padding:12px;transition:all .2s}.access-email-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.btn{border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .2s}.btn-primary{background-color:#007bff}.btn-primary:hover{background-color:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268;transform:translateY(-1px)}@media (max-width:768px){.error-container{margin:20px;padding:40px 20px}.error-container h1{font-size:36px}.error-message{font-size:16px}.access-request-form{padding:20px}.access-request-form h2{font-size:18px}}.story-gallery-loading{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.story-spinner{animation:spin .8s linear infinite;border:3px solid #fff3;border-radius:50%;border-top-color:#fff;height:48px;width:48px}.story-gallery-loading p{font-size:1rem;margin-top:1rem;opacity:.8}.story-gallery-empty,.story-gallery-error{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.empty-icon,.error-icon{font-size:4rem;margin-bottom:1rem}.story-gallery-empty h2,.story-gallery-error h2{color:#fff!important;font-size:1.5rem;margin-bottom:.5rem}.story-gallery-empty p,.story-gallery-error p{max-width:400px;opacity:.7}.empty-hint{font-size:.875rem;margin-top:1rem}.story-gallery-grid-page{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;min-height:100vh}.story-header{background:#0000004d;border-bottom:1px solid #ffffff1a;padding:2rem 1rem;text-align:center}.story-header-content{margin:0 auto;max-width:600px}.story-header h1{color:#fff!important;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.gallery-desc{font-size:.9375rem;margin-bottom:1rem;opacity:.7}.gallery-meta{display:flex;font-size:.875rem;gap:1.5rem;justify-content:center;opacity:.6}.story-grid{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(3,1fr);padding:2px}@media (min-width:768px){.story-grid{gap:4px;grid-template-columns:repeat(4,1fr);padding:1rem}}@media (min-width:1024px){.story-grid{grid-template-columns:repeat(5,1fr);margin:0 auto;max-width:1200px}}.story-grid-item{aspect-ratio:1;background:#ffffff0d;cursor:pointer;overflow:hidden;position:relative}.story-grid-item img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.story-grid-item:hover img{transform:scale(1.05)}.grid-item-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s ease}.story-grid-item:hover .grid-item-overlay{opacity:1}.view-icon{font-size:2rem}.view-icon-svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));opacity:.9}.story-viewer{background:#000;display:flex;flex-direction:column;inset:0;position:fixed;-webkit-user-select:none;user-select:none;z-index:1000}.story-progress-container{display:flex;gap:4px;left:0;padding:8px 12px;position:absolute;right:0;top:0;z-index:10}.story-progress-bar{background:#ffffff4d;border-radius:2px;flex:1 1;height:3px;overflow:hidden}.story-progress-fill{background:#fff;height:100%;transition:width .05s linear}.story-viewer-header{align-items:center;display:flex;justify-content:space-between;left:0;padding:0 1rem;position:absolute;right:0;top:20px;z-index:10}.story-close-btn,.story-download-btn{align-items:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;transition:background .2s,transform .2s;width:44px}.story-close-btn:hover,.story-download-btn:hover{background:#000000b3;transform:scale(1.05)}.story-download-btn:disabled{cursor:not-allowed;opacity:.5}.download-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.story-profile-section{align-items:center;display:flex;gap:10px}.story-avatar-ring{align-items:center;background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);border-radius:50%;display:flex;height:40px;justify-content:center;padding:2px;width:40px}.story-avatar{border:2px solid #000;border-radius:50%;height:36px;object-fit:cover;width:36px}.story-avatar-initials{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:14px;font-weight:700;justify-content:center}.story-profile-info{display:flex;flex-direction:column}.story-profile-name{color:#fff;font-size:14px;font-weight:600;text-shadow:0 1px 3px #000c}.story-profile-time{color:#ffffffb3;font-size:12px}.story-header-actions{align-items:center;display:flex;gap:8px}.story-title-container{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-width:0;padding:0 .5rem}.story-title{color:#fff;font-size:1rem;font-weight:600;margin:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 3px #000c;white-space:nowrap}.story-counter{color:#fffc;font-size:.75rem;font-weight:500;margin-top:2px}.story-photo-container{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:hidden;position:relative}.story-photo{max-height:100%;max-width:100%;object-fit:contain}.pause-indicator{align-items:center;animation:fadeIn .2s ease;background:#00000080;border-radius:50%;display:flex;height:80px;justify-content:center;position:absolute;width:80px}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.heart-animation{align-items:center;animation:heartPop 1s ease forwards;display:flex;justify-content:center;pointer-events:none;position:absolute}@keyframes heartPop{0%{opacity:0;transform:scale(0)}15%{opacity:1;transform:scale(1.2)}30%{transform:scale(.95)}45%{transform:scale(1)}80%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1)}}.story-nav-hints{align-items:center;display:flex;inset:0;justify-content:space-between;padding:0 1rem;pointer-events:none;position:absolute}.nav-hint{color:#fff;opacity:0;transition:opacity .2s}.story-viewer:hover .nav-hint{opacity:.5}.story-viewer-footer{background:linear-gradient(#0000,#000c);bottom:0;left:0;padding:1rem;position:absolute;right:0;z-index:10}.story-actions-row{align-items:center;display:flex;gap:12px}.story-like-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:transform .2s ease}.story-like-btn:hover{transform:scale(1.1)}.story-like-btn:active{transform:scale(.95)}.story-like-btn.liked{animation:likeButton .3s ease}@keyframes likeButton{0%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(.95)}to{transform:scale(1)}}.story-reply-container{align-items:center;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:24px;display:flex;flex:1 1;gap:8px;padding:8px 12px}.story-reply-input{background:#0000;border:none;color:#fff;flex:1 1;font-size:14px;outline:none}.story-reply-input::placeholder{color:#fff9}.story-send-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;opacity:.7;padding:4px;transition:opacity .2s}.story-send-btn:hover{opacity:1}.story-photo-info{display:flex;justify-content:center;margin-top:12px}.story-photo-counter{color:#ffffffb3;font-size:12px}.photo-filename{color:#fff;font-size:.875rem;font-weight:500;margin-bottom:.25rem;word-break:break-all}.photo-time{color:#fff9;font-size:.75rem}@media (max-width:768px){.story-header{padding:1.5rem 1rem}.story-header h1{color:#fff!important;font-size:1.25rem}.gallery-meta{flex-direction:column;gap:.5rem}.story-viewer-header{top:16px}.story-close-btn,.story-download-btn{height:40px;width:40px}.nav-hint{display:none}}@supports (padding:max(0px)){.story-progress-container{padding-top:max(8px,env(safe-area-inset-top))}.story-viewer-footer{padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}}.new-photo-toast{animation:toastSlideIn .3s ease,toastFadeOut .3s ease 2.7s forwards;background:linear-gradient(135deg,#4ade80,#22c55e);border-radius:24px;box-shadow:0 4px 20px #22c55e66;color:#fff;font-size:14px;font-weight:600;left:50%;padding:12px 24px;position:fixed;top:20px;transform:translateX(-50%);z-index:1001}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes toastFadeOut{0%{opacity:1}to{opacity:0}}.story-gallery-blocked{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.blocked-content{max-width:450px;width:100%}.blocked-icon{color:#f59e0b;margin-bottom:1.5rem}.blocked-icon svg{filter:drop-shadow(0 4px 12px rgba(245,158,11,.3))}.story-gallery-blocked h2{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.blocked-message{font-size:1rem;line-height:1.5;margin-bottom:1.5rem;opacity:.9}.blocked-stats{background:#f59e0b26;border:1px solid #f59e0b4d;border-radius:8px;display:inline-block;margin-bottom:1.5rem;padding:.75rem 1.5rem}.blocked-stats span{color:#f59e0b;font-weight:600}.blocked-cta{background:#ffffff0d;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.blocked-cta p{font-size:.9375rem;margin:0;opacity:.8}.blocked-cta .blocked-hint{font-size:.875rem;margin-top:.75rem;opacity:.6}.blocked-fotografo{border-top:1px solid #ffffff1a;padding-top:1rem}.blocked-fotografo span{font-size:.875rem;opacity:.6}.preset-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#000000d9;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:2000}.preset-download-modal{animation:slideUp .3s ease;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffffff1a;border-radius:16px;max-width:420px;padding:2rem;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.preset-modal-header{margin-bottom:1.5rem}.preset-modal-header.upgrade .preset-modal-icon{color:#f59e0b}.preset-modal-icon{color:#6366f1;margin-bottom:1rem}.preset-modal-icon.locked{color:#f59e0b}.preset-modal-header h3{color:#fff;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.preset-modal-header p{color:#ffffffb3;font-size:.9375rem;line-height:1.5}.preset-modal-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.preset-option{align-items:center;background:#ffffff0d;border:2px solid #ffffff1a;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;position:relative;transition:all .2s ease}.preset-option:hover:not(:disabled){background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.preset-option:disabled{cursor:not-allowed;opacity:.5}.preset-option-icon{align-items:center;background:#ffffff1a;border-radius:12px;display:flex;height:56px;justify-content:center;margin-bottom:.5rem;width:56px}.preset-option-icon.edited{background:linear-gradient(135deg,#6366f14d,#8b5cf64d);color:#a78bfa}.preset-option-title{font-size:1rem;font-weight:600}.preset-option-desc{color:#fff9;font-size:.875rem}.preset-option-badge{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:4px 10px;position:absolute;right:-8px;top:-8px}.preset-option-edited{background:#6366f11a;border-color:#6366f14d}.preset-option-edited:hover:not(:disabled){background:#6366f126;border-color:#6366f180}.preset-upgrade-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;text-align:left}.preset-feature{align-items:center;color:#ffffffe6;display:flex;font-size:.9375rem;gap:.75rem}.preset-feature svg{flex-shrink:0}.preset-modal-actions{margin-bottom:1rem}.preset-btn-download-original{background:#ffffff1a;border:1px solid #fff3;border-radius:10px;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;padding:.875rem 1.5rem;transition:all .2s ease;width:100%}.preset-btn-download-original:hover:not(:disabled){background:#ffffff26;border-color:#ffffff4d}.preset-btn-download-original:disabled{cursor:not-allowed;opacity:.5}.preset-contact-hint{color:#ffffff80;font-size:.8125rem;margin-top:1rem}.preset-modal-close{background:#0000;border:none;color:#fff9;cursor:pointer;font-size:.9375rem;padding:.75rem;transition:color .2s ease;width:100%}.preset-modal-close:hover{color:#fff}@media (max-width:480px){.preset-download-modal{margin:.5rem;padding:1.5rem}.preset-modal-header h3{font-size:1.125rem}.preset-modal-options{gap:.75rem}.preset-option{padding:1rem}.preset-option-icon{height:48px;width:48px}}.static-page{margin:0 auto;max-width:900px;padding:30px 20px}.static-page-header{margin-bottom:40px;text-align:center}.static-page-header h1{color:#333;font-size:2rem;margin-bottom:10px}.static-page-header p{color:#666;font-size:1rem}.features-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.feature-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:24px;transition:all .3s}.feature-card:hover{box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.feature-icon{color:#007bff;margin-bottom:15px}.feature-card h3{color:#333;font-size:1.1rem;margin-bottom:10px}.feature-card p{color:#666;font-size:.9rem;line-height:1.5}.faq-list{display:flex;flex-direction:column;gap:10px}.faq-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.faq-item.open{border-color:#007bff}.faq-question{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;justify-content:space-between;padding:16px 20px;text-align:left;width:100%}.faq-question:hover{background:#f8f9fa}.faq-icon{color:#666;flex-shrink:0;transition:transform .3s}.faq-item.open .faq-icon{color:#007bff}.faq-answer{padding:0 20px 16px}.faq-answer p{color:#666;font-size:.9rem;line-height:1.6;margin:0}.faq-contact{background:#f8f9fa;border-radius:10px;margin-top:40px;padding:30px;text-align:center}.faq-contact h3{color:#333;margin-bottom:10px}.faq-contact p{color:#666;margin-bottom:20px}.btn-contact{background:#007bff;border-radius:6px;color:#fff;display:inline-block;font-weight:500;padding:12px 24px;text-decoration:none;transition:background .3s}.btn-contact:hover{background:#0056b3}.docs-content{display:flex;flex-direction:column;gap:30px}.docs-section h2{border-bottom:2px solid #007bff;color:#333;font-size:1.3rem;margin-bottom:15px;padding-bottom:10px}.docs-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:15px;padding:20px}.docs-card h3{color:#333;font-size:1rem;margin-bottom:10px}.docs-card p{color:#666;font-size:.9rem;line-height:1.6;margin-bottom:10px}.docs-card p:last-child{margin-bottom:0}.docs-card ul{margin:10px 0;padding-left:20px}.docs-card li{color:#666;font-size:.9rem;line-height:1.8}.legal-content{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:30px}.legal-section{margin-bottom:30px}.legal-section:last-child{margin-bottom:0}.legal-section h2{color:#333;font-size:1.2rem;margin-bottom:15px}.legal-section h3{color:#555;font-size:1rem;margin:15px 0 10px}.legal-section p{color:#666;font-size:.9rem;line-height:1.7;margin-bottom:10px}.legal-section ul{margin:10px 0 15px;padding-left:20px}.legal-section li{color:#666;font-size:.9rem;line-height:1.8}.legal-section a{color:#007bff;text-decoration:none}.legal-section a:hover{text-decoration:underline}@media (max-width:768px){.static-page{padding:20px 15px}.static-page-header h1{font-size:1.5rem}.features-grid{grid-template-columns:1fr}.legal-content{padding:20px}}.photo-uploader-container{background:#f7fafc;min-height:100vh}.photo-uploader-header{background:#fff;box-shadow:0 1px 3px #0000001a;padding:16px 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.photo-uploader-header .header-content{align-items:center;display:flex;justify-content:space-between}.photo-uploader-header h1{color:#1a202c;font-size:24px;font-weight:700;margin:0 0 4px}.photo-uploader-header .event-name{color:#475569!important;font-size:14px;font-weight:500;margin:0}.photo-uploader-main{padding:32px 0}.uploader-content{margin:0 auto;max-width:900px}.drop-zone{background:#fff;border:3px dashed #cbd5e0;border-radius:12px;cursor:pointer;padding:60px 20px;text-align:center;transition:all .2s}.drop-zone:hover{background:#f7fafc;border-color:#667eea}.drop-zone-content{align-items:center;display:flex;flex-direction:column;gap:16px}.upload-icon{color:#667eea;height:64px;width:64px}.drop-zone h3{color:#2d3748;font-size:18px;font-weight:600;margin:0}.drop-zone p{color:#718096;font-size:14px;margin:0}.selected-files{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-top:32px;padding:24px}.selected-files-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.selected-files-header h3{color:#2d3748;font-size:18px;font-weight:600;margin:0}.btn-clear{background:#e53e3e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-clear:hover{background:#c53030}.files-list{grid-gap:12px;display:grid;gap:12px;margin-bottom:20px;max-height:400px;overflow-y:auto}.file-item{align-items:center;background:#f7fafc;border-radius:8px;display:flex;gap:16px;padding:12px;transition:all .2s}.file-item:hover{background:#edf2f7}.file-preview{border-radius:6px;flex-shrink:0;height:60px;overflow:hidden;width:60px}.file-preview img{height:100%;object-fit:cover;width:100%}.file-info{flex:1 1;min-width:0}.file-name{color:#2d3748;font-size:14px;font-weight:500;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#718096;font-size:12px;margin:0}.btn-remove{background:#fed7d7;border:none;border-radius:50%;color:#742a2a;cursor:pointer;flex-shrink:0;font-size:20px;font-weight:700;height:32px;line-height:1;padding:0;transition:all .2s;width:32px}.btn-remove:hover{background:#fc8181;color:#fff}.upload-actions{display:flex;justify-content:flex-end}.btn-upload{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 32px;transition:all .2s}.btn-upload:hover{box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.upload-progress{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:40px;text-align:center}.upload-progress h3{color:#2d3748;font-size:20px;font-weight:600;margin:0 0 24px}.progress-bar{background:#e2e8f0;border-radius:6px;height:12px;margin-bottom:16px;overflow:hidden;width:100%}.progress-bar-fill{background:linear-gradient(135deg,#667eea,#764ba2);height:100%;transition:width .3s ease}.progress-text{color:#667eea;font-size:24px;font-weight:700;margin:0}.upload-results{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.results-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.results-header h3{color:#2d3748;font-size:20px;font-weight:600;margin:0}.results-summary{background:#f7fafc;border-radius:8px;margin-bottom:20px;padding:16px}.results-summary p{color:#2d3748;font-size:14px;font-weight:500;margin:0}.results-list{grid-gap:8px;display:grid;gap:8px;margin-bottom:20px;max-height:400px;overflow-y:auto}.result-item{align-items:center;border-radius:8px;display:flex;gap:12px;padding:12px}.result-item.success{background:#c6f6d5}.result-item.error{background:#fed7d7}.result-icon{align-items:center;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:24px;justify-content:center;width:24px}.result-item.success .result-icon{color:#22543d}.result-item.error .result-icon{color:#742a2a}.result-info{flex:1 1;min-width:0}.result-filename{font-size:14px;font-weight:500;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-item.success .result-filename{color:#22543d}.result-item.error .result-filename{color:#742a2a}.result-error{color:#742a2a;font-size:12px;margin:4px 0 0}.results-actions{display:flex;gap:12px;justify-content:flex-end}.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;transition:all .2s}.btn-primary:hover{box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-secondary:hover{background:#f7fafc}@media (max-width:768px){.results-header{align-items:flex-start;flex-direction:column;gap:12px}.results-actions{flex-direction:column;width:100%}.btn-primary,.btn-secondary{width:100%}}.upload-page{margin:0 auto;max-width:1200px;padding:0 20px 40px}.upload-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.upload-loading .spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-top-color:#6366f1;border:3px solid var(--border-color,#e5e7eb);border-radius:50%;border-top-color:var(--primary-color,#6366f1);height:40px;width:40px}.events-select-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.event-select-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:20px;transition:all .2s ease}.event-select-card:hover{border-color:#6366f1;border-color:var(--primary-color,#6366f1);box-shadow:0 4px 12px #6366f126;transform:translateY(-2px)}.event-select-card.inactive{opacity:.7}.event-select-icon{align-items:center;background:#eef2ff;background:var(--primary-light,#eef2ff);border-radius:12px;color:#6366f1;color:var(--primary-color,#6366f1);display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.event-select-info{flex:1 1;min-width:0}.event-select-info h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-select-info .event-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:13px;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-select-info .event-meta{color:#9ca3af;color:var(--text-muted,#9ca3af);display:flex;font-size:12px;gap:16px}.event-select-info .event-meta span{align-items:center;display:flex;gap:4px}.event-select-action{align-items:flex-end;color:#9ca3af;color:var(--text-muted,#9ca3af);display:flex;flex-direction:column;gap:8px}.event-select-action .badge{font-size:11px;padding:2px 8px}.empty-state{flex-direction:column;padding:60px 20px;text-align:center}.empty-icon,.empty-state{align-items:center;display:flex;justify-content:center}.empty-icon{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:50%;color:#9ca3af;color:var(--text-muted,#9ca3af);height:80px;margin-bottom:20px;width:80px}.empty-state h3{color:#111827;color:var(--text-primary,#111827);font-size:18px;font-weight:600;margin:0 0 8px}.empty-state p{color:#6b7280;color:var(--text-secondary,#6b7280);margin:0 0 24px}.alert{align-items:center;border-radius:8px;display:flex;gap:12px;margin-bottom:20px;padding:12px 16px}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}@media (max-width:768px){.events-select-grid{grid-template-columns:1fr}.event-select-card{padding:16px}.event-select-icon{height:50px;width:50px}.event-select-icon svg{height:24px;width:24px}}.admin-page{background:#f1f5f9;min-height:100vh;padding-bottom:40px}.admin-denied,.admin-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.admin-loading .spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.admin-denied .denied-icon{color:#ef4444}.admin-denied h2{color:#1e293b;margin:0}.admin-header{background:linear-gradient(135deg,#1e293b,#334155);color:#fff;margin-bottom:24px;padding:32px 24px}.admin-header-content{margin:0 auto;max-width:1400px}.admin-header h1{font-size:28px;font-weight:700;margin:0 0 8px}.admin-header p{font-size:14px;margin:0;opacity:.8}.admin-alert{align-items:center;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;margin:0 auto 16px;max-width:1400px;padding:12px 16px}.admin-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.admin-alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.admin-alert button{background:none;border:none;color:inherit;cursor:pointer;font-size:20px;opacity:.6}.admin-alert button:hover{opacity:1}.admin-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin:0 auto 24px;max-width:1400px;padding:0 24px}.stat-card{background:#fff;box-shadow:0 1px 3px #0000001a;gap:16px;padding:20px}.stat-card,.stat-icon{align-items:center;border-radius:12px;display:flex}.stat-icon{height:48px;justify-content:center;width:48px}.stat-icon-tenants{background:#ede9fe;color:#7c3aed}.stat-icon-photos{background:#dbeafe;color:#2563eb}.stat-icon-events{background:#dcfce7;color:#16a34a}.stat-icon-plans{background:#fef3c7;color:#d97706}.stat-info{display:flex;flex-direction:column}.stat-value{color:#1e293b;font-size:28px;font-weight:700;line-height:1}.stat-label{color:#64748b;font-size:14px;margin-top:4px}.stat-sub{color:#94a3b8;font-size:12px}.admin-tabs{display:flex;gap:8px;margin:0 auto 20px;max-width:1400px;padding:0 24px}.admin-tab{background:#fff;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.admin-tab:hover{color:#1e293b}.admin-tab.active{background:#6366f1;color:#fff}.admin-section{margin:0 auto;max-width:1400px;padding:0 24px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h2{color:#1e293b;font-size:18px;margin:0}.section-count{background:#e2e8f0;border-radius:20px;color:#64748b;font-size:13px;padding:4px 12px}.period-select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:14px;padding:8px 16px}.admin-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.admin-table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:14px;padding:16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr.inactive{background:#f8fafc;opacity:.7}.admin-table tr:hover{background:#f8fafc}.tenant-cell{display:flex;flex-direction:column;gap:2px}.tenant-cell strong{font-weight:600}.tenant-subdomain{color:#6366f1;font-size:12px}.tenant-email{color:#94a3b8;font-size:12px}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase}.badge-free{background:#f1f5f9;color:#64748b}.badge-basic{background:#dbeafe;color:#2563eb}.badge-pro{background:#dcfce7;color:#16a34a}.badge-master{background:#fef3c7;color:#d97706}.status-badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;padding:4px 10px}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.inactive{background:#fee2e2;color:#dc2626}.action-buttons{display:flex;gap:8px}.btn-action{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.btn-view{background:#e0e7ff;color:#4f46e5}.btn-view:hover{background:#c7d2fe}.btn-edit{background:#dbeafe;color:#2563eb}.btn-edit:hover{background:#bfdbfe}.btn-activate{background:#dcfce7;color:#16a34a}.btn-activate:hover{background:#bbf7d0}.btn-deactivate{background:#fef3c7;color:#d97706}.btn-deactivate:hover{background:#fde68a}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.ranking-list{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.ranking-item{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:16px;padding:16px 20px}.ranking-item:last-child{border-bottom:none}.ranking-item.top-1{background:linear-gradient(90deg,#fef3c7,#fff 50%)}.ranking-item.top-2{background:linear-gradient(90deg,#e2e8f0,#fff 50%)}.ranking-item.top-3{background:linear-gradient(90deg,#fed7aa,#fff 50%)}.ranking-position{text-align:center;width:40px}.medal{font-size:24px}.position-number{color:#64748b;font-size:18px;font-weight:700}.ranking-info{display:flex;flex:1 1;flex-direction:column}.ranking-info strong{color:#1e293b;font-size:15px}.ranking-info span{color:#6366f1;font-size:13px}.ranking-stats{text-align:right}.photo-count{color:#1e293b;display:block;font-size:16px;font-weight:600}.storage-size{color:#64748b;display:block;font-size:12px}.empty-ranking{color:#64748b;padding:40px;text-align:center}.modal-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}.modal-content{background:#fff;border-radius:16px;max-height:90vh;max-width:600px;overflow-y:auto;padding:24px;position:relative;width:100%}.modal-close{align-items:center;background:#f1f5f9;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;height:32px;justify-content:center;position:absolute;right:16px;top:16px;width:32px}.modal-close:hover{background:#e2e8f0;color:#1e293b}.modal-edit h2,.modal-view h2{color:#1e293b;font-size:20px;margin:0 0 24px}.detail-section{margin-bottom:24px}.detail-section h3{color:#64748b;font-size:14px;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{color:#94a3b8;font-size:12px}.detail-item span{color:#1e293b;font-size:14px}.detail-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.detail-stat{background:#f8fafc;border-radius:8px;padding:16px;text-align:center}.detail-stat .stat-value{font-size:24px}.detail-stat .stat-label{font-size:12px}.invoices-list{display:flex;flex-direction:column;gap:8px}.invoice-item{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:12px;padding:12px}.invoice-date{color:#64748b;font-size:13px}.invoice-status{flex:1 1;font-size:12px;font-weight:500;text-transform:uppercase}.invoice-status.paid{color:#16a34a}.invoice-status.pending{color:#d97706}.invoice-amount{color:#1e293b;font-weight:600}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:14px;padding:12px 16px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn-cancel{background:#f1f5f9;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.btn-cancel:hover{background:#e2e8f0}.btn-save{background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.btn-save:hover{background:#4f46e5}@media (max-width:1024px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.admin-stats-grid{grid-template-columns:1fr;padding:0 16px}.admin-section{padding:0 16px}.admin-table-container{overflow-x:auto}.admin-table{min-width:800px}.detail-grid{grid-template-columns:1fr}.detail-stats{grid-template-columns:repeat(2,1fr)}.modal-content{border-radius:16px 16px 0 0;bottom:0;margin:0;max-height:85vh;max-width:100%;position:fixed}}
/*# sourceMappingURL=main.cec93aee.css.map*/