@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500&family=Poppins:wght@600;700&display=swap";:root{--gum-navy: #001E3D;--gum-gold: #F7B32B;--gum-coral: #FF6B6B;--gum-blue: #1DA1F2;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--gum-blue);text-decoration:inherit}a:hover{color:var(--gum-navy)}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-family:Poppins,sans-serif;font-weight:700;font-size:3.2em;line-height:1.1;color:var(--gum-navy)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--gum-gold);color:var(--gum-navy);cursor:pointer;transition:all .25s}button:hover{background-color:var(--gum-coral);color:#fff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f8f9fa;--color-bg-tertiary: #e9ecef;--color-text-primary: #212529;--color-text-secondary: #6c757d;--color-text-muted: #adb5bd;--color-border: #dee2e6;--color-border-light: #f8f9fa;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--border-radius: 8px;--border-radius-sm: 4px;--border-radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--header-height: 60px;--mobile-nav-height: 60px}*{box-sizing:border-box}body{background-color:var(--color-bg-primary);color:var(--color-text-primary);overflow-x:hidden}#root{display:flex;flex-direction:column}button.secondary{background-color:var(--gum-navy);color:#fff}button.secondary:hover{background-color:#002951}button.ghost{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}button.ghost:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.bg-primary{background-color:var(--color-bg-primary)}.bg-secondary{background-color:var(--color-bg-secondary)}.bg-tertiary{background-color:var(--color-bg-tertiary)}.heading-font{font-family:Poppins,sans-serif;font-weight:600}.heading-font-bold{font-family:Poppins,sans-serif;font-weight:700}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.px-md{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.py-md{padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.mb-md{margin-bottom:var(--spacing-md)}.mt-md{margin-top:var(--spacing-md)}.rounded{border-radius:var(--border-radius)}.rounded-sm{border-radius:var(--border-radius-sm)}.rounded-lg{border-radius:var(--border-radius-lg)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.border{border:1px solid var(--color-border)}.border-light{border:1px solid var(--color-border-light)}@media (max-width: 768px){:root{--spacing-md: .75rem;--spacing-lg: 1rem}.container{padding:0 var(--spacing-sm)}}.points-badge{display:inline-flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 12px;border-radius:20px;text-decoration:none;transition:transform .2s,box-shadow .2s;cursor:pointer;font-size:.875rem}.points-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.badge-content{display:flex;align-items:center;gap:4px}.badge-icon{font-size:1rem}.badge-value{font-weight:600}.badge-streak{font-size:.875rem;margin-left:2px}.badge-level{font-size:.625rem;opacity:.9;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.points-badge{padding:4px 8px;font-size:.75rem}.badge-icon{font-size:.875rem}.badge-level{display:none}}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background-color:var(--gum-navy);color:#fff;border-bottom:1px solid rgba(255,255,255,.1);z-index:1000;box-shadow:var(--shadow-md)}.header-container{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.menu-toggle{color:#fff;padding:var(--spacing-xs)}.menu-toggle:hover{background-color:#ffffff1a;color:#fff}.logo-link{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:#fff}.logo-link:hover{text-decoration:none;color:var(--gum-gold)}.logo{height:32px;width:32px}.logo-text{font-size:1.25rem;color:var(--gum-gold)}.header-nav{display:flex;align-items:center;gap:var(--spacing-lg)}.nav-link{color:#fff;text-decoration:none;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);transition:all .2s ease}.nav-link:hover{background-color:#ffffff1a;color:var(--gum-gold);text-decoration:none}.nav-link.active{background-color:var(--gum-gold);color:var(--gum-navy)}.admin-link{background:#dc267f33;padding:4px 12px;border-radius:4px;border:1px solid rgba(220,38,127,.3)}.admin-link:hover{background:#dc267f4d;color:#fff}.nav-dropdown{position:relative;display:inline-block}.dropdown-trigger{color:#fff;text-decoration:none;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);transition:all .2s ease;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:inherit}.dropdown-trigger:hover{background-color:#ffffff1a;color:var(--gum-gold)}.dropdown-arrow{transition:transform .2s ease;stroke:currentColor}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1100;padding:8px 0;margin-top:4px}.user-menu-dropdown{right:0;left:auto}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#333;text-decoration:none;transition:all .2s ease;border:none;background:none;width:100%;text-align:left;cursor:pointer;font-size:14px}.dropdown-item:hover{background-color:#f8f9fa;color:#667eea;text-decoration:none}.dropdown-item.logout-item{color:#dc3545}.dropdown-item.logout-item:hover{background-color:#fff5f5;color:#dc3545}.dropdown-icon{font-size:16px;width:20px;text-align:center}.dropdown-divider{border:none;border-top:1px solid #e0e0e0;margin:8px 0}.user-dropdown .user-trigger{display:flex;align-items:center;gap:8px;background:none;border:none;color:#fff;cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);transition:all .2s ease}.user-dropdown .user-trigger:hover{background-color:#ffffff1a;color:var(--gum-gold)}.user-dropdown .username{font-weight:500}.header-right,.user-menu{display:flex;align-items:center;gap:var(--spacing-md)}.username{color:var(--gum-gold);font-weight:500;font-size:.875rem}.auth-buttons{display:flex;align-items:center;gap:var(--spacing-sm)}.auth-buttons .ghost{color:#fff;border-color:#ffffff4d}.auth-buttons .ghost:hover{background-color:#ffffff1a;border-color:var(--gum-gold);color:var(--gum-gold)}@media (max-width: 768px){.header-container{padding:0 var(--spacing-sm)}.header-nav{display:none}.user-menu{gap:var(--spacing-sm)}.user-dropdown .username{display:none}.user-dropdown .user-trigger{padding:var(--spacing-xs);min-width:40px;justify-content:center}.dropdown-menu{right:0;left:auto;min-width:180px}.auth-buttons{gap:var(--spacing-xs)}.auth-buttons button{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8rem}}.sidebar-countdown{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:1rem;color:#fff;margin-bottom:1rem;position:relative;overflow:hidden}.sidebar-countdown:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.sidebar-countdown--empty{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#4a5568}.sidebar-countdown--current{background:linear-gradient(135deg,#56ab2f,#a8e6cf);animation:glow 2s ease-in-out infinite alternate}.sidebar-countdown--past{background:linear-gradient(135deg,#bdc3c7,#2c3e50);opacity:.9}@keyframes glow{0%{box-shadow:0 4px 20px #56ab2f4d}to{box-shadow:0 6px 25px #56ab2f80}}.sidebar-countdown__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.sidebar-countdown__icon{font-size:1.25rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.sidebar-countdown__title{margin:0;font-size:.875rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.2)}.sidebar-countdown__text{margin:0 0 .75rem;font-size:.75rem;opacity:.9;line-height:1.4}.sidebar-countdown__trip-info{margin-bottom:.75rem}.sidebar-countdown__trip-name{font-weight:600;font-size:.875rem;margin-bottom:.25rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.sidebar-countdown__resort{font-size:.75rem;opacity:.9}.sidebar-countdown__time{display:flex;justify-content:space-between;margin-bottom:.75rem}.sidebar-countdown__days,.sidebar-countdown__hours{text-align:center;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:.5rem;border:1px solid rgba(255,255,255,.2);flex:1}.sidebar-countdown__days:not(:last-child){margin-right:.5rem}.sidebar-countdown__number{display:block;font-size:1.25rem;font-weight:800;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.3)}.sidebar-countdown__label{font-size:.625rem;opacity:.9;text-transform:uppercase;letter-spacing:.05em}.sidebar-countdown__date{font-size:.75rem;text-align:center;opacity:.9;margin-bottom:.75rem;font-weight:500}.sidebar-countdown__status{text-align:center;font-style:italic;font-size:.75rem;opacity:.9;margin-bottom:.75rem}.sidebar-countdown__link{display:block;text-align:center;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;text-decoration:none;padding:.5rem;border-radius:6px;font-size:.75rem;font-weight:600;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sidebar-countdown__link:hover{background:#ffffff4d;transform:translateY(-1px);color:#fff}.sidebar-countdown--empty .sidebar-countdown__link{background:#667eea;border-color:#667eea;color:#fff}.sidebar-countdown--empty .sidebar-countdown__link:hover{background:#5a6fd8;border-color:#5a6fd8}@media (max-width: 768px){.sidebar-countdown{padding:.875rem}.sidebar-countdown__time{gap:.375rem}.sidebar-countdown__days,.sidebar-countdown__hours{padding:.375rem}.sidebar-countdown__number{font-size:1.125rem}}.sidebar-countdown[data-days-until="1"] .sidebar-countdown__days,.sidebar-countdown[data-days-until="2"] .sidebar-countdown__days,.sidebar-countdown[data-days-until="3"] .sidebar-countdown__days{animation:pulse 1.5s ease-in-out infinite}.sidebar{width:280px;background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border);overflow-y:auto;height:calc(100vh - var(--header-height));position:sticky;top:var(--header-height);transition:transform .3s ease}.sidebar-content{padding:var(--spacing-lg) 0}.sidebar-section{padding:0 var(--spacing-lg);margin-bottom:var(--spacing-xl)}.sidebar-section:last-child{margin-bottom:0}.sidebar-title{font-size:1rem;color:var(--gum-navy);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--gum-gold)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.stat-item{text-align:center;padding:var(--spacing-md);background-color:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.stat-number{font-size:1.5rem;font-weight:700;color:var(--gum-coral);margin-bottom:var(--spacing-xs)}.stat-label{font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.quick-links{display:flex;flex-direction:column;gap:var(--spacing-xs)}.quick-link-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.2);border-radius:var(--border-radius);text-align:left;font-size:.875rem;color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;text-decoration:none}.quick-link-item:hover{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:#667eea4d;transform:translateY(-1px);text-decoration:none;color:var(--gum-navy)}.quick-link-icon{font-size:1.1rem;width:20px;text-align:center}.quick-link-name{font-weight:500}.category-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.category-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--border-radius);text-align:left;font-size:.875rem;color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;text-decoration:none}.category-item:hover{background-color:var(--color-bg-tertiary);color:var(--gum-navy);text-decoration:none}.category-item.active{background-color:var(--gum-gold);color:var(--gum-navy);font-weight:600}.category-icon{font-size:1.1rem;width:20px;text-align:center}.category-name{flex:1}.quick-links{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quick-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--border-radius);font-size:.875rem;transition:all .2s ease}.quick-link:hover{background-color:var(--color-bg-tertiary);color:var(--gum-navy);text-decoration:none}.link-icon{width:16px;text-align:center}.disney-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,var(--gum-coral),var(--gum-gold));border-radius:var(--border-radius-lg);color:#fff;box-shadow:var(--shadow-md)}.badge-icon{font-size:1.5rem}.badge-title{font-size:.875rem;font-weight:600;margin-bottom:var(--spacing-xs)}.badge-subtitle{font-size:.75rem;opacity:.9;line-height:1.3}.quick-link.premium-link{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.2)}.quick-link.premium-link:hover{background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea4d}@media (max-width: 768px){.sidebar{position:fixed;top:var(--header-height);left:0;bottom:var(--mobile-nav-height);width:280px;z-index:999;transform:translate(-100%);background-color:#fff;box-shadow:var(--shadow-lg)}.sidebar.mobile.show{transform:translate(0)}.sidebar-overlay{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background-color:#00000080;z-index:998}.sidebar-section{padding:0 var(--spacing-md);margin-bottom:var(--spacing-lg)}.stats-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.stat-item{padding:var(--spacing-sm)}.stat-number{font-size:1.25rem}}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-height);background-color:#fff;border-top:1px solid var(--color-border);z-index:1000;box-shadow:0 -2px 10px #0000001a}.mobile-nav-container{height:100%;display:flex;align-items:center;justify-content:space-around;padding:0 var(--spacing-sm)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--spacing-xs);min-width:60px;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--border-radius-sm);transition:all .2s ease;background:none;border:none;cursor:pointer;font-family:inherit}.nav-item:hover{color:var(--gum-navy);background-color:var(--color-bg-secondary);text-decoration:none}.nav-item.active{color:var(--gum-gold);font-weight:600}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-icon{font-size:1.25rem;transition:transform .2s ease}.nav-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.3px;font-weight:500}.write-button{background-color:var(--gum-gold);color:var(--gum-navy);border-radius:var(--border-radius-lg);font-weight:600}.write-button:hover{background-color:var(--gum-coral);color:#fff}@media (min-width: 769px){.mobile-nav{display:none}}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-body{display:flex;flex:1;margin-top:var(--header-height)}.main-content{flex:1;min-width:0;background-color:var(--color-bg-primary);padding:var(--spacing-lg);margin-bottom:var(--mobile-nav-height)}@media (min-width: 769px){.main-content{margin-bottom:0}}@media (max-width: 768px){.layout-body{flex-direction:column}.main-content{padding:var(--spacing-md)}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center}.loading-spinner{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md)}.loading-spinner.small{width:32px;height:32px}.loading-spinner.medium{width:48px;height:48px}.loading-spinner.large{width:64px;height:64px}.spinner-castle{font-size:2em;animation:bounce 1.5s ease-in-out infinite}.spinner-stars{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%}.spinner-stars span{position:absolute;font-size:.8em;color:var(--gum-gold);animation:sparkle 2s ease-in-out infinite}.spinner-stars span:nth-child(1){top:0;left:50%;transform:translate(-50%);animation-delay:0s}.spinner-stars span:nth-child(2){top:50%;right:0;transform:translateY(-50%);animation-delay:.7s}.spinner-stars span:nth-child(3){bottom:0;left:50%;transform:translate(-50%);animation-delay:1.4s}.loading-message{color:var(--color-text-secondary);font-size:.9rem;margin:0;font-style:italic}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes sparkle{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.loading-spinner.small .spinner-castle{font-size:1.2em}.loading-spinner.large .spinner-castle{font-size:2.5em}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;padding:var(--spacing-md)}.auth-modal{background-color:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;max-height:90vh;overflow-y:auto}.auth-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,var(--gum-navy),var(--gum-blue));border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;color:#fff}.auth-modal-title{margin:0;font-size:1.5rem;color:var(--gum-gold)}.auth-modal-close{background:none;border:none;color:#fff;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--border-radius-sm);transition:background-color .2s ease}.auth-modal-close:hover{background-color:#ffffff1a}.auth-modal-content{padding:var(--spacing-lg)}.auth-modal-subtitle{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);text-align:center;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-weight:600;color:var(--color-text-primary);font-size:.9rem}.form-input{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--border-radius);font-size:1rem;transition:border-color .2s ease;background-color:#fff}.form-input:focus{outline:none;border-color:var(--gum-blue);box-shadow:0 0 0 3px #1da1f21a}.form-input::placeholder{color:var(--color-text-muted)}.form-error{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background-color:#ffeaea;color:#d8000c;border-radius:var(--border-radius);font-size:.9rem;border:1px solid #ffcdd2}.error-icon{flex-shrink:0}.form-success{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background-color:#eafaf1;color:#155724;border-radius:var(--border-radius);font-size:.9rem;border:1px solid #c3e6cb}.success-icon{flex-shrink:0}.success-content{display:flex;flex-direction:column;gap:var(--spacing-lg);text-align:center;padding:var(--spacing-lg) 0}.success-content .form-success{margin-bottom:var(--spacing-md);text-align:left}.success-content .primary-btn{background-color:var(--color-primary);color:#fff;border:none;padding:var(--spacing-md);border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.success-content .primary-btn:hover{background-color:var(--color-primary-dark)}.auth-submit-button{padding:var(--spacing-md);font-size:1rem;font-weight:600;border-radius:var(--border-radius);margin-top:var(--spacing-sm);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.auth-submit-button:disabled{opacity:.7;cursor:not-allowed}.auth-switch{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.auth-switch p{margin:0;color:var(--color-text-secondary)}.auth-switch-button{background:none;border:none;color:var(--gum-blue);font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.auth-switch-button:hover{color:var(--gum-navy)}@media (max-width: 768px){.auth-modal-overlay{padding:var(--spacing-sm)}.auth-modal{max-height:95vh}.auth-modal-header{padding:var(--spacing-md)}.auth-modal-title{font-size:1.25rem}.auth-modal-content{padding:var(--spacing-md)}.form-input{font-size:16px}}.vote-buttons{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;min-width:60px;background:linear-gradient(135deg,#f7b32b0d,#1da1f20d);border-radius:16px;border:1px solid rgba(247,179,43,.1)}.vote-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid var(--color-border);border-radius:12px;background:#ffffffe6;color:var(--color-text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #001e3d14}.vote-button:hover:not(.disabled){background:#f7b32b1a;transform:translateY(-2px);box-shadow:0 4px 12px #001e3d26}.vote-button.upvote:hover:not(.disabled),.vote-button.upvote.active{background:linear-gradient(135deg,var(--gum-gold) 0%,#ffed4e 100%);color:var(--gum-navy);border-color:var(--gum-gold);box-shadow:0 4px 12px #f7b32b4d}.vote-button.downvote:hover:not(.disabled),.vote-button.downvote.active{background:linear-gradient(135deg,var(--gum-coral) 0%,#ff8e8e 100%);color:#fff;border-color:var(--gum-coral);box-shadow:0 4px 12px #ff6b6b4d}.vote-button.disabled{opacity:.5;cursor:not-allowed}.vote-count{font-size:.9rem;font-weight:700;text-align:center;min-height:20px;display:flex;align-items:center;color:var(--gum-navy);padding:4px 8px;border-radius:8px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(247,179,43,.2)}.vote-count.positive{color:var(--gum-gold);background:#f7b32b1a;border-color:var(--gum-gold)}.vote-count.negative{color:var(--gum-coral);background:#ff6b6b1a;border-color:var(--gum-coral)}@media (max-width: 768px){.vote-buttons{flex-direction:row;gap:12px;padding:12px 16px;min-width:auto;width:100%;justify-content:center;margin-bottom:16px;border-radius:20px}.vote-button{width:40px;height:40px;border-radius:16px}.vote-count{min-width:50px;font-size:.9rem;padding:6px 12px}}.post-card{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid var(--color-border);border-radius:16px;margin-bottom:var(--spacing-md);box-shadow:0 2px 8px #001e3d14;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.post-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gum-gold) 0%,var(--gum-coral) 50%,var(--gum-blue) 100%);opacity:0;transition:opacity .3s ease}.post-card:hover{box-shadow:0 8px 24px #001e3d26;transform:translateY(-2px)}.post-card:hover:before{opacity:1}.post-card .post-title-section{margin-bottom:16px}.post-content{display:flex;padding:20px;gap:var(--spacing-md)}.post-body{flex:1;min-width:0}.post-card .post-header{margin-bottom:0;padding:0}.post-meta{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;font-size:.75rem;opacity:.8;margin-top:12px;padding-top:12px;border-top:1px solid rgba(247,179,43,.1)}.category-badge{background:linear-gradient(135deg,var(--gum-gold) 0%,#ffed4e 100%);color:var(--gum-navy);padding:3px 8px;border-radius:16px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;box-shadow:0 1px 3px #f7b32b33;border:1px solid rgba(247,179,43,.2);position:relative;overflow:hidden;opacity:.9}.category-badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.category-badge:hover:before{left:100%}.post-author{color:var(--color-text-secondary);font-weight:500}.post-time{color:var(--color-text-muted)}.source-domain{color:var(--gum-blue);font-weight:500}.post-featured-image{width:100%;height:200px;border-radius:12px;overflow:hidden;margin-bottom:16px;background-color:var(--color-bg-tertiary);box-shadow:0 4px 16px #001e3d26;border:2px solid rgba(247,179,43,.15);position:relative;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.post-featured-image:hover{transform:translateY(-2px);box-shadow:0 8px 24px #001e3d33;border-color:#f7b32b4d}.post-featured-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s cubic-bezier(.4,0,.2,1)}.post-featured-image:hover img{transform:scale(1.05)}.post-main{margin-bottom:var(--spacing-md)}.post-card .post-text{width:100%}.post-card .post-title{margin:0 0 24px;font-size:2.4rem!important;font-weight:900!important;line-height:1.2!important;color:var(--gum-navy)!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;letter-spacing:-.04em;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;display:block;max-width:none!important;text-shadow:0 2px 4px rgba(0,30,61,.12)}.title-button{background:none;border:none;padding:0;font-size:inherit;font-weight:inherit;color:inherit;text-align:left;cursor:pointer;line-height:inherit;transition:all .2s ease;width:100%}.title-button:hover{color:var(--gum-blue)}.title-link{color:var(--gum-navy);text-decoration:none;transition:all .2s ease;display:inline-block;position:relative;width:100%;text-align:left;background:linear-gradient(90deg,var(--gum-blue) 0%,var(--gum-coral) 50%,var(--gum-gold) 100%);background-size:0% 3px;background-position:left bottom;background-repeat:no-repeat;padding-bottom:2px}.title-link:hover{color:transparent;background-clip:text;-webkit-background-clip:text;background-image:linear-gradient(90deg,var(--gum-blue) 0%,var(--gum-coral) 50%,var(--gum-gold) 100%);background-size:100% 100%;text-shadow:none;transform:translate(2px)}.post-card .external-link{color:var(--gum-navy);text-decoration:none;display:inline-flex;align-items:baseline;gap:6px;transition:all .2s ease;position:relative;background:linear-gradient(90deg,var(--gum-blue) 0%,var(--gum-coral) 50%,var(--gum-gold) 100%);background-size:0% 3px;background-position:left bottom;background-repeat:no-repeat;padding-bottom:2px}.post-card .external-link:hover{color:var(--gum-blue);text-shadow:0 1px 2px rgba(29,161,242,.2);transform:translate(2px)}.external-icon{color:var(--color-text-muted);flex-shrink:0}.post-excerpt{margin:0;color:var(--color-text-primary);line-height:1.5;font-size:1.1rem;font-weight:400;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-width:100%;overflow-wrap:break-word;opacity:.9}.post-full-content{margin-top:var(--spacing-sm)}.post-full-content p{margin:0;line-height:1.6;color:var(--color-text-primary)}.post-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(247,179,43,.2);background:linear-gradient(90deg,#f7b32b05,#1da1f205);border-radius:8px;padding:12px 16px;margin:16px -16px -16px}.post-stats{display:flex;gap:var(--spacing-md)}.stat{display:flex;align-items:center;gap:6px;color:var(--color-text-secondary);font-size:.85rem;font-weight:500;padding:4px 8px;border-radius:12px;background:#6c757d14;transition:all .2s ease}.stat svg{color:var(--gum-blue);width:18px;height:18px}.stat-link{text-decoration:none;color:inherit;transition:color .2s ease}.stat-link:hover{color:var(--gum-navy);text-decoration:none;background:#f7b32b26;transform:translateY(-1px)}.stat-link:hover svg{color:var(--gum-gold)}.post-actions{display:flex;gap:var(--spacing-sm)}.action-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fffc;border:1.5px solid var(--color-border);border-radius:20px;color:var(--color-text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.action-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.action-button:hover{background:linear-gradient(135deg,var(--gum-blue) 0%,rgba(29,161,242,.8) 100%);color:#fff;border-color:var(--gum-blue);transform:translateY(-2px);box-shadow:0 4px 12px #1da1f24d}.action-button:hover:before{left:100%}.action-button.saved{color:var(--gum-navy);background:linear-gradient(135deg,var(--gum-gold) 0%,#ffed4e 100%);border-color:var(--gum-gold);box-shadow:0 4px 12px #f7b32b4d}.action-button.saved svg{fill:var(--gum-navy)}.action-button.saved:hover{background:linear-gradient(135deg,#ffed4e 0%,var(--gum-gold) 100%);transform:translateY(-2px);box-shadow:0 6px 16px #f7b32b66}.action-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.post-content{flex-direction:column;padding:16px}.post-featured-image{height:180px;margin-bottom:20px}.post-card .post-title{font-size:1.9rem!important;line-height:1.25!important;margin-bottom:20px;max-width:none!important;font-weight:900!important}.post-meta{font-size:.7rem;gap:6px;margin-bottom:16px;opacity:.7}.category-badge{font-size:.7rem;padding:3px 10px}.post-footer{flex-direction:column;gap:16px;align-items:stretch;margin:20px -16px -16px;padding:16px;border-radius:0 0 16px 16px}.post-stats{justify-content:space-around;gap:8px}.stat{font-size:.8rem;padding:6px 10px;flex:1;justify-content:center}.post-actions{justify-content:center;gap:12px}.action-button{flex:1;justify-content:center;padding:10px 16px;font-size:.85rem}}.sort-controls{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.sort-label{font-weight:600;color:var(--color-text-primary);font-size:.9rem}.sort-buttons{display:flex;gap:var(--spacing-sm)}.sort-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.sort-button:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--gum-blue)}.sort-button.active{background-color:var(--gum-gold);color:var(--gum-navy);border-color:var(--gum-gold);font-weight:600}.sort-icon{font-size:1rem}.sort-text{font-family:inherit}@media (max-width: 768px){.sort-controls{flex-direction:column;align-items:stretch;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm)}.sort-label{text-align:center}.sort-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-xs)}.sort-button{justify-content:center;padding:var(--spacing-sm);font-size:.8rem}}.post-feed{width:100%;max-width:800px}.posts-list{display:flex;flex-direction:column}.loading-more{padding:var(--spacing-lg);text-align:center}.feed-error{display:flex;justify-content:center;align-items:center;min-height:400px;padding:var(--spacing-xl)}.error-content{text-align:center;max-width:400px}.error-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.error-title{color:var(--gum-navy);margin-bottom:var(--spacing-sm);font-size:1.25rem}.error-message{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);line-height:1.5}.no-posts{display:flex;justify-content:center;align-items:center;min-height:300px;padding:var(--spacing-xl)}.no-posts-content{text-align:center;max-width:400px}.no-posts-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.no-posts-title{color:var(--gum-navy);margin-bottom:var(--spacing-sm);font-size:1.25rem}.no-posts-message{color:var(--color-text-secondary);line-height:1.5;margin:0}.end-of-feed{text-align:center;padding:var(--spacing-xl);margin-top:var(--spacing-lg)}.end-message{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);color:var(--color-text-muted);font-style:italic;font-size:.9rem}.end-icon{color:var(--gum-gold);font-size:1.1rem}.error-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background-color:var(--gum-coral);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--spacing-md);z-index:1001;animation:slideUp .3s ease}.error-toast-message{font-size:.9rem;font-weight:500}.error-toast-retry{color:#fff;border-color:#ffffff4d;font-size:.8rem;padding:var(--spacing-xs) var(--spacing-sm)}.error-toast-retry:hover{background-color:#ffffff1a;border-color:#fff}@keyframes slideUp{0%{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%);opacity:1}}@media (max-width: 768px){.post-feed{max-width:100%}.error-toast{bottom:80px;left:var(--spacing-md);right:var(--spacing-md);transform:none}.end-message{flex-direction:column;gap:var(--spacing-xs)}.feed-error,.no-posts{min-height:250px;padding:var(--spacing-lg)}.error-content,.no-posts-content{max-width:100%}.error-title,.no-posts-title{font-size:1.125rem}.error-icon,.no-posts-icon{font-size:2.5rem}}.home-page{width:100%;max-width:800px;margin:0 auto}.home-header{text-align:center;margin-bottom:var(--spacing-xl);padding:var(--spacing-lg) 0;background:linear-gradient(135deg,var(--gum-navy),var(--gum-blue));border-radius:var(--border-radius-lg);color:#fff;box-shadow:var(--shadow-md)}.home-title{font-size:2.5rem;color:var(--gum-gold);margin-bottom:var(--spacing-sm);text-shadow:2px 2px 4px rgba(0,0,0,.3)}.home-subtitle{font-size:1.125rem;opacity:.9;max-width:600px;margin:0 auto;line-height:1.5}@media (max-width: 768px){.home-header{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);border-radius:var(--border-radius)}.home-title{font-size:2rem}.home-subtitle{font-size:1rem}}.post-detail-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;position:relative}.post-detail-page:before{content:"";position:absolute;top:0;left:0;right:0;height:400px;background:linear-gradient(135deg,#667eeae6,#764ba2e6);z-index:1}.post-detail-container{max-width:1400px;margin:0 auto;padding:0 1rem;position:relative;z-index:2}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.loading-spinner{width:3rem;height:3rem;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.loading-text{color:var(--color-text-secondary);font-size:1.125rem}.error-container{text-align:center;padding:3rem 2rem;max-width:500px;margin:2rem auto}.error-icon{font-size:4rem;margin-bottom:1rem}.error-title{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.75rem}.error-description{color:var(--color-text-secondary);margin-bottom:2rem;line-height:1.6}.back-to-home-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-radius:.75rem;text-decoration:none;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #3b82f64d}.back-to-home-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666;text-decoration:none;color:#fff}.post-nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;margin-bottom:2rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;color:#fff;text-decoration:none;border-radius:1rem;transition:all .3s ease;font-weight:600;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.back-link:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 12px 40px #0003;text-decoration:none;color:#fff}.user-info .welcome-text{color:#ffffffe6;font-size:1rem;font-weight:500}.hero-title-section{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:2rem;border:1px solid rgba(255,255,255,.1);margin-bottom:3rem;padding:3rem;box-shadow:0 20px 60px #0000001a;position:relative;overflow:hidden}.hero-title-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(255,255,255,.05),transparent,rgba(255,255,255,.05));pointer-events:none}.hero-title-content{position:relative;z-index:2}.post-metadata-hero{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:2rem}.category-badge-hero{padding:.5rem 1.25rem;border-radius:2rem;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff;box-shadow:0 4px 20px #0003}.adults-only-badge-hero{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;padding:.5rem 1rem;border-radius:1rem;font-size:.875rem;font-weight:700;box-shadow:0 4px 20px #ee5a244d}.post-meta-text-hero{display:flex;align-items:center;gap:.75rem;color:#fffc;font-size:1rem}.author-hero{font-weight:700;color:#fff}.source-domain-hero{color:#74b9ff;font-weight:600}.hero-title{font-size:3.5rem;font-weight:900;line-height:1.1;color:#fff;margin:0;text-shadow:0 4px 20px rgba(0,0,0,.3);letter-spacing:-.02em}.external-hero-link{display:flex;align-items:flex-start;gap:1rem;color:inherit;text-decoration:none;transition:all .3s ease}.external-hero-link:hover{color:#74b9ff;text-decoration:none;transform:translateY(-2px)}.external-hero-icon{flex-shrink:0;margin-top:.5rem;opacity:.7;transition:all .3s ease}.external-hero-link:hover .external-hero-icon{opacity:1;transform:scale(1.1)}.floating-vote-container{position:absolute;right:2rem;top:50%;transform:translateY(-50%);background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:1.5rem;padding:1rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 10px 40px #0003}.content-layout{display:grid;grid-template-columns:2fr 1fr;gap:3rem;margin-bottom:4rem}.main-content-column{background:#fff;border-radius:2rem;box-shadow:0 20px 60px #0000001a;overflow:hidden;border:1px solid rgba(255,255,255,.2)}.post-article{padding:3rem}.featured-image-compact{float:right;margin:0 0 2rem 2rem;width:300px;max-width:40%}.featured-image-small{width:100%;height:auto;border-radius:1rem;box-shadow:0 10px 30px #00000026}.article-content{margin-bottom:2rem}.content-text-enhanced{font-size:1.2rem;line-height:1.8;color:#2d3748;font-weight:400;text-align:justify}.interactive-stats-bar{border-top:1px solid #f1f5f9;padding-top:2rem;margin-top:3rem}.stats-group{display:flex;gap:1rem}.stat-button{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;cursor:pointer;transition:all .3s ease;min-width:100px}.stat-button:hover{background:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 10px 30px #3b82f64d}.stat-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 10px 30px #667eea4d}.stat-number{font-weight:700;font-size:1.125rem}.stat-label{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.content-sidebar{display:flex;flex-direction:column;gap:1.5rem}.sidebar-card{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 10px 30px #00000014;border:1px solid #f1f5f9}.sidebar-title{font-size:1.25rem;font-weight:700;color:#1a202c;margin:0 0 1.5rem}.sidebar-stats{display:flex;flex-direction:column;gap:1rem}.sidebar-stat{display:flex;flex-direction:column;gap:.25rem}.sidebar-stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.sidebar-stat-value{font-weight:600;color:#1e293b}.sidebar-stat-link{font-weight:600;color:#3b82f6;text-decoration:none}.sidebar-stat-link:hover{text-decoration:underline}.post-detail-page .post-header{padding:2rem 2rem 1rem;border-bottom:1px solid #f1f5f9}.post-metadata{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem}.category-badge{display:inline-block;padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff}.adults-only-badge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:.25rem .625rem;border-radius:.5rem;font-size:.75rem;font-weight:600}.post-meta-text{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.875rem}.author{font-weight:600;color:var(--color-text-primary)}.separator{color:var(--color-text-muted)}.source-domain{color:#3b82f6;font-weight:500}.post-detail-page .post-title-section{padding:0 2rem 1.5rem}.post-detail-page .post-title{font-size:2rem;font-weight:800;line-height:1.2;color:var(--color-text-primary);margin:0}.external-title-link{display:flex;align-items:flex-start;gap:.75rem;color:inherit;text-decoration:none;transition:color .2s ease}.external-title-link:hover{color:#3b82f6;text-decoration:none}.external-icon{flex-shrink:0;margin-top:.25rem;opacity:.6;transition:opacity .2s ease}.external-title-link:hover .external-icon{opacity:1}.featured-image-container{margin:0 2rem 2rem}.featured-image{width:100%;height:auto;border-radius:.75rem;box-shadow:0 4px 20px #0000001a}.post-content{padding:0 2rem 2rem}.content-text{font-size:1.125rem;line-height:1.8;color:var(--color-text-primary);white-space:pre-wrap}.post-stats-bar{display:flex;gap:2rem;padding:1.5rem 2rem;background:#f8fafc;border-top:1px solid #e5e7eb}.stat-item{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.875rem}.stat-number{font-weight:700;color:var(--color-text-primary)}.stat-label{color:var(--color-text-secondary)}.comments-section-wide{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:3rem 3rem 0 0;box-shadow:0 -10px 60px #0000001a;border:1px solid rgba(255,255,255,.3);margin:0 -2rem;padding:4rem 2rem 2rem;position:relative}.comments-section-wide:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:80px;height:6px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px}.comments-container-wide{max-width:1400px;margin:0 auto;padding:0 2rem}.comments-header-wide{text-align:center;margin-bottom:3rem}.comments-title-wide{font-size:2.5rem;font-weight:900;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1rem;text-align:center}.login-prompt-wide{text-align:center;padding:2rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:2rem;border:2px dashed rgba(102,126,234,.3);margin-bottom:2rem}.login-text{font-size:1.125rem;color:#4a5568;font-weight:500}.login-link-wide{color:#667eea;text-decoration:none;font-weight:700;padding:.25rem .5rem;border-radius:.5rem;transition:all .2s ease}.login-link-wide:hover{background:#667eea1a;text-decoration:none;transform:translateY(-1px)}.comments-content-wide{background:#fff;border-radius:2rem;padding:2rem;box-shadow:0 20px 60px #0000000d;border:1px solid #f1f5f9}.comments-content-wide textarea{width:100%!important;max-width:none!important;min-width:100%!important;box-sizing:border-box!important}.comments-content-wide .space-y-6>*{width:100%!important}.comment-item-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000000d;transition:all .2s ease}.comment-item-card:hover{box-shadow:0 4px 16px #0000001a;border-color:#cbd5e1}.comment-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.comment-avatar{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0}.comment-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.comment-username{font-weight:600;color:#1e293b}.comment-username-link{color:var(--gum-blue);text-decoration:none;font-weight:600;transition:all .2s ease}.comment-username-link:hover{color:var(--gum-navy);text-decoration:underline}.comment-time{color:#64748b;font-size:.875rem}.comment-edited{background:#dbeafe;color:#1d4ed8;font-size:.75rem;padding:.125rem .5rem;border-radius:.375rem;font-weight:500}.comment-content{color:#334155;line-height:1.6;margin-bottom:1rem;font-size:1rem}.comment-actions{display:flex;gap:1rem;align-items:center}.comment-action-button{background:none;border:none;color:#64748b;font-size:.875rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:.375rem;transition:all .2s ease}.comment-action-button:hover{background:#f1f5f9;color:#334155}.comment-reply-button:hover{color:#2563eb;background:#dbeafe}.comment-edit-button:hover{color:#059669;background:#d1fae5}.comment-delete-button:hover{color:#dc2626;background:#fee2e2}.comment-replies{margin-left:2rem;padding-left:1rem;border-left:2px solid #e2e8f0;margin-top:1rem}.comment-form-container{width:100%!important;max-width:none!important}.comment-form-container form,.comment-textarea-container{width:100%!important}.comment-textarea-container textarea{width:100%!important;min-width:100%!important;resize:vertical!important}@media (max-width: 768px){.post-detail-container{padding:0 .5rem}.post-nav{padding:1rem 0;margin-bottom:1rem}.hero-title-section{padding:2rem 1rem;margin:0 -.5rem 2rem;border-radius:1rem}.hero-title{font-size:2rem}.floating-vote-container{position:static;transform:none;margin:2rem auto 0;width:fit-content}.content-layout{grid-template-columns:1fr;gap:1.5rem}.post-article{padding:1.5rem}.featured-image-compact{float:none;width:100%;max-width:100%;margin:0 0 1.5rem}.content-text-enhanced{font-size:1rem;text-align:left}.stats-group{flex-direction:column}.content-sidebar{order:-1}.sidebar-card{padding:1.5rem}.comments-section-wide{margin:0 -.5rem;padding:2rem .5rem;border-radius:2rem 2rem 0 0}.comments-container-wide{padding:0 1rem}.comments-title-wide{font-size:1.75rem}.comments-content-wide{padding:1rem}.user-info{display:none}}@media (prefers-color-scheme: dark){.post-detail-page{background:linear-gradient(to bottom,#0f172a,#1e293b)}.post-main-content,.comments-section{background:#1e293b;border-color:#334155}.post-header{border-bottom-color:#334155}.post-stats-bar{background:#0f172a;border-top-color:#334155}.comments-header{border-bottom-color:#334155}}.about-page{max-width:800px;margin:0 auto;padding:2rem}.page-header{text-align:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--border-color)}.page-header h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-primary)}.page-subtitle{font-size:1.2rem;color:var(--text-secondary);font-style:italic}.content-section{display:flex;flex-direction:column;gap:2.5rem}.about-section{background:var(--surface-color);padding:2rem;border-radius:12px;border:1px solid var(--border-color)}.about-section h2{font-size:1.5rem;margin-bottom:1rem;color:var(--primary-color);border-bottom:2px solid var(--primary-color);padding-bottom:.5rem}.about-section p{line-height:1.7;margin-bottom:1rem;color:var(--text-primary)}.about-section p:last-child{margin-bottom:0}.feature-list{list-style:none;padding:0;margin:0}.feature-list li{padding:1rem;margin-bottom:1rem;background:var(--background-color);border-radius:8px;border-left:4px solid var(--primary-color);line-height:1.6}.feature-list li:last-child{margin-bottom:0}.feature-list strong{color:var(--primary-color);display:block;margin-bottom:.5rem}@media (max-width: 768px){.about-page{padding:1rem}.page-header{margin-bottom:2rem;padding-bottom:1.5rem}.page-header h1{font-size:2rem}.about-section{padding:1.5rem}.content-section{gap:1.5rem}}.rules-page{max-width:900px;margin:0 auto;padding:2rem}.rules-intro{background:var(--surface-color);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);margin-bottom:2rem;border-left:4px solid var(--primary-color)}.rules-intro p{margin:0;line-height:1.6;color:var(--text-primary)}.rules-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.rule-item{display:flex;gap:1.5rem;background:var(--surface-color);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.rule-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.rule-number{flex-shrink:0;width:40px;height:40px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.rule-content h3{margin:0 0 .75rem;color:var(--primary-color);font-size:1.2rem}.rule-content p{margin:0;line-height:1.6;color:var(--text-primary)}.rules-footer{background:var(--surface-color);padding:2rem;border-radius:12px;border:1px solid var(--border-color);border-top:4px solid var(--accent-color)}.rules-footer h3{color:var(--accent-color);margin-top:0;margin-bottom:1rem;font-size:1.3rem}.rules-footer h3:not(:first-child){margin-top:2rem}.rules-footer p{line-height:1.6;margin-bottom:0;color:var(--text-primary)}@media (max-width: 768px){.rules-page{padding:1rem}.rule-item{flex-direction:column;gap:1rem;padding:1.25rem}.rule-number{align-self:flex-start}.rules-intro,.rules-footer{padding:1.25rem}.rules-list{gap:1rem}}@media (max-width: 480px){.rule-item{padding:1rem}.rule-number{width:32px;height:32px;font-size:1rem}.rule-content h3{font-size:1.1rem}}.contact-page{max-width:1200px;margin:0 auto;padding:2rem}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2rem}.contact-info{display:flex;flex-direction:column;gap:2rem}.info-section{background:var(--surface-color);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color)}.info-section h3{margin:0 0 1rem;color:var(--primary-color);font-size:1.2rem}.info-section p{margin:0;line-height:1.6;color:var(--text-primary)}.contact-topics{list-style:none;padding:0;margin:0}.contact-topics li{padding:.5rem 0;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.contact-topics li:last-child{border-bottom:none}.contact-form-container{background:var(--surface-color);padding:2rem;border-radius:12px;border:1px solid var(--border-color);height:fit-content}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--background-color);color:var(--text-primary);transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.form-group textarea{resize:vertical;min-height:120px}.submit-btn{padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;margin-top:1rem}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.form-message{padding:1rem;border-radius:8px;font-weight:500;text-align:center}.form-message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#15803d}.form-message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#b91c1c}@media (max-width: 768px){.contact-page{padding:1rem}.contact-content{grid-template-columns:1fr;gap:2rem}.contact-form-container{padding:1.5rem}.info-section{padding:1.25rem}}@media (max-width: 480px){.contact-form-container,.info-section{padding:1rem}.form-group input,.form-group select,.form-group textarea{padding:.625rem}.submit-btn{padding:.875rem 1.5rem}}.saved-articles-container{max-width:1200px;margin:0 auto;padding:var(--spacing-lg);min-height:calc(100vh - 200px)}.saved-header{text-align:center;margin-bottom:var(--spacing-xl);position:relative;padding:var(--spacing-xl) 0;background:linear-gradient(135deg,#ffd7000d,#8a2be20d);border-radius:var(--border-radius-lg);overflow:hidden}.saved-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,215,0,.1) 0%,transparent 70%);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{transform:translate(-50%) translateY(-50%) scale(1);opacity:.5}50%{transform:translate(-50%) translateY(-50%) scale(1.1);opacity:.8}}.saved-header-content{position:relative;z-index:1}.saved-title{font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-sm);display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.magic-sparkle{font-size:1.5rem;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:.8}50%{transform:scale(1.2) rotate(180deg);opacity:1}}.saved-subtitle{font-size:1.1rem;color:var(--color-text-secondary);margin:0}.saved-decorations{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;overflow:hidden}.decoration{position:absolute;font-size:2rem;opacity:.3;animation:float 6s ease-in-out infinite}.decoration.castle{top:20%;left:10%;animation-delay:0s}.decoration.mickey{top:60%;right:15%;animation-delay:2s}.decoration.wand{bottom:20%;left:20%;animation-delay:4s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(10deg)}}.saved-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap;justify-content:center}.filter-chip{padding:var(--spacing-xs) var(--spacing-md);border-radius:20px;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all .3s ease;border:2px solid transparent;font-weight:500}.filter-chip:hover{background-color:#8a2be21a;color:var(--gum-purple);border-color:var(--gum-purple);transform:translateY(-2px)}.filter-chip.active{background-color:var(--gum-gold);color:#fff;border-color:var(--gum-gold)}.saved-posts{display:flex;flex-direction:column;gap:var(--spacing-md)}.saved-post-wrapper{position:relative}.saved-info{padding:var(--spacing-sm) var(--spacing-md);background-color:#ffd7000d;border-top:2px solid var(--gum-gold);margin-top:-1px;border-radius:0 0 var(--border-radius) var(--border-radius);font-size:.9rem}.saved-date{color:var(--color-text-secondary);font-style:italic}.saved-notes{margin-top:var(--spacing-xs);padding:var(--spacing-xs);background-color:#fff;border-radius:var(--border-radius-sm);display:flex;align-items:center;gap:var(--spacing-xs)}.notes-icon{font-size:1rem}.empty-state,.loading-state,.error-state{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);background-color:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);margin:var(--spacing-xl) auto;max-width:600px}.empty-icon,.error-icon{font-size:4rem;margin-bottom:var(--spacing-md);animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state h2,.error-state h2{color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.empty-state p,.error-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.magic-tips{background-color:var(--color-bg-secondary);border-radius:var(--border-radius);padding:var(--spacing-md);margin:var(--spacing-lg) 0;text-align:left}.magic-tips h3{color:var(--gum-purple);margin-bottom:var(--spacing-sm);font-size:1.1rem}.magic-tips ul{list-style:none;padding:0;margin:0}.magic-tips li{padding:var(--spacing-xs) 0;color:var(--color-text-secondary);position:relative;padding-left:var(--spacing-lg)}.magic-tips li:before{content:"🌟";position:absolute;left:0}.magic-button{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--gum-gold) 0%,var(--gum-purple) 100%);color:#fff;text-decoration:none;border-radius:25px;font-weight:600;transition:all .3s ease;border:none;cursor:pointer;position:relative;overflow:hidden}.magic-button:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.magic-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #8a2be24d}.magic-button:hover:before{opacity:1}.load-more-container{text-align:center;margin:var(--spacing-xl) 0}.magic-button.load-more{padding:var(--spacing-md) var(--spacing-xl);font-size:1.1rem}.magic-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.saved-footer{text-align:center;padding:var(--spacing-xl) 0;margin-top:var(--spacing-xl);border-top:2px solid var(--color-border-light)}.footer-decoration{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--color-text-secondary);font-style:italic;font-size:1.1rem}.footer-decoration span:first-child,.footer-decoration span:last-child{font-size:1.5rem;animation:twinkle 3s ease-in-out infinite}@keyframes twinkle{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.loading-state{padding:var(--spacing-xl)}.loading-state p{margin-top:var(--spacing-md);color:var(--color-text-secondary);font-size:1.1rem}@media (max-width: 768px){.saved-articles-container{padding:var(--spacing-md)}.saved-title{font-size:1.8rem}.saved-subtitle{font-size:1rem}.decoration{font-size:1.5rem}.saved-filters{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:var(--spacing-sm)}.filter-chip{flex-shrink:0}.empty-icon,.error-icon{font-size:3rem}}.trip-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px #0000000d;border:1px solid #e2e8f0;border-top:4px solid #667eea;transition:all .3s ease;position:relative;overflow:hidden}.trip-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.trip-card--current{background:linear-gradient(135deg,#56ab2f0d,#a8e6cf0d);border-color:#56ab2f}.trip-card--past{opacity:.85;background:linear-gradient(135deg,#bdc3c70d,#2c3e500d)}.trip-card__badge{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.trip-card__badge--current{background:linear-gradient(135deg,#56ab2f,#a8e6cf);color:#fff;animation:pulse 2s ease-in-out infinite}.trip-card__badge--past{background:linear-gradient(135deg,#bdc3c7,#2c3e50);color:#fff}.trip-card__badge--soon{background:linear-gradient(135deg,#ff6b6b,orange);color:#fff;animation:bounce 1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.trip-card__header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding-right:5rem}.trip-card__icon{font-size:2.5rem;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.trip-card__title-section{flex:1;min-width:0}.trip-card__title{margin:0 0 .25rem;font-size:1.25rem;font-weight:700;line-height:1.2}.trip-card__link{color:#2d3748;text-decoration:none;transition:color .3s ease}.trip-card__link:hover{color:#667eea}.trip-card__type{color:#718096;font-size:.875rem;font-weight:500}.trip-card__resort{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;color:#4a5568;background:#f7fafc;padding:.5rem .75rem;border-radius:8px}.trip-card__resort-icon{font-size:1rem}.trip-card__dates{margin-bottom:1rem}.trip-card__date-range{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#2d3748;margin-bottom:.25rem}.trip-card__date-icon{font-size:.875rem;opacity:.7}.trip-card__duration{font-size:.875rem;color:#718096;margin-left:1.375rem}.trip-card__meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.875rem}.trip-card__party-size,.trip-card__reactions{display:flex;align-items:center;gap:.25rem;color:#4a5568}.trip-card__meta-icon{opacity:.7}.trip-card__countdown{margin-bottom:1rem;padding:.75rem;border-radius:8px;text-align:center;font-weight:600}.trip-card__countdown-current{background:linear-gradient(135deg,#56ab2f1a,#a8e6cf1a);color:#38a169}.trip-card__countdown-future{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#667eea}.trip-card__countdown-icon{margin-right:.5rem}.trip-card__visibility{margin-bottom:1rem}.trip-card__visibility-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500}.trip-card__visibility-badge--public{background:#48bb781a;color:#38a169}.trip-card__visibility-badge--private{background:#a0aec033;color:#4a5568}.trip-card__actions{display:flex;gap:.5rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid #e2e8f0}.trip-card__action{padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .3s ease;flex:1;text-align:center;min-width:fit-content}.trip-card__action--view{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.trip-card__action--view:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.trip-card__action--edit{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.trip-card__action--edit:hover{background:#edf2f7;border-color:#cbd5e0}.trip-card__action--archive{background:#fff5e6;color:#d69e2e;border:1px solid #fbd38d}.trip-card__action--archive:hover{background:#ffeaa7}.trip-card__action--delete{background:#fed7d7;color:#e53e3e;border:1px solid #feb2b2}.trip-card__action--delete:hover{background:#fbb6ce}@media (max-width: 768px){.trip-card{padding:1rem}.trip-card__header{padding-right:3rem}.trip-card__icon{font-size:2rem}.trip-card__title{font-size:1.125rem}.trip-card__badge{font-size:.625rem;padding:.25rem .5rem}.trip-card__actions{flex-direction:column}.trip-card__action{flex:none}}@media (max-width: 480px){.trip-card{padding:.875rem}.trip-card__header{flex-direction:column;align-items:center;text-align:center;padding-right:1rem}.trip-card__icon{font-size:2.5rem;margin-bottom:.5rem}.trip-card__badge{position:static;margin-bottom:1rem;align-self:center}.trip-card__meta{flex-direction:column;gap:.5rem;align-items:flex-start}}.profile-page{max-width:800px;margin:0 auto;padding:var(--spacing-xl);background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md)}.profile-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.avatar{width:120px;height:120px;border-radius:50%;background:var(--gum-gold);color:var(--gum-navy);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.profile-info h1{margin:0 0 var(--spacing-sm) 0;color:var(--color-text-primary)}.profile-meta{color:var(--color-text-secondary);font-size:.9rem;margin:var(--spacing-xs) 0}.disney-memberships{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.membership-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:500;background:var(--color-bg-tertiary);border:1px solid var(--color-border)}.dvc-badge{background:linear-gradient(135deg,#5b3a99,#8b6bb1);color:#fff;border-color:#5b3a99}.pass-badge{background:linear-gradient(135deg,orange,gold);color:#333;border-color:orange}.rundisney-badge{background:linear-gradient(135deg,#ff1744,#ff6b6b);color:#fff;border-color:#ff1744}.checkbox-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.checkbox-item{display:flex;align-items:center;gap:var(--spacing-sm)}.checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-item label{cursor:pointer;margin:0}.points-summary{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:20px;color:#fff;margin:16px 0}.points-summary.public{background:linear-gradient(135deg,#4caf50,#45a049)}.points-display{display:flex;flex-wrap:wrap;gap:20px;align-items:center;margin-bottom:16px}.points-value{font-size:2rem;font-weight:700;line-height:1}.achievement-display{display:flex;flex-direction:column;gap:4px}.level-badge{display:flex;align-items:center;gap:8px;background:#fff3;padding:8px 12px;border-radius:20px}.badge-img{width:24px;height:24px;object-fit:contain}.level-name{font-weight:600}.level-description{font-size:.75rem;opacity:.9;margin-left:32px}.streak-display{display:flex;align-items:center;gap:8px;background:#fff3;padding:8px 12px;border-radius:20px}.streak-text{font-weight:600;font-size:.875rem}.points-actions{display:flex;gap:12px;flex-wrap:wrap}.points-actions .btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:20px;text-decoration:none;font-size:.875rem;transition:all .2s}.points-actions .btn:hover{background:#ffffff4d;transform:translateY(-1px)}.points-empty{color:#666;font-style:italic;padding:20px;text-align:center}.premium-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:linear-gradient(135deg,var(--gum-gold),#ffed4e);color:var(--gum-navy);padding:var(--spacing-xs) var(--spacing-sm);border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.profile-content{display:grid;gap:var(--spacing-xl)}.profile-section{background:var(--color-bg-primary);padding:var(--spacing-lg);border-radius:var(--border-radius);border:1px solid var(--color-border)}.profile-section h2{margin:0 0 var(--spacing-md) 0;color:var(--color-text-primary);font-size:1.25rem}.bio-content{color:var(--color-text-secondary);line-height:1.6}.bio-empty{color:var(--color-text-muted);font-style:italic}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--color-text-primary);font-weight:500}.form-group input,.form-group textarea{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);background:var(--color-bg-secondary);color:var(--color-text-primary);font-family:inherit;resize:vertical}.form-group textarea{min-height:100px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--gum-blue);box-shadow:0 0 0 2px #1da1f21a}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.btn{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-sm);font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block;text-align:center}.btn-primary{background:var(--gum-gold);color:var(--gum-navy)}.btn-primary:hover{background:var(--gum-coral);color:#fff}.btn-primary:disabled{background:var(--color-text-muted);cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.edit-mode .profile-section{background:var(--color-bg-secondary)}.loading-spinner{display:flex;align-items:center;justify-content:center;min-height:200px}.error-message{background:#fee;border:1px solid #fcc;color:#c66;padding:1rem;border-radius:6px;margin-bottom:1rem}.success-message{background:#efe;border:1px solid #cfc;color:#6c6;padding:1rem;border-radius:6px;margin-bottom:1rem}@media (max-width: 768px){.profile-page{padding:1rem;margin:1rem}.profile-header{flex-direction:column;text-align:center}.avatar{width:100px;height:100px;font-size:2.5rem}.form-actions{flex-direction:column}}.profile-trips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.trips-loading{text-align:center;padding:2rem;color:var(--color-text-secondary)}.no-trips{text-align:center;padding:2rem;color:var(--color-text-secondary);background:var(--color-bg-primary);border-radius:var(--border-radius-md);border:2px dashed var(--color-border)}.no-trips p{margin:0 0 1rem;line-height:1.5}@media (max-width: 768px){.profile-trips-grid{grid-template-columns:1fr;gap:1rem}}.chatbot-container{display:flex;flex-direction:column;height:600px;max-width:800px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden;position:relative}.chatbot-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chatbot-header h3{margin:0;font-size:1.35rem;font-weight:600}.chatbot-actions{display:flex;gap:.5rem}.settings-btn,.clear-btn{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;transition:background .2s;font-size:.875rem}.settings-btn:hover,.clear-btn:hover{background:#ffffff4d}.chatbot-settings{padding:1rem 1.5rem;background:#f0f2f5;border-bottom:1px solid #e0e0e0}.setting-group{margin-bottom:1rem}.setting-group:last-child{margin-bottom:0}.setting-group label{display:block;margin-bottom:.25rem;font-weight:500;color:var(--text-primary);font-size:.875rem}.setting-group select,.setting-group input,.setting-group textarea{width:100%;padding:.5rem;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#333;font-size:.875rem}.setting-group textarea{resize:vertical;min-height:60px;font-family:inherit;line-height:1.4}.chatbot-messages{flex:1;overflow-y:auto;padding:1.5rem;background:#f8f9fa;min-height:0}.welcome-message{text-align:center;padding:2rem;color:var(--text-secondary)}.welcome-message h4{color:var(--text-primary);margin-bottom:1rem;font-size:1.2rem}.welcome-message ul{list-style:none;padding:0;margin:1rem 0;text-align:left;max-width:400px;margin-left:auto;margin-right:auto}.welcome-message li{padding:.5rem 0;border-bottom:1px solid var(--border-color)}.welcome-message li:last-child{border-bottom:none}.message{margin-bottom:1.5rem;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{text-align:right}.message.user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-left:auto;margin-right:0}.message.assistant .message-content{background:#fff;color:#333;border:1px solid #e0e0e0}.message-role{font-size:.75rem;font-weight:600;margin-bottom:.25rem;color:var(--text-secondary)}.message-content{display:inline-block;max-width:70%;padding:1rem;border-radius:12px;line-height:1.6;word-wrap:break-word;white-space:pre-wrap;font-size:.95rem}.message.loading .message-content{padding:.5rem 1rem}.message-timestamp{font-size:.7rem;color:var(--text-secondary);margin-top:.25rem}.error-message{background:#fee;color:#c00;padding:1rem;border-radius:6px;margin-bottom:1rem;text-align:center;font-size:.875rem}.chatbot-input{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:#f8f9fa;border-top:1px solid #e0e0e0}.chatbot-input textarea{width:100%;padding:1rem;border:1px solid #e0e0e0;border-radius:8px;background:#fff;background-color:#fff;color:#333;font-size:1rem;resize:none;font-family:inherit;line-height:1.5;min-height:80px;max-height:150px;overflow-y:auto;box-sizing:border-box}.chatbot-input textarea:focus{outline:none;border-color:#667eea}.chatbot-input textarea:disabled{opacity:.6;cursor:not-allowed}.send-btn{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s;align-self:flex-end;font-size:1rem;min-height:48px}.send-btn:hover:not(:disabled){transform:translateY(-2px)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.chatbot-messages::-webkit-scrollbar{width:8px}.chatbot-messages::-webkit-scrollbar-track{background:var(--bg-secondary)}.chatbot-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.chatbot-messages::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 768px){.chatbot-container{height:100vh;max-width:100%;border-radius:0}.message-content{max-width:85%}.chatbot-header h3{font-size:1.1rem}.settings-btn,.clear-btn{padding:.4rem .8rem;font-size:.8rem}.chatbot-input{padding:1rem}}.ai-chat-page{padding:2rem 1rem;max-width:1200px;margin:0 auto}.ai-chat-header{text-align:center;margin-bottom:2rem}.ai-chat-header h1{font-size:2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.ai-chat-header p{color:var(--text-secondary);font-size:1.1rem}@media (max-width: 768px){.ai-chat-page{padding:1rem 0}.ai-chat-header{padding:0 1rem;margin-bottom:1rem}.ai-chat-header h1{font-size:2rem}.ai-chat-header p{font-size:1rem}}.premium-required{text-align:center;padding:4rem 2rem;background:var(--card-bg);border-radius:12px;box-shadow:0 2px 10px #0000001a;max-width:600px;margin:2rem auto}.premium-required h2{font-size:2rem;color:var(--text-primary);margin-bottom:1rem}.premium-required p{color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin-bottom:.5rem}.admin-navbar{background:#2c3e50;padding:0;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.admin-navbar-container{max-width:1400px;margin:0 auto;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;gap:20px}.btn-back-home{background:#34495e;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap;transition:background .2s ease}.btn-back-home:hover{background:#1a252f}.admin-nav-links{display:flex;gap:10px;flex-wrap:wrap}.admin-nav-link{background:transparent;color:#ecf0f1;border:1px solid transparent;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.admin-nav-link:hover{background:#ffffff1a;border-color:#fff3}.admin-nav-link.active{background:#3498db;color:#fff;border-color:#3498db}@media (max-width: 768px){.admin-navbar-container{flex-direction:column;align-items:stretch;gap:15px}.btn-back-home{width:100%}.admin-nav-links{justify-content:center}.admin-nav-link{flex:1;min-width:100px;text-align:center;font-size:13px;padding:6px 12px}}@media (max-width: 480px){.admin-nav-links{flex-direction:column;width:100%}.admin-nav-link{width:100%}}.admin-layout{min-height:100vh;background:#f8f9fa}.admin-content{padding:0;margin:0}.admin-dashboard{max-width:1200px;margin:0 auto;padding:30px 20px;background:#fff;min-height:calc(100vh - 80px)}.admin-header{text-align:center;margin-bottom:30px}.admin-header h1{color:#5e72e4;margin-bottom:10px}.admin-header p{color:#666;font-size:14px}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.stat-card h3{margin:0 0 10px;font-size:14px;color:#666;text-transform:uppercase}.stat-number{font-size:32px;font-weight:700;margin:0;color:#333}.stat-number.pending{color:#f39c12}.stat-number.failed{color:#e74c3c}.stat-number.errors{color:#e67e22}.admin-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.action-card{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s;text-align:center}.action-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.action-card h3{margin:0 0 15px;color:#5e72e4;font-size:18px}.action-card p{margin:0;color:#666;font-size:14px}.admin-loading{text-align:center;padding:50px;font-size:18px;color:#666}.admin-error{text-align:center;padding:50px}.admin-error h2{color:#e74c3c;margin-bottom:10px}.admin-error p{color:#666;margin-bottom:20px}.admin-error button{background:#5e72e4;color:#fff;border:none;padding:12px 24px;border-radius:4px;cursor:pointer;font-size:16px}.admin-error button:hover{background:#4c63d2}.admin-section{margin-bottom:50px}.section-header{text-align:center;margin-bottom:30px;padding:20px 0}.section-header h2{color:#2c3e50;font-size:24px;margin-bottom:8px}.section-header p{color:#7f8c8d;font-size:16px;margin:0}.disney-stats{margin-bottom:30px}.disney-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.disney-card h3{color:#fff;font-size:16px}.disney-card .stat-number{color:#fff;font-size:28px}.disney-card .stat-label{color:#fffc;font-size:12px;margin:5px 0 0;text-transform:uppercase;letter-spacing:.5px}.disney-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px}.disney-action{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-left:4px solid #667eea;position:relative;overflow:hidden}.disney-action:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#667eea1a,#764ba21a);z-index:0}.disney-action h3{position:relative;z-index:1;color:#4a5568;font-size:18px}.disney-action p{position:relative;z-index:1;color:#718096}.disney-action:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea26}.card-stats{position:relative;z-index:1;margin-top:15px;padding-top:15px;border-top:1px solid rgba(102,126,234,.2)}.card-stats span{background:#667eea1a;color:#667eea;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.admin-dashboard{padding:15px}.admin-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.admin-actions{grid-template-columns:1fr;gap:15px}.disney-actions{grid-template-columns:1fr;gap:20px}.section-header h2{font-size:20px}.section-header p{font-size:14px}}.email-list-container{max-width:1200px;margin:0 auto;padding:20px}.email-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.email-list-header h1{color:#5e72e4;margin:0}.email-list-controls{display:flex;gap:20px}.filter-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.email-list-stats{background:#fff;padding:15px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.email-list-stats p{margin:0;color:#666;font-size:14px}.email-list{display:flex;flex-direction:column;gap:15px}.email-item{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s}.email-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.email-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.email-item-header h3{margin:0;color:#333;font-size:18px;font-weight:600}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.status-badge.pending{background:#fff3cd;color:#856404}.status-badge.success{background:#d4edda;color:#155724}.status-badge.failed{background:#f8d7da;color:#721c24}.status-badge.draft{background:#e2e3e5;color:#495057}.email-item-details{margin-bottom:15px}.email-item-details p{margin:5px 0;font-size:14px;color:#666}.email-item-preview{color:#888;font-size:14px;line-height:1.4;margin-bottom:15px;font-style:italic}.email-item-stats{display:flex;gap:15px;font-size:14px}.email-item-stats span{display:flex;align-items:center;gap:4px}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:30px}.pagination button{background:#5e72e4;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px}.pagination button:hover:not(:disabled){background:#4c63d2}.pagination button:disabled{background:#ccc;cursor:not-allowed}.pagination span{color:#666;font-size:14px}.email-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.email-modal{background:#fff;border-radius:8px;max-width:800px;max-height:90vh;width:90%;overflow-y:auto}.email-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.email-modal-header h2{margin:0;color:#333;font-size:20px}.email-modal-header button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.email-modal-content{padding:20px}.email-modal-details{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #eee}.email-modal-details p{margin:8px 0;font-size:14px}.email-modal-details ul{margin:8px 0;padding-left:20px}.email-modal-details li{margin:4px 0;font-size:14px}.email-modal-body h3{margin:0 0 15px;color:#333;font-size:16px}.email-body-preview{border:1px solid #eee;border-radius:4px;padding:15px;background:#f9f9f9;font-family:Arial,sans-serif;font-size:14px;line-height:1.5;max-height:400px;overflow-y:auto}.email-list-loading,.email-list-error{text-align:center;padding:50px;font-size:16px}.email-list-loading{color:#666}.email-list-error{color:#e74c3c}@media (max-width: 768px){.email-list-container{padding:15px}.email-list-header{flex-direction:column;align-items:stretch;gap:15px}.email-list-stats{flex-direction:column;gap:10px;text-align:center}.email-item{padding:15px}.email-item-header{flex-direction:column;align-items:stretch;gap:10px}.pagination{flex-direction:column;gap:15px}.email-modal{width:95%;max-height:95vh}}.email-templates-container{max-width:1200px;margin:0 auto;padding:20px}.templates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.templates-header h1{color:#5e72e4;margin:0}.create-btn{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .2s}.create-btn:hover{background:#218838}.templates-error{background:#f8d7da;color:#721c24;padding:12px 20px;border-radius:4px;margin-bottom:20px}.templates-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.template-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:transform .2s,box-shadow .2s}.template-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.template-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.template-title{display:flex;flex-direction:column;gap:4px}.template-header h3{margin:0;color:#333;font-size:18px;font-weight:600}.template-id{font-size:12px;color:#666;background:#f8f9fa;padding:2px 8px;border-radius:12px;font-family:monospace;align-self:flex-start}.template-actions{display:flex;gap:8px;flex-wrap:wrap}.template-actions button{background:#6c757d;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.template-actions button:hover{background:#5a6268}.delete-btn{background:#dc3545!important}.delete-btn:hover{background:#c82333!important}.template-details{margin-bottom:15px}.template-details p{margin:8px 0;font-size:14px;color:#666}.template-body-preview{background:#f8f9fa;padding:12px;border-radius:4px;font-size:13px;color:#666;line-height:1.4;font-family:monospace}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:8px;max-height:90vh;overflow-y:auto}.template-editor{width:90%;max-width:800px}.template-preview{width:90%;max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;z-index:1}.modal-header h2{margin:0;color:#333;font-size:20px}.modal-header button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.template-form{padding:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#5e72e4}.form-group textarea{resize:vertical;font-family:Courier New,monospace}.variable-buttons{margin-bottom:10px}.variable-buttons p{margin:0 0 8px;font-size:14px;color:#666}.variable-btn{background:#e9ecef;color:#495057;border:1px solid #ced4da;padding:4px 8px;border-radius:3px;cursor:pointer;font-size:12px;font-family:monospace;margin:0 4px 4px 0;transition:background-color .2s}.variable-btn:hover{background:#dee2e6}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid #eee}.form-actions button{padding:12px 24px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .2s}.form-actions button[type=button]{background:#6c757d;color:#fff}.form-actions button[type=button]:hover{background:#5a6268}.save-btn{background:#28a745!important;color:#fff!important}.save-btn:hover{background:#218838!important}.preview-content{padding:20px}.preview-subject{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:4px}.preview-body{margin-bottom:20px}.preview-html{border:1px solid #eee;border-radius:4px;padding:20px;background:#fff;margin-top:10px;max-height:500px;overflow-y:auto}.templates-loading{text-align:center;padding:50px;font-size:18px;color:#666}@media (max-width: 768px){.email-templates-container{padding:15px}.templates-header{flex-direction:column;gap:15px;align-items:stretch}.templates-list{grid-template-columns:1fr}.template-header{flex-direction:column;gap:15px}.template-actions{justify-content:flex-start}.modal-overlay{padding:10px}.template-editor,.template-preview{width:100%}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;margin:0}.template-header{flex-direction:column;gap:10px;align-items:stretch}.template-title{align-items:flex-start}.template-actions{justify-content:flex-start;align-self:stretch}}.test-email-container{max-width:1400px;margin:0 auto;padding:20px}.test-email-header{text-align:center;margin-bottom:30px}.test-email-header h1{color:#5e72e4;margin:0 0 10px}.test-email-header p{color:#666;margin:0}.success-message{background:#d4edda;color:#155724;padding:12px 20px;border-radius:4px;margin-bottom:20px;border:1px solid #c3e6cb}.error-message{background:#f8d7da;color:#721c24;padding:12px 20px;border-radius:4px;margin-bottom:20px;border:1px solid #f5c6cb}.test-email-content{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}.email-form{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#5e72e4;box-shadow:0 0 0 2px #5e72e41a}.form-group textarea{resize:vertical;font-family:Courier New,monospace;line-height:1.5}.template-variables{background:#f8f9fa;padding:20px;border-radius:6px;margin:20px 0}.template-variables h3{margin:0 0 10px;color:#333;font-size:16px}.template-variables p{margin:0 0 15px;color:#666;font-size:14px}.form-actions{margin-top:30px}.send-btn{background:#28a745;color:#fff;border:none;padding:14px 30px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:600;width:100%;transition:background-color .2s}.send-btn:hover:not(:disabled){background:#218838}.send-btn:disabled{background:#6c757d;cursor:not-allowed}.email-preview{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a;position:sticky;top:20px}.email-preview h3{margin:0 0 20px;color:#333;font-size:18px}.preview-container{border:1px solid #eee;border-radius:6px;overflow:hidden}.preview-subject{background:#f8f9fa;padding:15px 20px;border-bottom:1px solid #eee;font-size:14px}.preview-body{padding:20px}.preview-body>strong{display:block;margin-bottom:15px;font-size:14px;color:#333}.preview-html{border:1px solid #eee;border-radius:4px;padding:20px;background:#fff;min-height:200px;max-height:500px;overflow-y:auto;font-family:Arial,sans-serif;line-height:1.6}.preview-html h1,.preview-html h2,.preview-html h3{color:#333;margin-top:0}.preview-html p{margin:15px 0}.preview-html a{color:#5e72e4;text-decoration:none}.preview-html a:hover{text-decoration:underline}@media (max-width: 768px){.test-email-container{padding:15px}.test-email-content{grid-template-columns:1fr;gap:20px}.email-form,.email-preview{padding:20px}.email-preview{position:static}.form-group textarea{rows:8}.preview-html{max-height:300px}}.user-management{padding:30px 20px;max-width:1200px;margin:0 auto;background:#fff;min-height:calc(100vh - 80px)}.user-management-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.user-management-header h1{color:#333;margin:0}.user-filters{display:flex;gap:15px;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px}.search-input,.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.search-input{flex:1;min-width:300px}.filter-select{min-width:150px}.user-stats{display:flex;gap:20px;margin-bottom:20px;font-size:14px;color:#666}.users-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.users-table table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.users-table th{background:#f8f9fa;font-weight:600;color:#555}.users-table tr:hover{background:#f8f9fa}.locked-user{background:#fff5f5!important}.locked-user:hover{background:#fed7d7!important}.status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase;margin-right:5px}.status.premium{background:#d4edda;color:#155724}.status.free{background:#f8d7da;color:#721c24}.status.locked{background:#f0ad4e;color:#8a6d3b}.unverified{color:#f0ad4e;margin-left:5px}.btn-view{background:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.user-modal{background:#fff;border-radius:8px;padding:0;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.modal-header h2{margin:0;color:#333}.modal-header button{background:none;border:none;font-size:24px;cursor:pointer;color:#999}.modal-header button:hover{color:#333}.modal-body{padding:20px}.user-info{margin-bottom:20px}.user-info p{margin:8px 0;color:#555}.user-info strong{color:#333}.user-actions{display:flex;flex-wrap:wrap;gap:10px;border-top:1px solid #eee;padding-top:20px}.lock-options{display:flex;gap:10px;flex-wrap:wrap}.btn-success{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer}.btn-success:hover{background:#1e7e34}.btn-warning{background:#ffc107;color:#212529;border:none;padding:8px 16px;border-radius:4px;cursor:pointer}.btn-warning:hover{background:#e0a800}.btn-danger{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer}.btn-danger:hover{background:#c82333}@media (max-width: 768px){.user-management{padding:10px}.user-management-header{flex-direction:column;align-items:flex-start;gap:15px}.user-filters{flex-direction:column}.search-input{min-width:auto;width:100%}.users-table{overflow-x:auto}.users-table table{min-width:700px}.user-modal{width:95%;margin:20px}.user-actions,.lock-options{flex-direction:column}}.article-analytics{padding:30px 20px;max-width:1400px;margin:0 auto;background:#fff;min-height:calc(100vh - 80px)}.analytics-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.analytics-header h1{color:#333;margin:0}.analytics-tabs{display:flex;margin-bottom:30px;border-bottom:1px solid #e0e0e0}.tab-active,.tab-inactive{padding:12px 24px;border:none;background:none;cursor:pointer;font-size:16px;border-bottom:3px solid transparent;transition:all .3s ease}.tab-active{color:#007bff;border-bottom-color:#007bff;font-weight:600}.tab-inactive{color:#666}.tab-inactive:hover{color:#333;background:#f8f9fa}.analytics-summary,.rss-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.summary-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.summary-card h3{margin:0 0 10px;color:#666;font-size:14px;font-weight:600;text-transform:uppercase}.summary-number{font-size:32px;font-weight:700;margin:0;color:#333}.analytics-filters{display:flex;gap:15px;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px}.analytics-filters select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:150px}.posts-stats{margin-bottom:15px;color:#666;font-size:14px}.posts-table,.rss-feeds-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.rss-feeds-table h3{padding:20px 20px 0;margin:0 0 15px;color:#333}.posts-table table,.rss-feeds-table table{width:100%;border-collapse:collapse}.posts-table th,.posts-table td,.rss-feeds-table th,.rss-feeds-table td{padding:12px;text-align:left;border-bottom:1px solid #eee;vertical-align:top}.posts-table th,.rss-feeds-table th{background:#f8f9fa;font-weight:600;color:#555}.posts-table tr:hover,.rss-feeds-table tr:hover{background:#f8f9fa}.article-analytics .post-title{font-weight:500;color:#333;max-width:300px;line-height:1.4}.post-author{color:#666;font-style:italic}.featured-badge{color:#ffc107;margin-left:8px;font-size:14px}.article-analytics .external-link{color:#007bff;margin-left:8px;text-decoration:none;font-size:14px}.article-analytics .external-link:hover{color:#0056b3}.category-badge{background:#e9ecef;color:#495057;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.source-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.source-badge.external{background:#fff3cd;color:#856404}.source-badge.internal{background:#d4edda;color:#155724}.engagement-stats{display:flex;flex-direction:column;gap:4px}.engagement-stats span{font-size:12px;color:#666}.engagement-score{font-weight:600;color:#333;font-size:13px}.upvotes{color:#28a745}.downvotes{color:#dc3545}.comments{color:#007bff}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.status-badge.published{background:#d4edda;color:#155724}.status-badge.draft{background:#fff3cd;color:#856404}.status-badge.archived{background:#f8d7da;color:#721c24}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.feed-url{color:#666;word-break:break-all}.btn-view{background:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;text-decoration:none}.btn-view:hover{background:#0056b3}.pagination{display:flex;justify-content:center;gap:5px;margin-top:20px}.pagination button{padding:8px 12px;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:4px}.pagination button:hover{background:#f8f9fa}.pagination button.active{background:#007bff;color:#fff;border-color:#007bff}.admin-loading,.admin-error{text-align:center;padding:40px}.admin-error{color:#dc3545}.admin-error button{margin-top:20px;padding:10px 20px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.admin-error button:hover{background:#0056b3}@media (max-width: 768px){.article-analytics{padding:10px}.analytics-header{flex-direction:column;align-items:flex-start;gap:15px}.analytics-summary,.rss-summary{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.analytics-filters{flex-direction:column;gap:10px}.analytics-filters select{min-width:auto;width:100%}.posts-table,.rss-feeds-table{overflow-x:auto}.posts-table table,.rss-feeds-table table{min-width:800px}.article-analytics .post-title{max-width:200px}.summary-number{font-size:24px}}@media (max-width: 480px){.analytics-tabs{flex-direction:column}.tab-active,.tab-inactive{padding:8px 16px;text-align:center}.analytics-summary,.rss-summary{grid-template-columns:1fr}.posts-table table,.rss-feeds-table table{min-width:600px}}.rss-actions{display:flex;align-items:center;gap:15px;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.btn-refresh-rss{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:5px}.btn-refresh-rss:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.btn-refresh-rss:disabled{background:#6c757d;cursor:not-allowed;opacity:.7}.refresh-message{padding:8px 12px;border-radius:4px;font-size:14px;font-weight:500;animation:fadeIn .3s ease}.refresh-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.refresh-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.verify-email-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.verify-email-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:500px;width:100%;overflow:hidden}.verify-email-header{background:linear-gradient(135deg,#5b47bd,#3a2b8c);padding:40px 30px;text-align:center;color:#fff}.logo-section h1{margin:0;font-size:28px;font-weight:600}.verify-email-content{padding:40px 30px}.status-section{text-align:center}.status-section h2{margin:20px 0 15px;color:#333;font-size:24px;font-weight:600}.status-section p{margin:15px 0;color:#666;line-height:1.6}.loading-spinner{font-size:48px;margin-bottom:20px;animation:spin 2s linear infinite}.status-icon{font-size:64px;margin-bottom:20px}.success .status-icon{color:#28a745}.error .status-icon{color:#dc3545}.redirect-info{font-style:italic;color:#888;font-size:14px;margin-top:20px}.resend-section{margin:30px 0;padding:20px;background:#f8f9fa;border-radius:8px}.resend-section p{margin:0 0 15px;font-size:14px}.primary-btn{background:linear-gradient(135deg,#5b47bd,#3a2b8c);color:#fff;border:none;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin:10px}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5b47bd4d}.secondary-btn{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s;margin:10px}.secondary-btn:hover:not(:disabled){background:#5a6268}.secondary-btn:disabled{opacity:.6;cursor:not-allowed}.ghost-btn{background:transparent;color:#6c757d;border:1px solid #dee2e6;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin:10px}.ghost-btn:hover{background:#f8f9fa;border-color:#6c757d}.verify-email-footer{background:#f8f9fa;padding:20px 30px;text-align:center;border-top:1px solid #e9ecef}.verify-email-footer p{margin:0;color:#666;font-size:14px}.verify-email-footer a{color:#5b47bd;text-decoration:none}.verify-email-footer a:hover{text-decoration:underline}@media (max-width: 768px){.verify-email-container{padding:15px}.verify-email-header,.verify-email-content{padding:30px 20px}.verify-email-footer{padding:20px}.logo-section h1{font-size:24px}.status-section h2{font-size:20px}.status-icon{font-size:48px}}.countdown-widget{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:1.5rem;color:#fff;box-shadow:0 8px 32px #667eea26;border:2px solid transparent;transition:all .3s ease;position:relative;overflow:hidden}.countdown-widget:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.countdown-widget:hover{transform:translateY(-2px);box-shadow:0 12px 40px #667eea40}.countdown-widget--small{padding:1rem;font-size:.875rem}.countdown-widget--medium{padding:1.5rem}.countdown-widget--large{padding:2rem;font-size:1.125rem}.countdown-widget--empty{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#4a5568;text-align:center}.countdown-widget--current{background:linear-gradient(135deg,#56ab2f,#a8e6cf);animation:glow 2s ease-in-out infinite alternate}.countdown-widget--past{background:linear-gradient(135deg,#bdc3c7,#2c3e50);opacity:.8}@keyframes glow{0%{box-shadow:0 8px 32px #56ab2f4d}to{box-shadow:0 12px 40px #56ab2f80}}.countdown-widget__header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.countdown-widget__icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.countdown-widget__trip-info{flex:1}.countdown-widget__title{margin:0;font-size:1.25rem;font-weight:700;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.2)}.countdown-widget--small .countdown-widget__title{font-size:1rem}.countdown-widget--large .countdown-widget__title{font-size:1.5rem}.countdown-widget__resort{margin:.25rem 0 0;opacity:.9;font-size:.875rem}.countdown-widget__status{font-weight:600;font-size:1.125rem;margin-bottom:.5rem;text-align:center}.countdown-widget__magical{text-align:center;font-style:italic;opacity:.9;margin-top:1rem}.countdown-widget__countdown{margin-bottom:1.5rem}.countdown-widget__time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}.countdown-widget--large .countdown-widget__time-grid{grid-template-columns:repeat(4,1fr)}.countdown-widget--small .countdown-widget__time-grid{gap:.75rem}.countdown-widget__time-unit{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1rem;border:1px solid rgba(255,255,255,.2)}.countdown-widget--small .countdown-widget__time-unit{padding:.75rem}.countdown-widget--large .countdown-widget__time-unit{padding:1.25rem}.countdown-widget__time-value{font-size:1.875rem;font-weight:800;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.3)}.countdown-widget--small .countdown-widget__time-value{font-size:1.5rem}.countdown-widget--large .countdown-widget__time-value{font-size:2.25rem}.countdown-widget__time-label{font-size:.75rem;font-weight:500;margin-top:.25rem;opacity:.9;text-transform:uppercase;letter-spacing:.05em}.countdown-widget__footer{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.countdown-widget__date{font-size:.875rem;opacity:.9;font-weight:500}.countdown-widget__share-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.countdown-widget__share-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.countdown-widget--empty .countdown-widget__text h3{margin:.5rem 0;color:#2d3748}.countdown-widget--empty .countdown-widget__text p{margin:0;color:#718096}.countdown-widget--empty .countdown-widget__icon{font-size:3rem;opacity:.7}@media (max-width: 768px){.countdown-widget{padding:1rem}.countdown-widget__header{flex-direction:column;text-align:center;gap:.5rem}.countdown-widget__time-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.countdown-widget--large .countdown-widget__time-grid{grid-template-columns:repeat(2,1fr)}.countdown-widget__footer{flex-direction:column;gap:1rem;text-align:center}.countdown-widget__time-value{font-size:1.5rem}.countdown-widget--large .countdown-widget__time-value{font-size:1.75rem}}@media (max-width: 480px){.countdown-widget__time-unit{padding:.5rem}.countdown-widget__time-value{font-size:1.25rem}.countdown-widget__time-label{font-size:.625rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.create-trip-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.create-trip-modal__header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1rem;border-bottom:1px solid #e2e8f0}.create-trip-modal__header h2{margin:0;font-size:1.5rem;font-weight:700;color:#2d3748;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.create-trip-modal__close{background:none;border:none;font-size:2rem;color:#a0aec0;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.create-trip-modal__close:hover{background:#f7fafc;color:#4a5568}.create-trip-modal__form{padding:2rem}.create-trip-modal__error{background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500;border:1px solid #feb2b2}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:#2d3748;font-size:.875rem}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:inherit;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fafafa}.form-textarea{resize:vertical;min-height:80px}.form-help{margin-top:.25rem;font-size:.875rem;color:#718096;font-style:italic}.form-checkbox{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer}.form-checkbox-input{width:1.25rem;height:1.25rem;margin:0;cursor:pointer;accent-color:#667eea}.form-checkbox-label{font-weight:600;color:#2d3748;cursor:pointer;line-height:1.4}.form-checkbox .form-help{margin-top:.25rem;margin-left:2rem}.create-trip-modal__actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #e2e8f0;margin-top:1.5rem}.btn{border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit;font-size:1rem;min-width:120px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea59}.btn--secondary:hover:not(:disabled){border-color:#cbd5e0;background:#f7fafc}@media (max-width: 768px){.modal-overlay{padding:.5rem}.create-trip-modal{max-height:95vh}.create-trip-modal__header{padding:1.5rem 1.5rem 1rem}.create-trip-modal__header h2{font-size:1.25rem}.create-trip-modal__form{padding:1.5rem}.form-row{grid-template-columns:1fr;gap:1.5rem}.create-trip-modal__actions{flex-direction:column}.btn{width:100%}}@media (max-width: 480px){.modal-overlay{padding:0;align-items:flex-end}.create-trip-modal{max-height:90vh;border-radius:16px 16px 0 0;margin-top:auto}.create-trip-modal__header,.create-trip-modal__form{padding:1rem}.form-input,.form-select,.form-textarea{padding:.625rem}.form-checkbox .form-help{margin-left:0;margin-top:.5rem}}.btn:disabled .btn-text{opacity:.7}.create-trip-modal{outline:none}.create-trip-modal__close:focus{outline:2px solid #667eea;outline-offset:2px}.form-input:invalid,.form-select:invalid{border-color:#e53e3e}.form-input:invalid:focus,.form-select:invalid:focus{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1a}.form-input,.form-select,.form-textarea{transition:border-color .3s ease,box-shadow .3s ease,background-color .3s ease}.form-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder,.form-textarea::placeholder{color:#a0aec0;opacity:1}.trip-form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #f0f4f8}.trip-form-section:last-of-type{border-bottom:none;padding-bottom:0;margin-bottom:0}.trip-form-section h3{margin:0 0 1.5rem;font-size:1.125rem;font-weight:700;color:#2d3748;display:flex;align-items:center;gap:.5rem}.planning-method-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.planning-method-option{display:flex;align-items:flex-start;gap:.75rem;padding:1.25rem;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .3s ease;background:#fff}.planning-method-option:hover{border-color:#cbd5e0;background:#fafafa;transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.planning-method-option input[type=radio]{margin:.125rem 0 0;width:1.25rem;height:1.25rem;accent-color:#667eea;cursor:pointer}.planning-method-option input[type=radio]:checked{transform:scale(1.1)}.planning-method-option:has(input:checked){border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d);box-shadow:0 0 0 3px #667eea1a}.planning-method-content{flex:1}.planning-method-content strong{display:block;color:#2d3748;font-size:1rem;margin-bottom:.25rem}.planning-method-content p{margin:0;color:#718096;font-size:.875rem;line-height:1.4}.trip-stops-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.btn--small{padding:.5rem 1rem;font-size:.875rem;min-width:auto}.trip-stops-list{display:flex;flex-direction:column;gap:1.5rem}.trip-stop{background:#fafafa;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;position:relative;transition:all .3s ease}.trip-stop:hover{border-color:#cbd5e0;box-shadow:0 2px 8px #0000000d}.trip-stop__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.trip-stop__header h4{margin:0;font-size:1rem;font-weight:600;color:#2d3748;display:flex;align-items:center;gap:.5rem}.trip-stop__remove{background:#fed7d7;color:#c53030;border:none;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;font-weight:700;transition:all .3s ease}.trip-stop__remove:hover{background:#feb2b2;transform:scale(1.1)}.trip-stop .form-group{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem}.trip-stop .form-group:last-child{margin-bottom:0}.trip-stop .form-row{margin-bottom:1rem}.trip-stop .form-row:last-child{margin-bottom:0}.loading-message{display:flex;flex-direction:column;align-items:center;padding:2rem;color:#718096}.loading-spinner{font-size:1.5rem;animation:spin 2s linear infinite;margin-bottom:.5rem}@media (max-width: 768px){.planning-method-options{grid-template-columns:1fr}.planning-method-option{padding:1rem}.trip-stops-header{flex-direction:column;align-items:stretch;gap:1rem}.trip-stop{padding:1rem}.trip-stop .form-group{padding:.75rem}}@media (max-width: 480px){.trip-form-section h3{font-size:1rem}.planning-method-content strong{font-size:.9rem}.planning-method-content p{font-size:.8rem}.trip-stop__header{flex-direction:column;align-items:flex-start;gap:.75rem}.trip-stop__remove{align-self:flex-end}}.my-trips{max-width:1200px;margin:0 auto;padding:2rem}.my-trips__header{text-align:center;margin-bottom:2rem}.my-trips__header h1{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.my-trips__header p{color:#718096;font-size:1.125rem;margin:0}.my-trips__loading,.my-trips__error{text-align:center;padding:4rem 2rem}.my-trips__loading .loading-spinner{font-size:3rem;animation:spin 2s linear infinite;margin-bottom:1rem}.my-trips__error h2{color:#e53e3e;margin-bottom:.5rem}.my-trips__error p{color:#718096;margin-bottom:1.5rem}.my-trips__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.trip-stat{background:#fff;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 4px 6px #0000000d;border:1px solid #e2e8f0;transition:all .3s ease}.trip-stat:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.trip-stat__value{font-size:2rem;font-weight:800;color:#667eea;margin-bottom:.25rem}.trip-stat__label{font-size:.875rem;color:#718096;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.my-trips__countdown{margin-bottom:2rem}.my-trips__actions{display:flex;justify-content:center;margin-bottom:2rem}.btn{border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-family:inherit}.btn--primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 6px #667eea40}.btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea59}.btn--secondary{background:#fff;color:#4a5568;border:2px solid #e2e8f0}.btn--secondary:hover{border-color:#cbd5e0;background:#f7fafc}.btn--large{padding:1rem 2rem;font-size:1.125rem}.my-trips__filters{display:flex;justify-content:center;margin-bottom:2rem;gap:.5rem;flex-wrap:wrap}.filter-tab{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:#4a5568}.filter-tab:hover{border-color:#cbd5e0;background:#f7fafc}.filter-tab--active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.my-trips__list{margin-top:2rem}.trips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.my-trips__empty{text-align:center;padding:4rem 2rem}.empty-state{max-width:400px;margin:0 auto}.empty-state__icon{font-size:4rem;margin-bottom:1rem;opacity:.7}.empty-state h3{color:#2d3748;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:#718096;margin-bottom:1.5rem}@media (max-width: 768px){.my-trips{padding:1rem}.my-trips__header h1{font-size:2rem}.my-trips__stats{grid-template-columns:repeat(2,1fr)}.trip-stat{padding:1rem}.trip-stat__value{font-size:1.5rem}.my-trips__filters{flex-direction:column;align-items:center}.filter-tab{width:100%;max-width:300px;text-align:center}.trips-grid{grid-template-columns:1fr;gap:1rem}.btn--large{width:100%;max-width:300px}}@media (max-width: 480px){.my-trips{padding:.5rem}.my-trips__header h1{font-size:1.75rem}.my-trips__stats{grid-template-columns:1fr;gap:.75rem}.trip-stat{padding:.75rem}.filter-tab{padding:.5rem 1rem;font-size:.875rem}}.trip-detail{max-width:1000px;margin:0 auto;padding:2rem}.trip-detail__loading,.trip-detail__error{text-align:center;padding:4rem 2rem}.trip-detail__loading .loading-spinner{font-size:3rem;animation:spin 2s linear infinite;margin-bottom:1rem}.trip-detail__header{margin-bottom:3rem}.trip-detail__breadcrumb{font-size:.9rem;color:#666;margin-bottom:1rem}.trip-detail__breadcrumb a{color:#06c;text-decoration:none}.trip-detail__breadcrumb a:hover{text-decoration:underline}.trip-detail__title{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.trip-detail__title h1{margin:0;color:#333;font-size:2.5rem}.trip-detail__badge{padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.9rem;white-space:nowrap}.trip-detail__badge--current{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.trip-detail__badge--past{background:linear-gradient(135deg,#a55eea,#8b5cf6);color:#fff}.trip-detail__badge--soon{background:linear-gradient(135deg,#feca57,#ff9ff3);color:#333}.trip-detail__badge--upcoming{background:linear-gradient(135deg,#48cae4,#0077b6);color:#fff}.trip-detail__actions{margin-top:1rem}.trip-detail__content{display:flex;flex-direction:column;gap:2.5rem}.trip-detail__overview h2{color:#333;margin-bottom:1.5rem;font-size:1.8rem}.trip-detail__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.trip-detail__info-item{background:#f8f9fa;padding:1.5rem;border-radius:12px;border-left:4px solid #0066cc}.trip-detail__info-item strong{display:block;color:#333;margin-bottom:.5rem;font-size:1rem}.trip-detail__info-item p{margin:0;color:#555;line-height:1.5}.trip-detail__info-item small{color:#777;font-size:.9rem}.trip-detail__section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;border:1px solid #eee}.trip-detail__section h3{color:#333;margin-bottom:1rem;font-size:1.4rem}.trip-detail__section p{color:#555;line-height:1.6;margin:0}.trip-detail__stops{display:flex;flex-direction:column;gap:1.5rem}.trip-detail__stop{background:#f8f9fa;padding:1.5rem;border-radius:8px;border-left:4px solid #28a745}.trip-detail__stop-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.trip-detail__stop h4{margin:0;color:#333;font-size:1.2rem}.trip-detail__stop-dates{color:#666;font-size:.9rem;background:#fff;padding:.3rem .8rem;border-radius:15px}.trip-detail__stop p{margin:.5rem 0;color:#555}.trip-detail__stop strong{color:#333}@media (max-width: 768px){.trip-detail{padding:1rem}.trip-detail__title{flex-direction:column;align-items:flex-start;gap:.5rem}.trip-detail__title h1{font-size:2rem}.trip-detail__info-grid{grid-template-columns:1fr;gap:1rem}.trip-detail__stop-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.friend-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .2s ease;border:1px solid #e1e8ed}.friend-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.friend-card-header{display:flex;align-items:flex-start;gap:15px;margin-bottom:15px}.friend-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid #f0f8ff}.friend-info{flex:1}.friend-name{font-size:1.2rem;font-weight:600;color:#1a1a1a;margin:0 0 5px}.friend-joined,.friend-since{font-size:.85rem;color:#657786;margin:2px 0}.friend-since{color:#1da1f2;font-weight:500}.friend-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.follow-btn{background:#1da1f2;color:#fff;border:none;padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.follow-btn:hover{background:#1991db}.follow-btn.following{background:#657786}.follow-btn.following:hover{background:#dc3545}.remove-friend-btn{background:none;border:none;color:#657786;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-friend-btn:hover{background:#ffebee;color:#dc3545}.friend-status{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:15px}.status-badge{background:#f7f9fa;color:#657786;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:500;border:1px solid #e1e8ed}.status-badge.mutual-friends{background:#e8f5e8;color:#1d9f1d;border-color:#4caf50}.status-badge.mutual-follow{background:#e3f2fd;color:#1976d2;border-color:#2196f3}.status-badge.following{background:#fff3e0;color:#f57c00;border-color:#ff9800}.status-badge.follower{background:#f3e5f5;color:#7b1fa2;border-color:#9c27b0}.friend-trip{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;padding:15px;color:#fff;margin-bottom:12px;display:flex;align-items:center;gap:12px}.trip-icon{font-size:1.5rem}.trip-details{flex:1}.trip-name{font-weight:600;margin:0 0 4px;font-size:.95rem}.trip-countdown{font-size:.85rem;margin:0 0 2px;opacity:.9}.trip-type{font-size:.8rem;margin:0;opacity:.8;text-transform:capitalize}.friend-stats{display:flex;justify-content:center;padding-top:12px;border-top:1px solid #e1e8ed}.stat{color:#657786;font-size:.85rem;font-weight:500}@media (max-width: 768px){.friend-card{padding:15px}.friend-card-header{gap:12px}.friend-avatar{width:50px;height:50px}.friend-name{font-size:1.1rem}.friend-actions{gap:6px}.follow-btn{padding:5px 12px;font-size:.8rem}}.friend-request{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e8ed;margin-bottom:16px}.request-header{display:flex;align-items:center;gap:15px;margin-bottom:15px;cursor:pointer;padding:5px;border-radius:8px;transition:background-color .2s ease}.request-header:hover{background-color:#f7f9fa}.request-avatar{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid #f0f8ff}.request-info{flex:1}.request-name{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin:0 0 4px}.request-date{font-size:.85rem;color:#657786;margin:0}.request-message{margin-bottom:20px;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;text-align:center}.request-message p{margin:0;font-size:.95rem;font-weight:500}.request-actions{display:flex;gap:12px}.accept-btn,.decline-btn{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative}.accept-btn{background:#28a745;color:#fff}.accept-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.decline-btn{background:#6c757d;color:#fff}.decline-btn:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.accept-btn:disabled,.decline-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.accept-btn:disabled,.decline-btn:disabled{pointer-events:none}@media (max-width: 768px){.friend-request{padding:15px}.request-header{gap:12px}.request-avatar{width:45px;height:45px}.request-name{font-size:1rem}.request-actions{flex-direction:column;gap:10px}.accept-btn,.decline-btn{padding:10px 16px;font-size:.9rem}}.friend-suggestion{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e8ed;position:relative;transition:all .2s ease}.friend-suggestion:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.dismiss-btn{position:absolute;top:15px;right:15px;background:none;border:none;color:#657786;font-size:1.1rem;cursor:pointer;padding:4px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dismiss-btn:hover{background:#f7f9fa;color:#dc3545}.suggestion-header{display:flex;align-items:center;gap:15px;margin-bottom:15px;cursor:pointer;padding:5px;border-radius:8px;transition:background-color .2s ease;margin-right:30px}.suggestion-header:hover{background-color:#f7f9fa}.suggestion-avatar{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid #f0f8ff}.suggestion-info{flex:1}.suggestion-name{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin:0 0 4px}.suggestion-joined{font-size:.85rem;color:#657786;margin:0}.suggestion-reason{display:flex;align-items:center;gap:8px;background:#f7f9fa;padding:10px 15px;border-radius:8px;margin-bottom:15px;border-left:4px solid #1da1f2}.reason-icon{font-size:1.2rem}.reason-text{font-size:.9rem;font-weight:500;color:#1a1a1a}.suggestion-details{margin-bottom:12px}.detail-label{font-size:.85rem;color:#657786;margin:0 0 6px;font-weight:500}.detail-values{display:flex;flex-wrap:wrap;gap:6px}.detail-tag{background:#e3f2fd;color:#1976d2;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.detail-value{color:#1a1a1a;font-size:.9rem;font-weight:500}.suggestion-actions{margin-top:15px;padding-top:15px;border-top:1px solid #e1e8ed}.send-request-btn{width:100%;background:#1da1f2;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.send-request-btn:hover:not(:disabled){background:#1991db;transform:translateY(-1px)}.send-request-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.request-sent{display:flex;align-items:center;justify-content:center;gap:8px;background:#e8f5e8;color:#1d9f1d;padding:12px 20px;border-radius:8px;font-weight:600}.sent-icon{font-size:1.2rem}.friend-suggestion[data-reason=mutual_friends] .suggestion-reason{border-left-color:#28a745;background:#f8fff8}.friend-suggestion[data-reason=similar_trip_dates] .suggestion-reason{border-left-color:#ffc107;background:#fffdf0}.friend-suggestion[data-reason=same_resort] .suggestion-reason{border-left-color:#6f42c1;background:#faf7ff}.friend-suggestion[data-reason=active_user] .suggestion-reason{border-left-color:#fd7e14;background:#fff8f0}@media (max-width: 768px){.friend-suggestion{padding:15px}.suggestion-header{gap:12px;margin-right:25px}.suggestion-avatar{width:45px;height:45px}.suggestion-name{font-size:1rem}.dismiss-btn{top:12px;right:12px;width:22px;height:22px;font-size:1rem}.send-request-btn{padding:10px 16px;font-size:.9rem}}.invite-friend-modal{max-width:500px;width:90%}.invite-description{background:linear-gradient(135deg,#f8f6ff,#f0edff);padding:16px;border-radius:8px;margin-bottom:24px;color:#5b47bd;border:1px solid #E8E4FF;font-size:14px;line-height:1.5}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#333}.form-group input,.form-group textarea{width:100%;padding:12px;border:2px solid #E1E5E9;border-radius:8px;font-size:14px;transition:border-color .2s ease;font-family:inherit;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#5b47bd;box-shadow:0 0 0 3px #5b47bd1a}.form-group input:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px}.character-count{display:block;text-align:right;color:#666;font-size:12px;margin-top:4px}.error-message{background:#fef2f2;color:#dc2626;padding:12px;border-radius:8px;border:1px solid #FECACA;margin-bottom:20px;font-size:14px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn{padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;min-width:120px;justify-content:center}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #D1D5DB}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-primary{background:linear-gradient(135deg,#5b47bd,#7c3aed);color:#fff;box-shadow:0 2px 4px #5b47bd33}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #5b47bd4d}.loading-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.modal-footer{border-top:1px solid #E5E7EB;padding-top:16px;margin-top:24px}.points-info{display:flex;align-items:center;gap:8px;justify-content:center;color:#666;font-size:13px}.points-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 8px;border-radius:12px;font-weight:600;font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003;animation:modalSlideIn .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;margin-bottom:24px}.modal-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.modal-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover:not(:disabled){background:#f3f4f6;color:#374151}.modal-body{padding:0 24px 24px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.invite-friend-modal{max-width:none;width:100%;margin:0 10px}.modal-actions{flex-direction:column-reverse}.btn{width:100%}}.friends-page{max-width:1200px;margin:0 auto;padding:20px}.friends-header{margin-bottom:30px}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-content>div{text-align:center;flex:1}.invite-btn{padding:12px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;text-decoration:none;font-size:14px}.invite-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-icon{font-size:16px}.friends-header h1{font-size:2.5rem;color:#1a1a1a;margin:0 0 10px;font-weight:700}.friends-header p{font-size:1.1rem;color:#657786;margin:0 0 20px}.friends-stats{display:flex;justify-content:center;gap:40px;margin-top:20px;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff}.stat-item{text-align:center}.stat-number{display:block;font-size:2rem;font-weight:700;line-height:1}.stat-label{display:block;font-size:.9rem;opacity:.9;margin-top:4px}.friends-tabs{display:flex;background:#fff;border-radius:12px;padding:8px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e8ed}.tab-btn{flex:1;background:none;border:none;padding:12px 20px;font-size:1rem;font-weight:600;color:#657786;cursor:pointer;border-radius:8px;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center;gap:8px}.tab-btn:hover{background:#f7f9fa;color:#1a1a1a}.tab-btn.active{background:#1da1f2;color:#fff}.tab-count{background:#ffffff4d;color:inherit;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:700}.tab-btn.active .tab-count{background:#fff3}.tab-count.notification{background:#dc3545;color:#fff}.tab-btn.active .tab-count.notification{background:#dc3545}.friends-content{min-height:400px}.friends-grid,.suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.requests-list{max-width:600px;margin:0 auto}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:15px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e8ed}.empty-state h3{font-size:1.5rem;color:#1a1a1a;margin:0 0 10px}.empty-state p{font-size:1rem;color:#657786;margin:0 0 20px;line-height:1.5}.primary-btn{background:#1da1f2;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.primary-btn:hover{background:#1991db;transform:translateY(-1px)}.loading-container,.error-container{text-align:center;padding:60px 20px}.error-message{color:#dc3545;font-size:1.1rem;margin-bottom:20px}.retry-btn{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn:hover{background:#218838;transform:translateY(-1px)}@media (max-width: 768px){.friends-page{padding:15px}.friends-header h1{font-size:2rem}.friends-stats{gap:20px;padding:15px}.stat-number{font-size:1.5rem}.header-content{flex-direction:column;gap:20px;align-items:center}.header-content>div{order:1}.invite-btn{order:2}}.invitations-grid{padding:20px}.invitation-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#f8f6ff,#f0edff);padding:20px;border-radius:12px;text-align:center;border:1px solid #E8E4FF}.stat-card .stat-number{display:block;font-size:2rem;font-weight:700;color:#5b47bd;line-height:1;margin-bottom:8px}.stat-card .stat-label{display:block;font-size:.9rem;color:#666;font-weight:500}.invitations-list{display:flex;flex-direction:column;gap:16px}.invitation-card{background:#fff;padding:20px;border-radius:12px;border:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.invitation-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a;border-color:#d1d5db}.invitation-info{flex:1}.invitation-email{font-weight:600;color:#1f2937;font-size:16px;margin-bottom:4px}.invitation-date{font-size:14px;color:#6b7280;margin-bottom:8px}.invitation-message{font-size:14px;color:#4b5563;font-style:italic;background:#f9fafb;padding:8px 12px;border-radius:6px;border-left:3px solid #E5E7EB}.invitation-status{flex-shrink:0}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge.accepted{background:#d1fae5;color:#065f46}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.expired{background:#fee2e2;color:#991b1b}@media (max-width: 768px){.invitation-card{flex-direction:column;align-items:flex-start;gap:12px}.invitation-status{width:100%}.status-badge{display:block;text-align:center;width:100%}}@media (max-width: 480px){.friends-tabs{flex-direction:column;gap:4px}.tab-btn{padding:10px 15px;font-size:.9rem}.friends-grid,.suggestions-grid{grid-template-columns:1fr;gap:15px}.empty-state{padding:40px 15px}.empty-state h3{font-size:1.3rem}}@media (max-width: 480px){.friends-stats{flex-direction:column;gap:15px}.stat-item{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.2)}.stat-item:last-child{border-bottom:none}}.search-grid{padding:20px}.search-container{max-width:800px;margin:0 auto}.search-header{text-align:center;margin-bottom:30px}.search-header h3{font-size:1.5rem;color:#1f2937;margin-bottom:8px}.search-header p{color:#6b7280;font-size:1rem}.search-input-container{position:relative;margin-bottom:30px}.search-input{width:100%;padding:16px 50px 16px 20px;border:2px solid #E5E7EB;border-radius:12px;font-size:16px;transition:all .2s ease;box-sizing:border-box}.search-input:focus{outline:none;border-color:#5b47bd;box-shadow:0 0 0 3px #5b47bd1a}.search-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:20px;color:#9ca3af}.search-loading{text-align:center;padding:40px 20px}.search-loading p{color:#6b7280;margin-top:16px}.results-count{color:#374151;font-weight:600;margin-bottom:20px;font-size:14px}.users-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.user-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:20px;transition:all .2s ease}.user-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a;border-color:#d1d5db}.user-info{display:flex;gap:16px;margin-bottom:16px}.user-avatar{flex-shrink:0}.user-avatar img,.avatar-placeholder{width:60px;height:60px;border-radius:50%}.user-avatar img{object-fit:cover}.avatar-placeholder{background:linear-gradient(135deg,#5b47bd,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600}.user-details{flex:1;min-width:0}.user-details h4{margin:0 0 4px;font-size:18px;font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.username{color:#6b7280;font-size:14px;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.premium-badge{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:11px;padding:2px 6px;border-radius:8px;font-weight:600;display:inline-block;margin-bottom:4px}.join-date{color:#9ca3af;font-size:13px;margin:0}.user-actions{display:flex;gap:8px}.btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;flex:1;text-align:center}.btn-outline{background:#fff;color:#374151;border:1px solid #D1D5DB}.btn-outline:hover{background:#f9fafb;border-color:#9ca3af}.btn-primary{background:linear-gradient(135deg,#5b47bd,#7c3aed);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5b47bd4d}.no-results{text-align:center;padding:60px 20px;color:#6b7280}.no-results p{font-size:16px;margin-bottom:8px}.no-results small{color:#9ca3af}.search-hint{text-align:center;padding:20px;color:#9ca3af;font-style:italic}.search-welcome{background:linear-gradient(135deg,#f8f6ff,#f0edff);border-radius:12px;padding:30px;border:1px solid #E8E4FF}.search-tips h4{color:#5b47bd;margin-bottom:16px;font-size:18px}.search-tips ul{list-style:none;padding:0;margin:0}.search-tips li{padding:8px 0;color:#374151;font-size:15px;line-height:1.5}@media (max-width: 768px){.users-grid{grid-template-columns:1fr}.user-card{padding:16px}.user-actions{flex-direction:column}.search-input{font-size:16px}}.leaderboard-page{max-width:1200px;margin:0 auto;padding:24px}.leaderboard-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px}.view-toggle{display:flex;gap:8px}.view-toggle button{padding:8px 16px;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:20px;cursor:pointer;transition:all .2s;font-weight:500}.view-toggle button:hover{background:#f0f4ff}.view-toggle button.active{background:#667eea;color:#fff}.count-selector{display:flex;align-items:center;gap:8px}.count-selector label{color:#666;font-weight:500}.count-selector select{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer}.month-header{text-align:center;margin-bottom:24px}.month-header h2{font-size:1.75rem;color:#333}.leaderboard-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.leaderboard-entry{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0;transition:background .2s}.leaderboard-entry:hover{background:#f8f9fa}.leaderboard-entry.rank-1{background:linear-gradient(90deg,#fff9e6,#fff)}.leaderboard-entry.rank-2{background:linear-gradient(90deg,#f0f0f0,#fff)}.leaderboard-entry.rank-3{background:linear-gradient(90deg,#fff5f0,#fff)}.entry-rank{width:50px;text-align:center;font-size:1.5rem}.rank-number{font-weight:700;color:#666}.entry-user{flex:1;display:flex;align-items:center;gap:12px;margin:0 20px}.user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid #f0f0f0}.user-info{flex:1}.user-name{font-weight:600;color:#333;margin-bottom:2px}.user-level{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#666}.level-icon{width:16px;height:16px}.entry-stats{text-align:right}.points-count{display:flex;align-items:baseline;gap:4px;justify-content:flex-end}.points-number{font-size:1.25rem;font-weight:700;color:#667eea}.points-label{font-size:.875rem;color:#666}.activity-count{font-size:.75rem;color:#999;margin-top:2px}.leaderboard-footer{margin-top:40px;padding:24px;background:#f8f9fa;border-radius:12px}.points-info h3{margin-bottom:16px;color:#333}.points-info ul{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}.points-info li{padding:8px 12px;background:#fff;border-radius:6px;display:flex;align-items:center;gap:8px}@media (max-width: 768px){.leaderboard-page{padding:16px}.page-header h1{font-size:1.75rem}.leaderboard-controls{flex-direction:column;gap:16px}.entry-user{margin:0 12px}.points-info ul{grid-template-columns:1fr}}.points-display{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:20px;color:#fff;box-shadow:0 4px 6px #0000001a;margin-bottom:20px}.points-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.points-total{display:flex;flex-direction:column}.points-value{font-size:2.5rem;font-weight:700;line-height:1}.points-label{font-size:.875rem;opacity:.9;margin-top:4px}.streak-indicator{display:flex;align-items:center;gap:8px;background:#fff3;padding:8px 12px;border-radius:20px}.streak-icon{font-size:1.25rem}.streak-days{font-weight:600;font-size:.875rem}.achievement-level{background:#ffffff1a;border-radius:8px;padding:16px}.level-header{display:flex;gap:12px;margin-bottom:12px}.level-badge{width:48px;height:48px;object-fit:contain}.level-info{flex:1}.level-name{margin:0;font-size:1.25rem;font-weight:600}.level-description{margin:4px 0 0;font-size:.875rem;opacity:.9}.level-progress{margin-top:12px}.progress-bar{height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,gold,#ffed4e);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.75rem;text-align:right;opacity:.9}@media (max-width: 768px){.points-display{padding:16px}.points-value{font-size:2rem}.points-summary{flex-direction:column;gap:12px;align-items:flex-start}}.points-history-page{max-width:1200px;margin:0 auto;padding:24px}.page-header{text-align:center;margin-bottom:32px}.page-header h1{font-size:2.5rem;margin-bottom:8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{color:#666;font-size:1.125rem}.achievement-levels-section{margin:40px 0}.achievement-levels-section h2{font-size:1.5rem;margin-bottom:20px;color:#333}.levels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-bottom:40px}.level-card{background:#fff;border-radius:12px;padding:20px;text-align:center;border:2px solid #e0e0e0;transition:all .3s;position:relative}.level-card.unlocked{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d)}.level-card.current{border-color:gold;box-shadow:0 4px 12px #ffd7004d;transform:scale(1.05)}.level-card.locked{opacity:.6;background:#f5f5f5}.level-badge-img{width:64px;height:64px;margin-bottom:12px;object-fit:contain}.level-card h3{margin:0 0 8px;color:#333;font-size:1.25rem}.level-range{color:#666;font-size:.875rem;margin-bottom:8px}.level-desc{color:#999;font-size:.75rem;margin:8px 0}.current-badge,.locked-badge{position:absolute;top:10px;right:10px;padding:4px 8px;border-radius:12px;font-size:.625rem;font-weight:700;text-transform:uppercase}.current-badge{background:gold;color:#333}.locked-badge{background:#e0e0e0;color:#666}.history-section{margin-top:40px}.history-section h2{font-size:1.5rem;margin-bottom:20px;color:#333}.history-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.history-entry{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0;transition:background .2s}.history-entry:hover{background:#f8f9fa}.history-entry:last-child{border-bottom:none}.entry-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f0f4ff;border-radius:50%;font-size:1.25rem;margin-right:16px}.entry-details{flex:1}.entry-description{font-weight:500;color:#333;margin-bottom:4px;text-transform:capitalize}.entry-date{font-size:.75rem;color:#999}.entry-points{font-size:1.25rem;font-weight:700}.entry-points.positive{color:#4caf50}.entry-points.negative{color:#f44336}.loading-state,.empty-state{text-align:center;padding:60px 20px;color:#666}.spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px}.pagination button{padding:8px 16px;border:1px solid #667eea;background:#fff;color:#667eea;border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500}.pagination button:hover:not(:disabled){background:#667eea;color:#fff}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:#666;font-weight:500}@media (max-width: 768px){.points-history-page{padding:16px}.page-header h1{font-size:1.75rem}.levels-grid{grid-template-columns:1fr}.level-card.current{transform:scale(1)}.history-entry{padding:12px 16px}.entry-icon{width:32px;height:32px;font-size:1rem;margin-right:12px}}.how-to-earn-page{max-width:1200px;margin:0 auto;padding:24px}.page-header{text-align:center;margin-bottom:40px}.page-header h1{font-size:2.5rem;margin-bottom:16px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:1.125rem;color:#666;max-width:600px;margin:0 auto;line-height:1.6}.intro-section{margin-bottom:40px}.intro-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:32px;border-radius:16px;text-align:center}.intro-card h2{margin-bottom:16px;font-size:1.75rem}.intro-card p{font-size:1.125rem;line-height:1.6;opacity:.95}.activities-section{margin-bottom:48px}.activities-section h2{text-align:center;font-size:2rem;margin-bottom:32px;color:#333}.activities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:24px}.activity-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px #0000001a;transition:transform .2s,box-shadow .2s}.activity-card:hover{transform:translateY(-2px);box-shadow:0 8px 12px #00000026}.activity-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.activity-icon{font-size:2rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f0f4ff;border-radius:50%}.activity-info h3{margin:0 0 8px;color:#333;font-size:1.25rem}.points-badge{background:#667eea;color:#fff;padding:4px 12px;border-radius:20px;font-size:.875rem;font-weight:600}.activity-description{color:#666;line-height:1.6;margin-bottom:16px}.activity-examples h4{margin:0 0 8px;color:#333;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.activity-examples ul{list-style:none;padding:0;margin:0}.activity-examples li{color:#666;font-size:.875rem;position:relative;padding:4px 0 4px 16px}.activity-examples li:before{content:"•";color:#667eea;position:absolute;left:0}.achievements-section{margin-bottom:48px}.achievements-section h2{text-align:center;font-size:2rem;margin-bottom:16px;color:#333}.achievements-intro{text-align:center;color:#666;margin-bottom:32px;font-size:1.125rem}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.achievement-card{background:#fff;border-radius:12px;padding:24px;text-align:center;box-shadow:0 4px 6px #0000001a;transition:transform .2s}.achievement-card:hover{transform:translateY(-2px)}.achievement-header{margin-bottom:16px}.achievement-badge,.achievement-placeholder{width:64px;height:64px;margin:0 auto 12px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;background:#f0f4ff}.achievement-card h3{margin:0;color:#333;font-size:1.25rem}.achievement-range{color:#667eea;font-weight:600;margin-bottom:8px}.achievement-description{color:#666;font-size:.875rem}.tips-section{margin-bottom:48px}.tips-section h2{text-align:center;font-size:2rem;margin-bottom:32px;color:#333}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.tip-card{background:#f8f9fa;border-radius:12px;padding:24px;text-align:center}.tip-card h3{color:#333;margin-bottom:12px;font-size:1.125rem}.tip-card p{color:#666;line-height:1.6;margin:0}.leaderboard-section{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:32px;border-radius:16px;text-align:center;margin-bottom:48px}.leaderboard-section h2{margin-bottom:16px;font-size:1.75rem}.leaderboard-section p{font-size:1.125rem;margin-bottom:24px;opacity:.95}.leaderboard-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.leaderboard-actions .btn{padding:12px 24px;border-radius:25px;text-decoration:none;font-weight:600;transition:all .2s}.leaderboard-actions .btn.btn-primary{background:#fff;color:#4caf50}.leaderboard-actions .btn.btn-secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.leaderboard-actions .btn:hover{transform:translateY(-1px)}.faq-section{background:#fff;border-radius:12px;padding:32px;box-shadow:0 4px 6px #0000001a}.faq-section h2{text-align:center;font-size:1.75rem;margin-bottom:32px;color:#333}.faq-list{display:grid;gap:24px}.faq-item{border-bottom:1px solid #f0f0f0;padding-bottom:20px}.faq-item:last-child{border-bottom:none;padding-bottom:0}.faq-item h3{color:#333;margin-bottom:8px;font-size:1.125rem}.faq-item p{color:#666;line-height:1.6;margin:0}@media (max-width: 768px){.how-to-earn-page{padding:16px}.page-header h1{font-size:1.75rem}.activities-grid,.achievements-grid,.tips-grid{grid-template-columns:1fr}.leaderboard-actions{flex-direction:column;align-items:center}.leaderboard-actions .btn{width:100%;max-width:200px}}.admin-points-management{max-width:1200px;margin:0 auto;padding:24px}.page-header{margin-bottom:32px}.page-header h1{font-size:2rem;margin-bottom:8px;color:#333}.page-header p{color:#666}.tab-navigation{display:flex;gap:8px;margin-bottom:32px;border-bottom:2px solid #f0f0f0}.tab-navigation button{padding:12px 20px;border:none;background:none;color:#666;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent;font-weight:500}.tab-navigation button:hover{color:#333;background:#f8f9fa}.tab-navigation button.active{color:#667eea;border-bottom-color:#667eea}.admin-section{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{margin:0}.btn-primary{background:#667eea;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-primary:hover{background:#5a67d8}.admin-section h2{margin-bottom:24px;color:#333}.settings-table,.levels-table{display:flex;flex-direction:column;gap:16px}.setting-row,.level-row{border:1px solid #e0e0e0;border-radius:8px;padding:16px;background:#fafafa}.setting-display,.level-display{display:flex;justify-content:space-between;align-items:center}.setting-info h3,.level-info h3{margin:0 0 8px;color:#333;text-transform:capitalize}.setting-info p,.level-info p{margin:0 0 12px;color:#666}.setting-meta,.level-meta{display:flex;gap:16px;align-items:center}.points,.range{font-weight:600;color:#667eea}.status.active{color:#4caf50;font-weight:500}.status.inactive{color:#f44336;font-weight:500}.btn-edit,.btn-save,.btn-cancel{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.btn-edit{background:#667eea;color:#fff}.btn-edit:hover{background:#5a6fd8}.btn-save{background:#4caf50;color:#fff}.btn-save:hover{background:#45a049}.btn-cancel{background:#f44336;color:#fff}.btn-cancel:hover{background:#da190b}.edit-form{width:100%}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group label{display:block;margin-bottom:4px;font-weight:500;color:#333}.form-group input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input[type=checkbox]{width:auto;margin-right:8px}.button-group{display:flex;gap:8px;margin-top:16px}.users-table,.transactions-table{background:#fff;border-radius:8px;overflow:hidden}.table-header{display:grid;padding:12px 16px;background:#f8f9fa;font-weight:600;color:#333;border-bottom:1px solid #e0e0e0}.users-table .table-header{grid-template-columns:2fr 1fr 1fr 1fr 1fr}.transactions-table .table-header{grid-template-columns:1fr 1fr 80px 1fr 2fr}.user-row,.transaction-row{display:grid;padding:12px 16px;border-bottom:1px solid #f0f0f0;align-items:center}.users-table .user-row{grid-template-columns:2fr 1fr 1fr 1fr 1fr}.transactions-table .transaction-row{grid-template-columns:1fr 1fr 80px 1fr 2fr}.user-row:hover,.transaction-row:hover{background:#f8f9fa}.user-info{display:flex;flex-direction:column}.user-name{font-weight:500;color:#333}.user-email{font-size:.875rem;color:#666}.user-points{font-weight:600;color:#667eea}.user-streak{color:#ff9800;font-weight:500}.transaction-points.positive{color:#4caf50;font-weight:600}.transaction-points.negative{color:#f44336;font-weight:600}.transaction-action{text-transform:capitalize;color:#666}.transaction-description{color:#666;font-size:.875rem}.loading{text-align:center;padding:60px;color:#666;font-size:1.125rem}@media (max-width: 768px){.admin-points-management{padding:16px}.tab-navigation{flex-wrap:wrap}.setting-display,.level-display{flex-direction:column;align-items:flex-start;gap:12px}.form-row{grid-template-columns:1fr}.users-table .table-header,.users-table .user-row,.transactions-table .table-header,.transactions-table .transaction-row{grid-template-columns:1fr;gap:8px}.table-header{display:none}.user-row,.transaction-row{display:block;padding:16px}}.weather-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 32px #0003;transition:transform .3s ease,box-shadow .3s ease}.weather-card:hover{transform:translateY(-4px);box-shadow:0 12px 48px #0000004d}.weather-card.rainy{background:linear-gradient(135deg,#4a6fa5,#166a8f)}.weather-card.sunny{background:linear-gradient(135deg,#ffeaa7,#fdcb6e);color:#2d3436}.weather-card.cloudy{background:linear-gradient(135deg,#636e72,#2d3436)}.weather-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.location-info h3{margin:0 0 4px;font-size:1.4rem;font-weight:600}.location-type{font-size:.9rem;opacity:.8;text-transform:capitalize}.weather-icon{width:60px;height:60px;opacity:.9}.current-weather{margin-bottom:24px}.temperature{font-size:3rem;font-weight:300;margin:0;line-height:1}.feels-like{font-size:.9rem;opacity:.8;margin-top:4px}.weather-description{font-size:1.1rem;margin:8px 0;text-transform:capitalize}.weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;margin-bottom:20px}.weather-detail{text-align:center}.weather-detail-label{font-size:.8rem;opacity:.8;margin-bottom:4px}.weather-detail-value{font-size:1.1rem;font-weight:500}.forecast-preview{border-top:1px solid rgba(255,255,255,.2);padding-top:16px}.forecast-title{font-size:.9rem;opacity:.8;margin-bottom:12px}.forecast-items{display:flex;gap:16px;overflow-x:auto;padding-bottom:4px}.forecast-item{flex-shrink:0;text-align:center;min-width:60px}.forecast-day{font-size:.8rem;opacity:.8;margin-bottom:4px}.forecast-icon{width:24px;height:24px;margin:4px auto;opacity:.9}.forecast-temps{font-size:.85rem}.temp-high{font-weight:500}.temp-low{opacity:.8}.rain-indicator{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;background:#ffffff1a;border-radius:8px}.rain-icon{width:20px;height:20px}.rain-chance{font-size:.9rem}.alerts-indicator{position:absolute;top:16px;right:16px;background:#e74c3c;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}.weather-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:#fff;font-size:1.1rem}.weather-error{background:#e74c3c;color:#fff;padding:16px;border-radius:8px;text-align:center}@media (max-width: 768px){.weather-card{padding:20px}.temperature{font-size:2.5rem}.weather-details{grid-template-columns:repeat(2,1fr);gap:12px}.forecast-items{gap:12px}}.weather-alerts{margin-bottom:24px}.alerts-container{display:flex;flex-direction:column;gap:16px}.alert-item{background:linear-gradient(135deg,#e74c3c,#c0392b);border-radius:12px;padding:20px;color:#fff;border-left:4px solid #fff;animation:alertPulse 3s infinite}.alert-item.minor{background:linear-gradient(135deg,#f39c12,#d68910)}.alert-item.moderate{background:linear-gradient(135deg,#e67e22,#d35400)}.alert-item.severe{background:linear-gradient(135deg,#e74c3c,#c0392b)}.alert-item.extreme{background:linear-gradient(135deg,#8e44ad,#7d3c98)}@keyframes alertPulse{0%{opacity:1}50%{opacity:.9}to{opacity:1}}.alert-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.alert-icon{font-size:1.5rem;flex-shrink:0}.alert-title{font-size:1.2rem;font-weight:600;margin:0;flex:1}.alert-severity{background:#fff3;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.alert-description{font-size:.95rem;line-height:1.5;margin:0 0 16px;opacity:.95}.alert-timing{display:flex;flex-wrap:wrap;gap:16px;font-size:.85rem;opacity:.9}.alert-time{display:flex;align-items:center;gap:6px}.alert-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.alert-tag{background:#ffffff26;padding:4px 10px;border-radius:16px;font-size:.75rem;text-transform:capitalize}.alerts-loading{display:flex;align-items:center;justify-content:center;padding:40px;font-size:1.1rem;color:#666}.alerts-error{background:#e74c3c;color:#fff;padding:16px;border-radius:8px;text-align:center;margin-bottom:16px}.no-alerts{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;padding:20px;border-radius:12px;text-align:center;display:flex;align-items:center;justify-content:center;gap:12px}.no-alerts-icon{font-size:1.5rem}.alerts-section-title{font-size:1.4rem;font-weight:600;color:#2c3e50;margin:0 0 16px;display:flex;align-items:center;gap:12px}.alerts-title-icon{font-size:1.6rem}@media (max-width: 768px){.alert-item{padding:16px}.alert-title{font-size:1.1rem}.alert-description{font-size:.9rem}.alert-timing{font-size:.8rem;gap:12px}.alert-tags{margin-top:8px}.alerts-section-title{font-size:1.3rem}}.weather-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-top:20px}.weather-container{max-width:1200px;margin:0 auto;padding:0 20px}.weather-hero{text-align:center;color:#fff;margin-bottom:40px}.weather-hero h1{font-size:3rem;font-weight:700;margin:0 0 16px;text-shadow:0 2px 10px rgba(0,0,0,.3)}.weather-hero p{font-size:1.2rem;opacity:.9;margin:0;text-shadow:0 1px 5px rgba(0,0,0,.3)}.weather-sections{display:flex;flex-direction:column;gap:48px}.weather-section{background:#fffffff2;border-radius:20px;padding:32px;box-shadow:0 10px 40px #0003}.weather-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:24px}.weather-grid.cruise-ports{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.weather-tabs{display:flex;background:#ffffff1a;border-radius:12px;padding:4px;margin-bottom:32px;gap:4px}.weather-tab{flex:1;background:transparent;border:none;color:#fff;padding:12px 20px;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;opacity:.7}.weather-tab.active{background:#fff3;opacity:1;font-weight:500}.weather-tab:hover{opacity:1;background:#ffffff1a}.last-updated{text-align:center;color:#fffc;font-size:.9rem;margin-top:32px;padding-top:16px;border-top:1px solid rgba(255,255,255,.2)}.cache-indicator{display:inline-flex;align-items:center;gap:6px;background:#ffffff1a;padding:6px 12px;border-radius:16px;font-size:.8rem;margin-left:12px}.cache-fresh{color:#2ecc71}.cache-stale{color:#f39c12}@media (max-width: 1024px){.weather-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}}@media (max-width: 768px){.weather-page{padding-top:16px}.weather-container{padding:0 16px}.weather-hero h1{font-size:2.2rem}.weather-hero p{font-size:1.1rem}.weather-sections{gap:32px}.weather-section{padding:24px 20px}.section-header{flex-direction:column;text-align:center;gap:12px;margin-bottom:24px}.section-title{font-size:1.7rem}.weather-grid{grid-template-columns:1fr;gap:16px}.weather-tabs{flex-direction:column;gap:2px}.weather-tab{padding:14px;text-align:center}}@media (max-width: 480px){.weather-hero h1{font-size:1.8rem}.section-title{font-size:1.5rem}.weather-section{padding:20px 16px}}.cruise-page{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#764ba2);padding-top:20px}.cruise-container{max-width:1200px;margin:0 auto;padding:0 20px}.cruise-hero{text-align:center;color:#fff;margin-bottom:40px}.cruise-hero h1{font-size:3rem;font-weight:700;margin:0 0 16px;text-shadow:0 2px 10px rgba(0,0,0,.3)}.cruise-hero p{font-size:1.2rem;opacity:.9;margin:0;text-shadow:0 1px 5px rgba(0,0,0,.3)}.cruise-sections{display:flex;flex-direction:column;gap:48px}.cruise-section{background:#fffffff2;border-radius:20px;padding:32px;box-shadow:0 10px 40px #0003}.section-header{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid #e0e6ed}.section-icon{font-size:2.5rem}.section-title{font-size:2rem;font-weight:600;color:#2c3e50;margin:0}.section-subtitle{font-size:1rem;color:#7f8c8d;margin:4px 0 0}.cruise-tabs{display:flex;background:#ffffff1a;border-radius:12px;padding:4px;margin-bottom:32px;gap:4px}.cruise-tab{flex:1;background:transparent;border:none;color:#fff;padding:12px 20px;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;opacity:.7}.cruise-tab.active{background:#fff3;opacity:1;font-weight:500}.cruise-tab:hover{opacity:1;background:#ffffff1a}.cruise-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:24px}.cruise-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #0000001a;border:1px solid #e0e6ed;transition:all .3s ease;cursor:pointer}.cruise-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #00000026}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.action-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:24px 20px;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-align:center;box-shadow:0 4px 20px #0000001a}.action-button:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0003}.action-button-icon{font-size:2rem;display:block;margin-bottom:8px}.fish-extender-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.fish-extender-card{background:#fff;border:1px solid #e0e6ed;border-radius:12px;padding:20px;transition:all .3s ease}.fish-extender-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.section-loading{display:flex;align-items:center;justify-content:center;min-height:200px;font-size:1.2rem;color:#7f8c8d}.section-error{background:#e74c3c;color:#fff;padding:24px;border-radius:12px;text-align:center;margin:16px 0}.refresh-button{background:#3498db;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;cursor:pointer;margin-top:16px;transition:all .3s ease}.refresh-button:hover{background:#2980b9;transform:translateY(-2px)}.empty-state{text-align:center;color:#7f8c8d;padding:60px 20px}.empty-state-icon{font-size:4rem;margin-bottom:20px;opacity:.7}.empty-state h3{font-size:1.5rem;margin:0 0 16px;color:#2c3e50}.empty-state p{font-size:1rem;max-width:400px;margin:0 auto 24px}@media (max-width: 768px){.cruise-page{padding-top:16px}.cruise-container{padding:0 16px}.cruise-hero h1{font-size:2.2rem}.cruise-hero p{font-size:1.1rem}.cruise-sections{gap:32px}.cruise-section{padding:24px 20px}.section-header{flex-direction:column;text-align:center;gap:12px;margin-bottom:24px}.section-title{font-size:1.7rem}.cruise-grid{grid-template-columns:1fr;gap:16px}.cruise-tabs{flex-direction:column;gap:2px}.cruise-tab{padding:14px;text-align:center}}.checklist-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;padding:30px;margin-bottom:30px;box-shadow:0 10px 30px #667eea4d;position:relative;overflow:hidden}.checklist-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="checklist-pattern" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23checklist-pattern)"/></svg>') repeat;opacity:.3}.checklist-header__content{display:flex;align-items:center;gap:20px;position:relative;z-index:1}.checklist-header__icon{font-size:3.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.checklist-header__text{flex:1}.checklist-header__title{font-size:2.2rem;font-weight:700;margin:0 0 10px;background:linear-gradient(45deg,#fff,#f8f9fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.1)}.checklist-header__subtitle{font-size:1.1rem;margin:0;opacity:.95;line-height:1.5}@media (max-width: 768px){.checklist-header{padding:25px 20px;margin-bottom:25px}.checklist-header__content{flex-direction:column;text-align:center;gap:15px}.checklist-header__icon{font-size:2.8rem}.checklist-header__title{font-size:1.8rem}.checklist-header__subtitle{font-size:1rem}}@media (max-width: 480px){.checklist-header{padding:20px 15px;margin-bottom:20px}.checklist-header__icon{font-size:2.5rem}.checklist-header__title{font-size:1.6rem}.checklist-header__subtitle{font-size:.9rem}}.checklist-progress{background:#fff;border-radius:15px;padding:25px;margin-bottom:25px;box-shadow:0 5px 20px #00000014;border:1px solid #e1e8ed}.checklist-progress__main{display:flex;align-items:center;gap:30px;margin-bottom:25px}.checklist-progress__summary h3{color:#2c3e50;font-size:1.4rem;margin:0 0 15px;font-weight:600}.checklist-progress__stats{display:flex;gap:20px}.stat{text-align:center}.stat__value{display:block;font-size:1.8rem;font-weight:700;color:#667eea;margin-bottom:4px}.stat__label{display:block;font-size:.85rem;color:#657786;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.checklist-progress__bar-container{flex:1}.checklist-progress__bar{background:#e1e8ed;border-radius:25px;height:16px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.checklist-progress__fill{background:linear-gradient(135deg,#667eea,#764ba2);height:100%;border-radius:25px;position:relative;transition:width .6s ease;display:flex;align-items:center;justify-content:flex-end;padding:0 10px;min-width:40px;box-shadow:0 2px 8px #667eea4d}.checklist-progress__percentage{color:#fff;font-size:.75rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2)}.checklist-progress__categories h4{color:#2c3e50;font-size:1.2rem;margin:0 0 15px;font-weight:600}.category-progress-list{display:grid;gap:12px}.category-progress{background:#f8f9fa;border-radius:10px;padding:15px;border:1px solid #e9ecef}.category-progress__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.category-progress__name{font-weight:600;color:#2c3e50;font-size:.95rem}.category-progress__stats{font-size:.85rem;color:#657786;font-weight:500}.category-progress__bar{background:#dee2e6;border-radius:10px;height:6px;overflow:hidden}.category-progress__fill{background:linear-gradient(135deg,#4facfe,#00f2fe);height:100%;border-radius:10px;transition:width .4s ease}@media (max-width: 768px){.checklist-progress{padding:20px;margin-bottom:20px}.checklist-progress__main{flex-direction:column;gap:20px;align-items:stretch;text-align:center}.checklist-progress__stats{justify-content:center;gap:30px}.stat__value{font-size:1.6rem}}@media (max-width: 480px){.checklist-progress{padding:15px}.checklist-progress__stats{gap:20px}.stat__value{font-size:1.4rem}.stat__label{font-size:.8rem}.category-progress{padding:12px}}.checklist-item{border-bottom:1px solid #e1e8ed;transition:all .3s ease;background:#fff;position:relative}.checklist-item:last-child{border-bottom:none}.checklist-item:hover{background:#f8f9fa}.checklist-item--completed{opacity:.7;background:#f1f8ff}.checklist-item--completed:hover{background:#e6f3ff}.checklist-item__main{display:flex;align-items:flex-start;gap:15px;padding:20px}.checklist-item__checkbox{cursor:pointer;flex-shrink:0;margin-top:2px}.checkbox{width:24px;height:24px;border:2px solid #d1d9e0;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:#fff}.checklist-item--completed .checkbox{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea}.checkbox__icon{color:#fff;opacity:0;transform:scale(.8);transition:all .2s ease}.checklist-item--completed .checkbox__icon{opacity:1;transform:scale(1)}.checkbox:hover{border-color:#667eea;transform:scale(1.05)}.checklist-item__content{flex:1;min-width:0}.checklist-item__header{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:8px}.checklist-item__title{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0;line-height:1.4;flex:1;transition:color .2s ease}.checklist-item--completed .checklist-item__title{color:#657786;text-decoration:line-through}.checklist-item__timing{background:linear-gradient(135deg,#ffeaa7,#fab1a0);color:#2d3436;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap;letter-spacing:.3px}.checklist-item__description{color:#657786;font-size:.95rem;line-height:1.5;margin:0 0 10px}.checklist-item__notes{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:10px;margin:10px 0;font-size:.9rem;color:#856404}.checklist-item__notes strong{color:#533f03}.checklist-item__completed-date{color:#28a745;font-size:.85rem;font-weight:500;margin-top:8px;display:flex;align-items:center;gap:5px}.checklist-item__completed-date:before{content:"✓";font-weight:700}.checklist-item__actions{display:flex;gap:8px;flex-shrink:0;opacity:0;transition:opacity .2s ease}.checklist-item:hover .checklist-item__actions{opacity:1}.checklist-item__action-btn{background:none;border:none;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:14px}.checklist-item__action-btn:hover{background:#e9ecef;transform:scale(1.1)}.checklist-item__action-btn--delete:hover{background:#f8d7da;color:#721c24}@media (max-width: 768px){.checklist-item__main{padding:15px;gap:12px}.checklist-item__header{flex-direction:column;align-items:flex-start;gap:8px}.checklist-item__timing{align-self:flex-start;font-size:.7rem;padding:3px 8px}.checklist-item__actions{opacity:1}}@media (max-width: 480px){.checklist-item__main{padding:12px;gap:10px}.checklist-item__title{font-size:1rem}.checklist-item__description{font-size:.9rem}.checklist-item__notes{padding:8px;font-size:.85rem}.checkbox{width:20px;height:20px}.checklist-item__action-btn{width:28px;height:28px;font-size:12px}}.checklist-items{display:flex;flex-direction:column;gap:25px}.checklist-items-empty{display:flex;justify-content:center;align-items:center;min-height:300px;text-align:center}.empty-state{padding:40px 20px}.empty-state__icon{font-size:3rem;margin-bottom:15px;opacity:.6}.empty-state h3{color:#2c3e50;font-size:1.5rem;margin:0 0 10px;font-weight:600}.empty-state p{color:#657786;font-size:1rem;margin:0}.checklist-category{background:#fff;border-radius:15px;border:1px solid #e1e8ed;overflow:hidden;box-shadow:0 3px 12px #0000000d;transition:box-shadow .3s ease}.checklist-category:hover{box-shadow:0 5px 20px #00000014}.checklist-category__header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:15px 20px;border-bottom:1px solid #e1e8ed;display:flex;justify-content:space-between;align-items:center}.checklist-category__title{color:#2c3e50;font-size:1.2rem;margin:0;font-weight:600;display:flex;align-items:center;gap:8px}.checklist-category__title:before{content:"📂";font-size:1rem}.checklist-category__count{background:#667eea;color:#fff;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.3px}.checklist-category__items{padding:0}.checklist-category:has(.checklist-category__title:contains("Planning")) .checklist-category__title:before{content:"📅"}.checklist-category:has(.checklist-category__title:contains("Packing")) .checklist-category__title:before{content:"🧳"}.checklist-category:has(.checklist-category__title:contains("Final Prep")) .checklist-category__title:before{content:"✅"}.checklist-category:has(.checklist-category__title:contains("Day Of")) .checklist-category__title:before{content:"🚢"}.checklist-category__title:has-text("Planning"):before{content:"📅"}@media (max-width: 768px){.checklist-items{gap:20px}.checklist-category__header{padding:12px 15px;flex-direction:column;gap:8px;text-align:center}.checklist-category__title{font-size:1.1rem}.checklist-category__count{font-size:.75rem;padding:3px 10px}}@media (max-width: 480px){.checklist-items{gap:15px}.checklist-category__header{padding:10px 12px}.checklist-category__title{font-size:1rem}}.checklist-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.checklist-modal{background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow:hidden;transform:translateY(20px);animation:slideUp .3s ease-out forwards}@keyframes slideUp{to{transform:translateY(0)}}.checklist-modal__header{display:flex;justify-content:space-between;align-items:center;padding:25px 25px 20px;border-bottom:1px solid #e1e8ed;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.checklist-modal__header h3{color:#2c3e50;font-size:1.4rem;font-weight:600;margin:0}.checklist-modal__close{background:none;border:none;font-size:1.5rem;color:#657786;cursor:pointer;padding:5px;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.checklist-modal__close:hover{background:#0000001a;color:#2c3e50;transform:scale(1.1)}.checklist-modal__form{padding:25px;max-height:calc(90vh - 100px);overflow-y:auto}.form-group{margin-bottom:20px}.form-label{display:block;color:#2c3e50;font-weight:600;font-size:.9rem;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-textarea,.form-select{width:100%;padding:12px 15px;border:2px solid #e1e8ed;border-radius:8px;font-size:1rem;transition:all .2s ease;font-family:inherit;background:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input--error{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.form-textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}.form-select{cursor:pointer;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.form-error{color:#e74c3c;font-size:.85rem;margin-top:5px;font-weight:500}.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.form-checkbox__checkmark{width:20px;height:20px;border:2px solid #d1d9e0;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:#fff;flex-shrink:0}.form-checkbox input[type=checkbox]:checked+.form-checkbox__checkmark{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea}.form-checkbox input[type=checkbox]:checked+.form-checkbox__checkmark:after{content:"✓";color:#fff;font-weight:700;font-size:12px}.form-checkbox__label{color:#2c3e50;font-weight:500}.checklist-modal__actions{display:flex;gap:12px;justify-content:flex-end;padding-top:20px;border-top:1px solid #e1e8ed;margin-top:20px}.btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap}.btn--secondary{background:#6c757d;color:#fff}.btn--secondary:hover{background:#5a6268;box-shadow:0 8px 25px #6c757d66}@media (max-width: 768px){.checklist-modal-overlay{padding:15px}.checklist-modal{max-width:100%}.checklist-modal__header{padding:20px 20px 15px}.checklist-modal__header h3{font-size:1.2rem}.checklist-modal__form{padding:20px}.form-group{margin-bottom:16px}.checklist-modal__actions{flex-direction:column-reverse;gap:8px}.btn{width:100%;justify-content:center}}@media (max-width: 480px){.checklist-modal-overlay{padding:10px}.checklist-modal__header{padding:15px 15px 12px}.checklist-modal__form{padding:15px}.form-input,.form-textarea,.form-select{padding:10px 12px;font-size:.95rem}.form-label{font-size:.85rem}}.cruise-checklist{max-width:1200px;margin:0 auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.loading-spinner{font-size:3rem;animation:spin 2s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.filter-tab:hover{border-color:#1da1f2;color:#1da1f2;transform:translateY(-1px)}.filter-tab--active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff;box-shadow:0 4px 15px #667eea4d}.btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:25px;padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66;filter:brightness(1.1)}.btn--primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn--secondary{background:linear-gradient(135deg,#f093fb,#f5576c)}.btn--success{background:linear-gradient(135deg,#4facfe,#00f2fe)}.btn--danger{background:linear-gradient(135deg,#fa709a,#fee140)}@media (max-width: 768px){.cruise-checklist{padding:15px}.checklist-actions{flex-direction:column;align-items:stretch}.filter-tabs{justify-content:center;margin-bottom:15px}.filter-tab{font-size:.8rem;padding:6px 12px}}@media (max-width: 480px){.cruise-checklist{padding:10px}.checklist-loading h2,.checklist-error h2{font-size:1.5rem}.filter-tabs{gap:3px}.filter-tab{font-size:.75rem;padding:5px 10px}}.resort-checklist{max-width:1200px;margin:0 auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.checklist-loading,.checklist-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:40px 20px}.loading-spinner{font-size:3rem;animation:bounce 2s ease-in-out infinite;margin-bottom:20px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-30px)}60%{transform:translateY(-15px)}}.checklist-loading h2,.checklist-error h2{color:#2c3e50;margin-bottom:10px;font-size:1.8rem}.checklist-loading p,.checklist-error p{color:#7f8c8d;font-size:1.1rem;margin-bottom:20px}.checklist-actions{display:flex;justify-content:space-between;align-items:center;margin:30px 0;flex-wrap:wrap;gap:20px}.filter-tabs{display:flex;gap:5px;flex-wrap:wrap}.filter-tab{background:#fff;border:2px solid #e1e8ed;border-radius:20px;padding:8px 16px;font-size:.9rem;font-weight:500;color:#657786;cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-tab:hover{border-color:#ff6b6b;color:#ff6b6b;transform:translateY(-1px)}.filter-tab--active{background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-color:transparent;color:#fff;box-shadow:0 4px 15px #ff6b6b4d}.btn{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;border:none;border-radius:25px;padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff6b6b66;filter:brightness(1.1)}.btn:active{transform:translateY(0)}.btn--primary{background:linear-gradient(135deg,#ff6b6b,#ee5a52)}.btn--secondary{background:linear-gradient(135deg,#74b9ff,#0984e3)}.btn--success{background:linear-gradient(135deg,#00b894,#00a085)}.btn--danger{background:linear-gradient(135deg,#e17055,#d63031)}.resort-checklist .checklist-header{background:linear-gradient(135deg,#ff6b6b,#ee5a52);box-shadow:0 10px 30px #ff6b6b4d}.resort-checklist .checklist-header:before{background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="castle-pattern" x="0" y="0" width="25" height="25" patternUnits="userSpaceOnUse"><polygon points="12.5,5 15,10 20,10 16,13 17.5,18 12.5,15 7.5,18 9,13 5,10 10,10" fill="rgba(255,255,255,0.08)"/></pattern></defs><rect width="100" height="100" fill="url(%23castle-pattern)"/></svg>') repeat}.resort-checklist .checklist-progress__fill{background:linear-gradient(135deg,#ff6b6b,#ee5a52);box-shadow:0 2px 8px #ff6b6b4d}.resort-checklist .category-progress__fill{background:linear-gradient(135deg,#74b9ff,#0984e3)}.resort-checklist .stat__value{color:#ff6b6b}@media (max-width: 768px){.resort-checklist{padding:15px}.checklist-actions{flex-direction:column;align-items:stretch}.filter-tabs{justify-content:center;margin-bottom:15px}.filter-tab{font-size:.8rem;padding:6px 12px}}@media (max-width: 480px){.resort-checklist{padding:10px}.checklist-loading h2,.checklist-error h2{font-size:1.5rem}.filter-tabs{gap:3px}.filter-tab{font-size:.75rem;padding:5px 10px}}.experiences-page{min-height:100vh;background:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb);padding-top:20px}.experiences-container{max-width:1200px;margin:0 auto;padding:0 20px}.experiences-hero{text-align:center;color:#fff;margin-bottom:40px}.experiences-hero h1{font-size:3rem;font-weight:700;margin:0 0 16px;text-shadow:0 2px 10px rgba(0,0,0,.3)}.experiences-hero p{font-size:1.2rem;opacity:.9;margin:0;text-shadow:0 1px 5px rgba(0,0,0,.3)}.experiences-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:32px}.experiences-tab{background:#fff3;color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.experiences-tab:hover{background:#ffffff4d;transform:translateY(-2px)}.experiences-tab.active{background:#fffffff2;color:#2d3748;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.experiences-content{background:#fffffff2;border-radius:20px;padding:32px;box-shadow:0 10px 40px #0003;min-height:600px}.experiences-sections{display:flex;flex-direction:column;gap:48px}.experiences-section{background:#fffffff2;border-radius:20px;padding:32px;box-shadow:0 10px 40px #0003}.section-header{display:flex;align-items:center;gap:16px;margin-bottom:32px}.section-icon{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.section-title{font-size:1.8rem;font-weight:700;color:#2d3748;margin:0 0 8px}.section-subtitle{color:#718096;margin:0;font-size:1rem}.experiences-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.experiences-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:32px}.loading-spinner{display:flex;justify-content:center;align-items:center;height:200px;color:#fff;font-size:1.2rem}.error-state{background:#fecacaf2;border:2px solid #fc8181;border-radius:12px;padding:24px;text-align:center;color:#742a2a}.empty-state{text-align:center;padding:60px 20px;color:#4a5568}.empty-state h3{font-size:1.5rem;font-weight:600;margin:16px 0}.empty-state p{margin-bottom:24px;opacity:.8}.empty-state .emoji{font-size:4rem;margin-bottom:16px;display:block}.login-required{text-align:center;color:#fff;padding:60px 20px}.login-required h1{font-size:3rem;font-weight:700;margin:0 0 16px;text-shadow:0 2px 10px rgba(0,0,0,.3)}.login-required p{font-size:1.2rem;opacity:.9;text-shadow:0 1px 5px rgba(0,0,0,.3);max-width:600px;margin:0 auto 32px}.login-required .emoji{font-size:4rem;margin-bottom:16px;display:block;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.login-box{background:#fffffff2;border-radius:16px;padding:32px;max-width:400px;margin:0 auto;box-shadow:0 10px 40px #0003}.login-box h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 12px}.login-box p{color:#4a5568;font-size:.9rem;margin:0;text-shadow:none}@media (max-width: 768px){.experiences-hero h1{font-size:2.5rem}.experiences-hero p{font-size:1rem}.experiences-tabs{flex-wrap:wrap}.experiences-tab{padding:10px 20px;font-size:.9rem}.experiences-content,.experiences-section{padding:20px}.section-title{font-size:1.5rem}.login-required h1{font-size:2.5rem}.login-required p{font-size:1rem}}.app{min-height:100vh;display:flex;flex-direction:column}
