@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--color-bg: #FAFAFA;--color-sidebar: #1e293b;--color-card: #ffffff;--color-card-dark: #FAFAFA;--color-text: #1e293b;--color-text-light: #ffffff;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-primary: #2563eb;--color-primary-light: #dbeafe;--color-primary-dark: #1d4ed8;--color-green: #16a34a;--color-green-light: #dcfce7;--color-blue: #2563eb;--color-blue-light: #dbeafe;--color-orange: #ea580c;--color-orange-light: #ffedd5;--color-gray: #64748b;--color-gray-light: #FAFAFA;--slot-best: #1CB67D;--slot-partial: #8E74DB;--slot-off-hours: #F0896D;--slot-night: #475569;--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SF Mono", Monaco, monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--border-color: #e2e8f0}*{margin:0;padding:0;box-sizing:border-box}html{font-size:15px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}@media screen and (max-width:767px){input,select,textarea{font-size:16px!important}}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);background:var(--color-sidebar);border-bottom:none}.logo{display:flex;align-items:center;gap:var(--space-sm)}.logo-icon{color:var(--color-primary);width:32px;height:32px}.logo-text{font-size:1.5rem;font-weight:800;color:var(--color-text-light);letter-spacing:-.02em}.header-right{display:flex;align-items:center;gap:var(--space-md)}.language-selector{position:relative}.language-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;color:var(--color-text-light);cursor:pointer;transition:all .2s ease}.language-button:hover{background:#fff3}.language-dropdown{position:absolute;top:100%;right:0;margin-top:8px;min-width:150px;background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border-color);z-index:200;overflow:hidden}.language-option{display:block;width:100%;padding:12px 18px;text-align:left;background:none;border:none;font-size:.9375rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .15s ease}.language-option:hover{background:var(--color-card-dark)}.language-option.active{background:var(--color-primary);color:#fff}.main{flex:1;width:100%;max-width:1000px;margin:0 auto;padding:var(--space-xl)}.hero-banner{text-align:center;margin-bottom:var(--space-xl)}.hero-banner h1{font-size:1.75rem;font-weight:800;color:var(--color-text);line-height:1.3;margin-bottom:8px}.hero-banner p{font-size:1.0625rem;color:var(--color-text-secondary);line-height:1.5;max-width:550px;margin:0 auto}@media(max-width:767px){.hero-banner h1{font-size:1.35rem}.hero-banner p{font-size:.9375rem}}@media(max-width:480px){.hero-banner h1{font-size:1.2rem}.hero-banner p{font-size:.875rem}}.step-progress{display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2xl);padding:var(--space-lg);background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.step-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.step-circle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;background:#e5e7eb;color:#9ca3af;transition:all .3s ease}.step-item.active .step-circle{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2563eb4d}.step-item.completed .step-circle{background:var(--color-green);color:#fff}.step-label{font-size:.875rem;color:var(--color-text-muted);font-weight:600;white-space:nowrap}.step-item.active .step-label{color:var(--color-text)}.step-item.completed .step-label{color:var(--color-green);cursor:pointer}.step-item.completed .step-label:hover{text-decoration:underline}.step-line{width:100px;height:2px;background:var(--border-color);margin:0 var(--space-lg);margin-bottom:28px;border-radius:var(--radius-full)}.step-content{animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-card{background:var(--color-card);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.date-picker-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--space-md);margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--border-color)}.date-field{display:flex;flex-direction:column;gap:var(--space-xs)}.date-field label{font-size:.8125rem;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.date-field select{padding:12px 36px 12px 16px;border:2px solid #e5e7eb;border-radius:var(--radius-md);background:#fff;color:var(--color-text);font-size:1rem;font-weight:600;min-width:100px;cursor:pointer;transition:all .2s ease;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.date-field select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.today-btn{display:flex;align-items:center;gap:8px;padding:14px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.today-btn:hover{background:var(--color-primary-dark)}.location-pickers{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.location-row{display:flex;align-items:center;gap:var(--space-md)}.location-label{font-size:1rem;font-weight:700;color:var(--color-text);min-width:100px}.location-selector{position:relative;flex:1;max-width:450px}.location-button{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .2s ease}.location-button:hover{border-color:var(--color-primary)}.selected-city{display:flex;align-items:center;gap:var(--space-sm)}.city-flag{font-size:1.5rem}.placeholder{color:var(--color-text-muted)}.arrow{transition:transform .2s ease;color:var(--color-text-muted)}.arrow.open{transform:rotate(90deg)}.clear-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border:none;border-radius:50%;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s ease}.clear-btn:hover{background:#dc2626}.city-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:8px;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border-color);z-index:100;max-height:350px;display:flex;flex-direction:column;overflow:hidden}.city-search{padding:14px 18px;border:none;border-bottom:2px solid #FAFAFA;font-size:1rem;font-weight:500;background:#f8fafc;color:var(--color-text)}.city-search:focus{outline:none;background:#fff}.city-search::placeholder{color:var(--color-text-muted)}.city-list{flex:1;overflow-y:auto}.city-option{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:14px 18px;background:none;border:none;text-align:left;cursor:pointer;transition:all .15s ease}.city-option:hover{background:var(--color-card-dark)}.city-option .city-flag{font-size:1.25rem}.city-name{font-weight:700;color:var(--color-text)}.city-country{font-size:.8125rem;color:var(--color-text-muted);margin-left:auto}.add-more-btn{padding:12px 24px;background:#fff;border:1px dashed var(--color-primary);border-radius:var(--radius-md);color:var(--color-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.add-more-btn:hover{background:var(--color-primary-light)}.step-actions{display:flex;justify-content:center;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-color)}.btn-primary{display:flex;align-items:center;gap:8px;padding:14px 32px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-primary:disabled{background:#e5e7eb;box-shadow:none;cursor:not-allowed}.btn-secondary{display:flex;align-items:center;gap:8px;padding:14px 24px;background:#fff;color:var(--color-text);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.date-display-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-color)}.date-display-text{display:flex;align-items:center;gap:var(--space-sm);font-size:1.05rem;font-weight:600;color:var(--color-text);padding:8px 16px;background:var(--color-card-dark);border-radius:var(--radius-md)}.instruction-text{text-align:center;font-size:1rem;color:var(--color-text-secondary);margin-bottom:var(--space-lg);font-weight:500}.color-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-xl);padding:var(--space-md) var(--space-lg);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:8px;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary)}.legend-color{width:28px;height:20px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.legend-color.slot-best{background:var(--slot-best)}.legend-color.slot-partial{background:var(--slot-partial)}.legend-color.slot-off-hours{background:var(--slot-off-hours)}.legend-color.slot-night{background:var(--slot-night)}.timetable-container{overflow-x:auto;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.timetable{width:100%;border-collapse:separate;border-spacing:3px;font-size:.9375rem;background:#fff;padding:var(--space-sm)}.timetable th,.timetable td{padding:12px 10px;text-align:center}.timetable thead th{background:#fafafa;color:var(--color-text);font-weight:700;border-radius:var(--radius-md);padding:16px 10px;border-bottom:2px solid var(--border-color)}.th-flag{display:block;font-size:1.75rem;margin-bottom:6px}.th-city{display:block;font-size:.9375rem}.utc-col{min-width:110px}.time-row{cursor:pointer;transition:all .15s ease}.time-row:hover td{filter:brightness(.92);box-shadow:0 1px 4px #00000014}.time-row:hover .utc-cell{background:#e2e8f0;color:var(--color-primary);filter:none}.time-row:active td{filter:brightness(.88)}.time-row.selected-row td{box-shadow:inset 0 0 0 2.5px var(--color-primary);filter:brightness(.9)}.time-row.selected-row .utc-cell{background:var(--color-primary);color:#fff;filter:none}.utc-cell{font-family:var(--font-mono);font-weight:700;color:var(--color-text);background:#fafafa;border-radius:var(--radius-md);position:relative}.time-cell{font-family:var(--font-mono);font-weight:600;border-radius:var(--radius-md);transition:all .15s ease}.time-cell.slot-best{background:var(--slot-best);color:#fff}.time-cell.slot-partial{background:var(--slot-partial);color:#fff}.time-cell.slot-off-hours{background:var(--slot-off-hours);color:#fff}.time-cell.slot-night{background:var(--slot-night);color:#e2e8f0}.time-cell.slot-none{background:#f1f5f9;color:var(--color-text-muted)}.details-title{font-size:1.5rem;font-weight:800;color:var(--color-text);margin-bottom:var(--space-sm)}.details-subtitle{font-size:1rem;color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.details-table{width:100%;border-collapse:separate;border-spacing:0;margin-bottom:var(--space-xl);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.details-table th,.details-table td{padding:16px 20px;text-align:left}.details-table th{font-size:.75rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;background:#f8fafc}.details-table tbody tr{background:#fff;transition:all .2s ease}.details-table tbody tr:hover{background:var(--color-card-dark)}.details-table tbody tr:not(:last-child) td{border-bottom:1px solid #FAFAFA}.location-cell{display:flex;align-items:center;gap:var(--space-md)}.detail-flag{font-size:2rem}.detail-name{font-weight:600;color:var(--color-text);font-size:1rem}.detail-country{font-size:.875rem;color:var(--color-text-muted)}.time-detail-cell{font-size:1rem;font-weight:600;color:var(--color-text)}.tz-cell{color:var(--color-text-secondary);font-weight:500;font-size:.9375rem}.details-actions{display:flex;justify-content:space-between;gap:var(--space-md);padding-top:var(--space-xl);border-top:1px solid var(--border-color)}.footer{padding:var(--space-xl);text-align:center;color:var(--color-text-light);font-size:.9375rem;font-weight:500;background:var(--color-sidebar)}@media(min-width:1200px){.main{max-width:1100px}.step-line{width:120px}}@media(min-width:1024px)and (max-width:1199px){.main{max-width:960px}}@media(min-width:768px)and (max-width:1023px){html{font-size:14px}.main{max-width:720px;padding:var(--space-lg)}.step-line{width:60px;margin:0 var(--space-md)}.step-label{font-size:.8125rem}.location-selector{max-width:350px}.color-legend{gap:var(--space-md)}.legend-item{font-size:.75rem}.timetable{font-size:.875rem}.th-flag{font-size:1.5rem}.th-city{font-size:.8125rem}}@media(max-width:767px){html{font-size:14px}.header{padding:var(--space-sm) var(--space-md)}.logo-text{font-size:1.25rem}.logo-icon{width:28px;height:28px}.header-right{gap:var(--space-sm)}.language-button{padding:8px 12px;font-size:.8125rem}.language-button .lang-flag{font-size:1rem}.language-button .lang-name{display:none}.main{padding:var(--space-md)}.step-progress{padding:var(--space-md);gap:var(--space-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.step-progress::-webkit-scrollbar{display:none}.step-circle{width:36px;height:36px;font-size:.875rem;flex-shrink:0}.step-label{font-size:.6875rem;white-space:nowrap}.step-line{width:40px;margin:0 var(--space-xs);margin-bottom:24px;flex-shrink:0}.step-card{padding:var(--space-md);border-radius:var(--radius-lg)}.date-picker-row{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.date-field{width:100%}.date-field select{width:100%;padding:14px 16px}.today-btn{width:100%;justify-content:center}.location-row{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.location-label{min-width:auto;margin-bottom:0}.location-selector{max-width:100%}.location-button{padding:16px}.clear-btn{width:36px;height:36px;align-self:flex-end;margin-top:-48px;margin-right:8px;position:relative;z-index:1}.add-more-btn{width:100%;padding:14px 20px}.step-actions{flex-direction:column;gap:var(--space-sm)}.btn-primary,.btn-secondary{width:100%;justify-content:center;padding:16px 24px}.date-display-bar{flex-direction:column-reverse;gap:var(--space-sm);align-items:stretch}.date-display-bar .btn-secondary{justify-content:center}.date-display-text{justify-content:center;font-size:.95rem}.color-legend{flex-direction:column;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md)}.legend-item{width:100%;font-size:.75rem}.timetable-container{margin:0 calc(-1 * var(--space-md));border-radius:0;width:calc(100% + var(--space-md) * 2)}.timetable{font-size:.75rem;border-spacing:2px;padding:var(--space-xs)}.timetable th,.timetable td{padding:8px 4px}.th-flag{font-size:1.25rem;margin-bottom:4px}.th-city{font-size:.6875rem}.utc-col{min-width:70px}.details-title{font-size:1.25rem}.details-subtitle{font-size:.875rem}.details-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.details-table th,.details-table td{padding:12px 10px;white-space:nowrap}.detail-flag{font-size:1.5rem}.detail-name{font-size:.9375rem}.time-detail-cell{font-size:.875rem}.details-actions{flex-direction:column;gap:var(--space-sm)}.calendar-menu{position:fixed;bottom:0;left:0;right:0;margin:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:60vh;overflow-y:auto}.calendar-menu button{padding:18px 20px}}@media(max-width:480px){html{font-size:13px}.header{padding:var(--space-xs) var(--space-sm)}.logo-text{font-size:1.125rem}.logo-icon{width:24px;height:24px}.step-progress{padding:var(--space-sm)}.step-circle{width:32px;height:32px;font-size:.8125rem}.step-label{font-size:.625rem}.step-line{width:30px;margin-bottom:20px}.step-card{padding:var(--space-sm)}.location-button{padding:14px 12px;font-size:.9375rem}.city-flag{font-size:1.25rem}.timetable{font-size:.6875rem}.timetable th,.timetable td{padding:6px 3px}.th-flag{font-size:1rem}.th-city{font-size:.5625rem}.utc-col{min-width:55px}.time-cell{min-width:40px}.details-table thead{display:none}.details-table tbody tr{display:flex;flex-direction:column;padding:var(--space-md);margin-bottom:var(--space-sm);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.details-table td{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid #FAFAFA!important;white-space:normal}.details-table td:last-child{border-bottom:none!important}.details-table td:before{content:attr(data-label);font-weight:600;color:var(--color-text-muted);font-size:.75rem;text-transform:uppercase}.location-cell{flex-direction:row}}.city-list::-webkit-scrollbar,.timetable-container::-webkit-scrollbar{width:8px;height:8px}.city-list::-webkit-scrollbar-track,.timetable-container::-webkit-scrollbar-track{background:#fafafa;border-radius:4px}.city-list::-webkit-scrollbar-thumb,.timetable-container::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:4px}.calendar-dropdown,.calendar-btn{position:relative}.dropdown-arrow{transition:transform .2s ease;margin-left:4px}.dropdown-arrow.open{transform:rotate(180deg)}.calendar-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;min-width:220px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:100;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.calendar-menu button{display:flex;align-items:center;gap:12px;width:100%;padding:14px 18px;background:none;border:none;font-size:.9375rem;font-weight:600;color:var(--color-text);cursor:pointer;transition:all .15s ease;text-align:left}.calendar-menu button:hover{background:var(--color-card-dark)}.cal-icon{font-size:1.25rem}.copy-icon{color:var(--color-primary)}.copy-icon.success{color:var(--color-green)}.menu-divider{height:1px;background:#e5e7eb;margin:4px 0}.site-footer{background:var(--color-sidebar);border-top:1px solid var(--border-color);padding:48px 24px 24px;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto}.footer-main{display:flex;justify-content:space-between;gap:48px;margin-bottom:32px}.footer-brand{max-width:300px}.footer-logo{font-size:1.5rem;font-weight:700;color:#fff}.footer-tagline{color:#9ca3af;margin-top:8px;font-size:.9rem}.footer-links{display:flex;gap:64px}.footer-column h4{color:#fff;font-size:.9rem;font-weight:600;margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em}.footer-column a{display:flex;align-items:center;gap:6px;color:#9ca3af;text-decoration:none;font-size:.9rem;margin-bottom:10px;transition:color .2s}.footer-column a:hover{color:#fff}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;gap:16px}.footer-copyright{color:#6b7280;font-size:.85rem}.footer-social{display:flex;gap:16px}.footer-social a{color:#9ca3af;transition:color .2s}.footer-social a:hover{color:#fff}.footer-made{display:flex;align-items:center;gap:4px;color:#6b7280;font-size:.85rem}.footer-made .heart-icon{color:#ef4444;animation:heartbeat 1.5s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:767px){.site-footer{padding:32px 16px 20px}.footer-main{flex-direction:column;gap:24px}.footer-brand{max-width:100%;text-align:center}.footer-links{flex-wrap:wrap;gap:24px;justify-content:center}.footer-column{min-width:120px}.footer-column h4,.footer-column a{font-size:.8125rem}.footer-bottom{flex-direction:column;text-align:center;gap:12px}.footer-copyright,.footer-made{font-size:.75rem}}.cookie-consent{position:fixed;bottom:0;left:0;right:0;background:var(--color-sidebar);border-top:1px solid var(--border-color);padding:20px 24px;z-index:1000;animation:slideUp .3s ease-out;overflow:visible}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:20px;position:relative}.cookie-icon{color:var(--color-primary);flex-shrink:0}.cookie-text{flex:1}.cookie-text h4{color:#fff;font-size:1rem;margin-bottom:4px}.cookie-text p{color:#9ca3af;font-size:.875rem;line-height:1.5}.cookie-text a{color:var(--color-primary);text-decoration:underline}.cookie-actions{display:flex;gap:12px;flex-shrink:0}.btn-cookie-essential{padding:10px 20px;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cookie-essential:hover{background:#ffffff1a}.btn-cookie-accept{padding:10px 20px;background:var(--color-primary);border:none;color:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cookie-accept:hover{background:var(--color-primary-dark)}.cookie-close{position:absolute;top:-14px;right:-20px;background:#ffffff1a;border:none;color:#9ca3af;cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1}.cookie-close:hover{color:#fff}@media(max-width:767px){.cookie-consent{padding:16px}.cookie-content{flex-direction:column;text-align:center;gap:16px}.cookie-icon{display:none}.cookie-text h4{font-size:.9375rem}.cookie-text p{font-size:.8125rem}.cookie-actions{width:100%;flex-direction:column;gap:8px}.btn-cookie-essential,.btn-cookie-accept{width:100%;padding:14px 20px}.cookie-close{top:-14px;right:-6px}}@media(hover:none)and (pointer:coarse){.btn-primary,.btn-secondary,.today-btn,.location-button,.language-button,.city-option,.calendar-menu button{min-height:48px}.time-row:hover,.feature-card:hover{transform:none}.btn-primary:active,.btn-secondary:active{transform:scale(.98)}.time-row:active{opacity:.9}}.info-section{background:var(--color-card);border-top:1px solid var(--border-color);padding:80px 24px}.info-container{max-width:1000px;margin:0 auto}.info-hero{text-align:center;margin-bottom:64px}.info-hero h2{font-size:2.25rem;font-weight:800;color:var(--color-text);margin-bottom:16px;line-height:1.2}.info-hero p{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.7;max-width:700px;margin:0 auto}.info-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:72px}.info-feature{background:var(--color-bg);border-radius:var(--radius-lg);padding:28px;border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.info-feature:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.info-feature svg{color:var(--color-primary);margin-bottom:16px}.info-feature h3{font-size:1.0625rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.info-feature p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.info-how-it-works{margin-bottom:72px}.info-how-it-works h2{font-size:1.75rem;font-weight:800;color:var(--color-text);text-align:center;margin-bottom:40px}.info-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.info-step{text-align:center;padding:24px}.info-step-number{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:1.25rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.info-step h3{font-size:1.0625rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.info-step p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.info-use-cases{margin-bottom:72px}.info-use-cases h2{font-size:1.75rem;font-weight:800;color:var(--color-text);text-align:center;margin-bottom:40px}.info-use-case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.info-use-case{background:var(--color-bg);border-radius:var(--radius-lg);padding:28px;border:1px solid var(--border-color)}.info-use-case h3{font-size:1.0625rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.info-use-case p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.info-faq{margin-bottom:72px}.info-faq h2{font-size:1.75rem;font-weight:800;color:var(--color-text);text-align:center;margin-bottom:40px}.info-faq-item{background:var(--color-bg);border-radius:var(--radius-lg);padding:24px 28px;margin-bottom:16px;border:1px solid var(--border-color)}.info-faq-item h3{font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.info-faq-item p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.info-cta{text-align:center;background:var(--color-bg);border-radius:var(--radius-xl);padding:48px 32px;border:1px solid var(--border-color)}.info-cta p{font-size:1.0625rem;color:var(--color-text-secondary);margin-bottom:24px}.info-cta-links{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.info-cta-links .btn-primary,.info-cta-links .btn-secondary{text-decoration:none;display:inline-flex;align-items:center;gap:8px}@media(max-width:767px){.info-section{padding:48px 16px}.info-hero h2{font-size:1.5rem}.info-hero p{font-size:1rem}.info-features-grid{grid-template-columns:1fr;gap:16px;margin-bottom:48px}.info-steps{grid-template-columns:1fr;gap:24px}.info-how-it-works{margin-bottom:48px}.info-use-case-grid{grid-template-columns:1fr;gap:16px}.info-use-cases,.info-faq{margin-bottom:48px}.info-cta{padding:32px 20px}.info-cta-links{flex-direction:column;align-items:center}}.guide-page{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.guide-container{max-width:800px;margin:0 auto;padding:40px 24px 64px;flex:1}.guide-hero{text-align:center;margin-bottom:48px}.guide-hero-icon{color:var(--color-primary);margin-bottom:16px}.guide-hero h1{font-size:2.5rem;font-weight:800;color:var(--color-text);margin-bottom:16px;line-height:1.2}.guide-hero-subtitle{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.7;max-width:600px;margin:0 auto}.guide-toc{background:var(--color-card);border-radius:var(--radius-lg);padding:28px 32px;margin-bottom:48px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.guide-toc h2{font-size:1.125rem;font-weight:700;color:var(--color-text);margin-bottom:16px}.guide-toc ol{padding-left:20px}.guide-toc li{margin-bottom:8px}.guide-toc a{color:var(--color-primary);text-decoration:none;font-weight:500;font-size:.9375rem}.guide-toc a:hover{text-decoration:underline}.guide-content{margin-bottom:48px}.guide-section{background:var(--color-card);border-radius:var(--radius-lg);padding:36px 32px;margin-bottom:24px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.guide-section-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:var(--color-primary-light);color:var(--color-primary);margin-bottom:16px}.guide-section h2{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:20px}.guide-section h3{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-top:24px;margin-bottom:12px}.guide-section p{font-size:1rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:16px}.guide-section ul,.guide-section ol{padding-left:24px;margin-bottom:16px}.guide-section li{font-size:1rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:10px}.guide-section li strong{color:var(--color-text)}.guide-tip{display:flex;gap:12px;align-items:flex-start;background:#fef3c7;border:1px solid #fbbf24;border-radius:var(--radius-md);padding:16px 20px;margin-top:20px}.guide-tip svg{color:#d97706;flex-shrink:0;margin-top:2px}.guide-tip p{margin:0;font-size:.9375rem;color:#92400e}.guide-numbered-list{display:flex;flex-direction:column;gap:24px}.guide-numbered-item{display:flex;gap:16px;align-items:flex-start}.guide-number{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:.9375rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:2px}.guide-numbered-item h3{margin-top:0;margin-bottom:6px}.guide-numbered-item p{margin-bottom:0}.guide-pitfall{background:var(--color-bg);border-radius:var(--radius-md);padding:20px 24px;margin-bottom:16px;border-left:4px solid #f59e0b}.guide-pitfall h3{margin-top:0;margin-bottom:8px}.guide-pitfall p{margin-bottom:0}.guide-cta{text-align:center;background:var(--color-card);border-radius:var(--radius-xl);padding:48px 32px;border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.guide-cta h2{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.guide-cta p{font-size:1.0625rem;color:var(--color-text-secondary);margin-bottom:24px}.guide-cta .btn-primary{display:inline-flex;text-decoration:none}@media(max-width:767px){.guide-container{padding:24px 16px 48px}.guide-hero h1{font-size:1.75rem}.guide-hero-subtitle{font-size:1rem}.guide-section{padding:24px 20px}.guide-section h2{font-size:1.25rem}.guide-numbered-item{flex-direction:column;gap:8px}.guide-cta{padding:32px 20px}}.ad-banner{width:100%;text-align:center;margin:24px 0}.ad-placeholder{background:var(--color-card-dark);border:1px dashed var(--border-color);border-radius:8px;padding:24px;min-height:90px;display:flex;align-items:center;justify-content:center}.ad-placeholder-content{display:flex;flex-direction:column;align-items:center;gap:4px;color:#9ca3af}.ad-placeholder-content span{font-size:1.25rem}.ad-placeholder-content small{font-size:.75rem;opacity:.7}.ad-bottom{max-width:728px;margin:32px auto}.legal-page{min-height:100vh;background:var(--color-bg);padding:40px 24px}.legal-container{max-width:800px;margin:0 auto;background:var(--color-card);border-radius:16px;padding:48px;box-shadow:var(--shadow-lg)}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--color-primary);text-decoration:none;font-weight:500;margin-bottom:32px;transition:color .2s}.back-link:hover{color:var(--color-primary-dark)}.legal-container h1{font-size:2.5rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.last-updated{color:var(--color-text-muted);font-size:.9rem;margin-bottom:40px}.legal-container section{margin-bottom:32px}.legal-container h2{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:16px;margin-top:32px}.legal-container h3{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:12px;margin-top:24px}.legal-container p{color:var(--color-text-secondary);line-height:1.7;margin-bottom:16px}.legal-container ul{color:var(--color-text-secondary);margin-left:24px;margin-bottom:16px}.legal-container li{margin-bottom:8px;line-height:1.6}.contact-email{font-size:1.125rem;color:var(--color-primary);font-weight:600}.about-page{min-height:100vh;background:var(--color-bg);padding:40px 24px}.about-container{max-width:900px;margin:0 auto}.about-hero{text-align:center;margin-bottom:48px}.about-hero h1{font-size:3rem;font-weight:700;color:var(--color-text);margin-bottom:16px}.about-hero .tagline{font-size:1.25rem;color:var(--color-text-secondary)}.about-section{background:var(--color-card);border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:var(--shadow-md)}.about-section h2{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:16px}.about-section p{color:var(--color-text-secondary);line-height:1.7;margin-bottom:16px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:24px}.feature-card{background:var(--color-card);border-radius:12px;padding:24px;text-align:center;box-shadow:var(--shadow-md);transition:transform .2s}.feature-card:hover{transform:translateY(-4px)}.feature-icon{color:var(--color-primary);margin-bottom:12px}.feature-card h3{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.feature-card p{font-size:.9rem;color:var(--color-text-secondary);line-height:1.5}.how-it-works{color:var(--color-text-secondary);padding-left:24px}.how-it-works li{margin-bottom:12px;line-height:1.6}.faq-item{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1)}.faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.faq-item h3{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.faq-item p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:0}.faq-item a{color:var(--color-primary)}.contact-section{text-align:center;background:var(--color-card);border-radius:16px;padding:32px;box-shadow:var(--shadow-md)}.contact-section h2{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:12px}.contact-section p{color:var(--color-text-secondary);margin-bottom:8px}.contact-section .contact-email a{font-size:1.25rem;color:var(--color-primary);font-weight:600;text-decoration:none}.contact-section .contact-email a:hover{text-decoration:underline}.not-found-page{min-height:100vh;background:var(--color-bg);display:flex;align-items:center;justify-content:center;padding:40px 24px}.not-found-container{text-align:center;max-width:500px}.error-code{font-size:8rem;font-weight:800;color:var(--color-primary);line-height:1;margin-bottom:16px}.not-found-container h1{font-size:2rem;font-weight:700;color:var(--color-text);margin-bottom:12px}.not-found-container p{color:var(--color-text-secondary);font-size:1.125rem;margin-bottom:24px}.not-found-illustration{display:flex;justify-content:center;gap:24px;font-size:3rem;margin:32px 0}.not-found-illustration .emoji.floating{animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.suggestion{color:var(--color-text-muted);font-size:.95rem}.not-found-actions{display:flex;justify-content:center;gap:16px;margin-top:32px;flex-wrap:wrap}.not-found-actions .btn-primary,.not-found-actions .btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:12px;font-weight:600;text-decoration:none;transition:all .2s}.not-found-actions .btn-primary{background:var(--color-primary);color:#fff;border:none}.not-found-actions .btn-secondary{background:transparent;color:var(--color-text);border:2px solid rgba(255,255,255,.2);cursor:pointer}.not-found-actions .btn-primary:hover{background:var(--color-primary-dark)}.not-found-actions .btn-secondary:hover{background:#ffffff1a}.blog-page,.blogpost-page{min-height:100vh;background:var(--color-bg)}.blog-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:100}.blog-nav-logo{font-size:1.2rem;font-weight:800;color:var(--color-text);text-decoration:none}.blog-nav-back{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--color-primary);text-decoration:none;transition:opacity .2s}.blog-nav-back:hover{opacity:.7}.blog-header{background:linear-gradient(135deg,#1e293b,#334155);padding:64px 32px;text-align:center;color:#fff}.blog-header-inner{max-width:680px;margin:0 auto}.blog-header-inner svg{opacity:.7;margin-bottom:16px}.blog-header h1{font-size:2.2rem;font-weight:800;margin-bottom:12px;letter-spacing:-.02em}.blog-header p{font-size:1.05rem;line-height:1.7;opacity:.85}.blog-content{max-width:960px;margin:0 auto;padding:40px 24px 60px}.blog-featured{display:block;background:#fff;border-radius:12px;padding:40px;text-decoration:none;color:inherit;border:1px solid #e2e8f0;transition:box-shadow .3s,transform .2s;margin-bottom:40px}.blog-featured:hover{box-shadow:0 8px 30px #00000014;transform:translateY(-2px)}.blog-featured-badge{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);font-size:.75rem;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px}.blog-featured-title{font-size:1.6rem;font-weight:800;line-height:1.3;color:var(--color-text);margin-bottom:12px}.blog-featured-excerpt{font-size:1rem;line-height:1.7;color:var(--color-text-secondary);margin-bottom:16px}.blog-featured-meta{display:flex;gap:16px;font-size:.82rem;color:var(--color-text-muted);margin-bottom:16px}.blog-featured-meta span{display:flex;align-items:center;gap:5px}.blog-featured-cta{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;font-weight:700;color:var(--color-primary)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:48px}.blog-card{background:#fff;border-radius:10px;padding:28px;text-decoration:none;color:inherit;border:1px solid #e2e8f0;transition:box-shadow .3s,transform .2s;display:flex;flex-direction:column}.blog-card:hover{box-shadow:0 6px 24px #00000012;transform:translateY(-2px)}.blog-card-category{display:inline-block;font-size:.7rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.blog-card-title{font-size:1.1rem;font-weight:700;line-height:1.35;color:var(--color-text);margin-bottom:8px}.blog-card-excerpt{font-size:.88rem;line-height:1.6;color:var(--color-text-secondary);margin-bottom:14px;flex:1}.blog-card-meta{display:flex;gap:12px;font-size:.78rem;color:var(--color-text-muted);margin-bottom:12px}.blog-card-meta span{display:flex;align-items:center;gap:4px}.blog-card-cta{display:inline-flex;align-items:center;gap:4px;font-size:.82rem;font-weight:700;color:var(--color-primary)}.blog-bottom-cta{text-align:center;padding:48px 32px;background:linear-gradient(135deg,#1e293b,#334155);border-radius:12px;color:#fff}.blog-bottom-cta h2{font-size:1.5rem;font-weight:800;margin-bottom:10px}.blog-bottom-cta p{font-size:.95rem;opacity:.85;margin-bottom:20px;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.6}.blog-bottom-cta-btn{display:inline-block;background:#fff;color:#1e293b;font-size:.9rem;font-weight:700;padding:12px 28px;border-radius:8px;text-decoration:none;transition:opacity .2s}.blog-bottom-cta-btn:hover{opacity:.9}.blogpost-article{max-width:740px;margin:0 auto;padding:40px 24px 60px}.blogpost-header{margin-bottom:36px}.blogpost-category{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);font-size:.75rem;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px}.blogpost-title{font-size:2rem;font-weight:800;line-height:1.25;color:var(--color-text);margin-bottom:14px;letter-spacing:-.02em}.blogpost-excerpt{font-size:1.1rem;line-height:1.7;color:var(--color-text-secondary);margin-bottom:20px}.blogpost-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:.82rem;color:var(--color-text-muted);padding-bottom:24px;border-bottom:1px solid #e2e8f0}.blogpost-meta span{display:flex;align-items:center;gap:5px}.blogpost-toc{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:24px 28px;margin-bottom:36px}.blogpost-toc h2{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:12px}.blogpost-toc ol{list-style:decimal;padding-left:20px}.blogpost-toc li{margin-bottom:6px}.blogpost-toc a{font-size:.9rem;color:var(--color-primary);text-decoration:none;line-height:1.5}.blogpost-toc a:hover{text-decoration:underline}.blogpost-body{line-height:1.8}.blogpost-section{margin-bottom:36px}.blogpost-section h2{font-size:1.35rem;font-weight:700;color:var(--color-text);margin-bottom:16px;line-height:1.3}.blogpost-section p{font-size:1rem;color:#374151;margin-bottom:14px;line-height:1.8}.blogpost-nav-links{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:48px;padding-top:32px;border-top:1px solid #e2e8f0}.blogpost-nav-prev,.blogpost-nav-next{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;text-decoration:none;color:inherit;transition:box-shadow .2s}.blogpost-nav-prev:hover,.blogpost-nav-next:hover{box-shadow:0 4px 12px #0000000f}.blogpost-nav-prev span,.blogpost-nav-next span{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.blogpost-nav-prev strong,.blogpost-nav-next strong{display:block;font-size:.88rem;font-weight:600;color:var(--color-text);line-height:1.3;margin-top:2px}.blogpost-nav-next{text-align:right;justify-content:flex-end}.blogpost-cta{text-align:center;margin-top:48px;padding:40px 28px;background:linear-gradient(135deg,#1e293b,#334155);border-radius:12px;color:#fff}.blogpost-cta h3{font-size:1.3rem;font-weight:800;margin-bottom:8px}.blogpost-cta p{font-size:.92rem;opacity:.85;margin-bottom:20px;line-height:1.6}.blogpost-cta-btn{display:inline-block;background:#fff;color:#1e293b;font-size:.88rem;font-weight:700;padding:11px 26px;border-radius:8px;text-decoration:none;transition:opacity .2s}.blogpost-cta-btn:hover{opacity:.9}@media(max-width:768px){.blog-header{padding:40px 20px}.blog-header h1{font-size:1.6rem}.blog-featured{padding:24px}.blog-featured-title{font-size:1.3rem}.blog-grid{grid-template-columns:1fr}.blogpost-title{font-size:1.5rem}.blogpost-nav-links{grid-template-columns:1fr}.blog-nav{padding:12px 16px}.blogpost-article{padding:24px 16px 40px}}.slot:hover{opacity:.85}.city-slot:hover{filter:brightness(1.1)}@keyframes slideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.hero{animation:slideIn .5s ease-out}.city-selectors{animation:slideIn .5s ease-out .1s both}.date-display{animation:slideIn .5s ease-out .15s both}.visualization{animation:slideIn .5s ease-out .2s both}.results{animation:slideIn .5s ease-out .25s both}.legend{animation:slideIn .5s ease-out .3s both}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.current-time-indicator,.city-current-indicator{animation:pulse 2s ease-in-out infinite}button:focus-visible,select:focus-visible,input:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}::selection{background:#0ea5e933;color:var(--color-text)}@keyframes dropIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.city-dropdown,.hours-dropdown{animation:dropIn .2s ease-out}@media print{.header,.footer,.add-city-button,.remove-city,.hours-button{display:none!important}.app{background:#fff!important}.background-pattern{display:none}.timeline-container,.best-time-card,.legend{box-shadow:none!important;border:1px solid #ccc!important}}
