@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Source+Sans+3:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh}#root{min-height:100vh}:root{--color-bg-primary: #0f0f1a;--color-bg-secondary: #1a1a2e;--color-bg-tertiary: #252540;--color-text-primary: #f0f0f5;--color-text-secondary: #a0a0b0;--color-text-muted: #606075;--color-accent: #ffd93d;--color-accent-dim: #c9a227;--color-border: #3a3a55;--font-display: "Playfair Display", Georgia, serif;--font-body: "Source Sans 3", system-ui, -apple-system, sans-serif;--sidebar-width: 250px;--sidebar-right-width: 200px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh;line-height:1.6}.app{min-height:100vh;display:flex;background:radial-gradient(ellipse at top,#1a1a3a 0%,transparent 50%),radial-gradient(ellipse at bottom,#0a0a15 0%,transparent 50%),var(--color-bg-primary)}.app-sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:10;display:flex;flex-direction:column}.app-sidebar-right{position:fixed;right:0;top:0;bottom:0;width:var(--sidebar-right-width);z-index:10;display:flex;flex-direction:column;justify-content:center}.info-panel{display:flex;flex-direction:column;overflow:hidden}.info-panel-content{display:flex;flex-direction:column;padding:1rem 1.5rem;gap:1rem;overflow-y:auto}.info-panel-date{font-size:1.1rem;font-weight:600;color:#ff6b6b;margin-bottom:.5rem}.info-panel-row{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--color-text-primary);padding:.25rem 0}.info-panel-row span:first-child{font-size:1.25rem}.app-content{flex:1;margin-left:var(--sidebar-width);margin-right:var(--sidebar-right-width);display:flex;flex-direction:column;height:100vh;overflow:hidden}.controls-mobile{display:none}.app-header{text-align:center;padding:1.5rem 1rem 1rem;flex-shrink:0}.app-header h1{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-accent);text-shadow:0 0 40px rgba(255,217,61,.3);letter-spacing:.02em;margin-bottom:.5rem}.app-header .subtitle{font-size:1rem;color:var(--color-text-secondary);font-weight:300}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 2rem 1rem;overflow:hidden;min-height:0}@media(max-width:768px){.app-main{padding:0 1rem 1rem}}.location-picker--desktop{display:flex;flex-direction:column;height:100%;overflow:hidden}.location-panel-header{padding:1.5rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.location-panel-header h2{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent);margin-bottom:.5rem}.location-panel-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.location-picker--desktop .location-search-wrapper{padding:1rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.location-picker--desktop .location-options{flex:1;overflow-y:auto;padding:0}.location-picker--desktop .custom-latitude{padding:1rem;border-top:1px solid var(--color-border);flex-shrink:0}.location-picker--mobile{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:400px}.location-nav-row{display:flex;align-items:center;gap:.5rem;width:100%}.location-nav-row .location-dropdown-trigger{flex:1;min-width:0}.location-dropdown-trigger{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:var(--font-body);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);cursor:pointer;transition:border-color .2s,box-shadow .2s;display:flex;justify-content:space-between;align-items:center;text-align:left}.location-dropdown-trigger:hover,.location-dropdown-trigger:focus{border-color:var(--color-accent-dim);outline:none;box-shadow:0 0 0 3px #ffd93d1a}.trigger-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trigger-arrow{margin-left:.5rem;font-size:.7rem;color:var(--color-text-secondary)}.location-modal-overlay{position:fixed;inset:0;background:#000c;z-index:1000;display:flex;align-items:stretch;justify-content:stretch;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.location-modal{width:100%;height:100%;background:var(--color-bg-primary);display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.location-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0}.location-modal-header h2{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent);margin:0}.location-modal-close{background:transparent;border:none;color:var(--color-text-secondary);font-size:1.25rem;cursor:pointer;padding:.5rem;line-height:1;transition:color .2s}.location-modal-close:hover{color:var(--color-text-primary)}.location-modal .location-search-wrapper{padding:1rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0}.location-modal .location-options{flex:1;overflow-y:auto;padding:0;-webkit-overflow-scrolling:touch}.location-search{width:100%;padding:.6rem .75rem;font-size:.95rem;font-family:var(--font-body);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s}.location-search::placeholder{color:var(--color-text-muted)}.location-search:focus{border-color:var(--color-accent-dim);outline:none;box-shadow:0 0 0 2px #ffd93d1a}.continent-group{margin-bottom:.5rem}.continent-header{padding:.5rem 1rem .25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent-dim);background:var(--color-bg-primary);position:sticky;top:0;z-index:1}.country-group{margin-bottom:.25rem}.country-header{padding:.4rem 1rem .25rem 1.25rem;font-size:.8rem;font-weight:600;color:var(--color-text-secondary)}.city-option{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem .5rem 2rem;font-size:.9rem;font-family:var(--font-body);background:transparent;border:none;color:var(--color-text-primary);cursor:pointer;text-align:left;transition:background-color .15s}.city-option:hover{background:var(--color-bg-tertiary)}.city-option.selected{background:#ffd93d1a;color:var(--color-accent)}.city-option.selected:hover{background:#ffd93d26}.city-name{flex:1}.city-latitude{font-size:.8rem;color:var(--color-text-muted);margin-left:.5rem}.custom-option-wrapper{border-top:1px solid var(--color-border);margin-top:.5rem;padding-top:.5rem}.custom-option{padding-left:1rem;font-style:italic;color:var(--color-text-secondary)}.custom-option:hover{color:var(--color-text-primary)}.no-results{padding:1.5rem 1rem;text-align:center;color:var(--color-text-muted);font-size:.9rem}.custom-latitude{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.custom-latitude label{font-size:.8rem;color:var(--color-text-secondary)}.custom-latitude input{padding:.75rem 1rem;font-size:1rem;font-family:var(--font-body);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s}.custom-latitude input:focus{border-color:var(--color-accent-dim);outline:none;box-shadow:0 0 0 3px #ffd93d1a}.clock-container{display:flex;justify-content:center;align-items:center;width:100%;flex:1;min-height:0;overflow:hidden}.sun-clock{filter:drop-shadow(0 0 30px rgba(255,217,61,.2));transition:filter .3s;max-width:100%;max-height:100%;height:auto;width:auto}.sun-segments path{transition:opacity .15s}.sun-segments path:hover{opacity:.85;cursor:pointer}.center-info{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:#0f0f1aeb;border:1px solid var(--color-border);border-radius:12px;padding:1rem 1.5rem;min-width:180px}.center-info-date{font-size:1rem;font-weight:600;color:#ff6b6b;margin-bottom:.25rem}.center-info-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--color-text-primary)}.center-info-row span:first-child{font-size:1rem}.explanation{max-width:500px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem 2rem}.explanation h2{font-family:var(--font-display);font-size:1.25rem;color:var(--color-text-primary);margin-bottom:1rem}.explanation ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}.explanation li{color:var(--color-text-secondary);font-size:.95rem;padding-left:1.5rem;position:relative}.explanation li:before{content:"◆";position:absolute;left:0;color:var(--color-accent-dim);font-size:.7rem;top:.25rem}.explanation li strong{color:var(--color-text-primary);font-weight:600}.hover-tip{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border);font-size:.85rem;color:var(--color-text-muted);font-style:italic}.app-footer{text-align:center;padding:2rem;border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.app-footer p{font-size:.85rem;color:var(--color-text-muted);max-width:600px;margin:0 auto}.city-tabs-mobile{display:none}@media(max-width:999px){html,body{position:fixed;inset:0;overflow:hidden;overscroll-behavior:none;touch-action:manipulation}.app{height:100dvh;max-height:100dvh;height:100vh;max-height:100vh;overflow:hidden;overscroll-behavior:none}@supports (height: 100dvh){.app{height:100dvh}}.app-sidebar,.app-sidebar-right,.app-header{display:none}.app-content{margin-left:0;margin-right:0;height:100%;overflow:hidden}.controls-mobile{display:flex;flex-direction:column;align-items:center;width:100%;padding:.75rem 1rem 0;gap:.5rem}.controls-mobile-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--color-accent);text-align:center;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;width:100%}.city-tabs-mobile{display:flex;width:100%;padding:0 1rem;flex-shrink:0}.city-tabs-list{display:flex;gap:.35rem;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px;justify-content:center}.city-tabs-list::-webkit-scrollbar{display:none}.city-tab{flex-shrink:0;padding:.25rem .65rem;font-size:.75rem;font-family:var(--font-body);font-weight:500;background:transparent;border:1px solid var(--color-border);border-radius:14px;color:var(--color-text-muted);cursor:pointer;transition:background-color .15s,border-color .15s,color .15s,transform .1s;-webkit-tap-highlight-color:transparent;white-space:nowrap;display:flex;align-items:center;gap:.4rem}.city-tab:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-text-muted)}.city-tab:active{transform:scale(.96)}.city-tab--active{background:transparent;border-color:var(--color-accent-dim);color:var(--color-text-primary);font-weight:500}.city-tab--active:hover{background:transparent;border-color:var(--color-accent);color:var(--color-text-primary)}.city-tab-name{flex:1}.city-tab-remove{background:transparent;border:none;color:var(--color-text-muted);font-size:1.2rem;line-height:1;cursor:pointer;padding:0;margin:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:color .15s,transform .1s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.city-tab--active .city-tab-remove{color:var(--color-text-primary)}.city-tab-remove:hover{color:var(--color-text-primary);transform:scale(1.2)}.city-tab-remove:active{transform:scale(.9)}.app-main{padding:.5rem 1rem 1rem;flex:1;overflow:hidden;justify-content:flex-start;gap:10px}.clock-container{padding:0;max-width:none;flex:0 0 auto}.explanation{padding:1.25rem 1.5rem}.center-info{position:fixed;bottom:0;left:0;right:0;width:100%;border-radius:12px 12px 0 0;z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto;gap:.25rem;padding:.75rem 1rem;min-width:auto}.center-info-date{font-size:.85rem;margin-bottom:.15rem}.center-info-row{gap:.35rem;font-size:.8rem}.center-info-row span:first-child{font-size:.85rem}}@media(min-width:1000px){.controls-mobile,.city-tabs-mobile,.center-info{display:none}}.info-fab{position:fixed;bottom:1.5rem;right:1.5rem;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-dim) 100%);border:none;cursor:pointer;box-shadow:0 4px 20px #ffd93d66,0 2px 8px #0000004d;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease;z-index:100}.info-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #ffd93d80,0 4px 12px #0006}.info-fab:active{transform:scale(.96)}.info-fab-icon{width:28px;height:28px;color:var(--color-bg-primary)}.info-modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease-out}.info-modal{position:relative;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:16px;box-shadow:0 20px 60px #00000080;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.info-modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s,color .15s,border-color .15s}.info-modal-close:hover{background:var(--color-bg-primary);color:var(--color-text-primary);border-color:var(--color-accent-dim)}.info-modal-content{padding:2rem 2rem 1.5rem}.info-modal-content h2{font-family:var(--font-display);font-size:1.5rem;color:var(--color-accent);margin-bottom:1.25rem;padding-right:2rem}.info-modal-content ul{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.info-modal-content li{color:var(--color-text-secondary);font-size:.95rem;padding-left:1.5rem;position:relative;line-height:1.6}.info-modal-content li:before{content:"◆";position:absolute;left:0;color:var(--color-accent-dim);font-size:.7rem;top:.3rem}.info-modal-content li strong{color:var(--color-text-primary);font-weight:600}.info-modal-content .hover-tip{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--color-border);font-size:.85rem;color:var(--color-text-muted);font-style:italic}.info-modal-footer{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.info-modal-footer p{font-size:.85rem;color:var(--color-text-muted);line-height:1.6}@media(max-width:599px){.info-fab{bottom:1rem;right:1rem;width:50px;height:50px}.info-fab-icon{width:24px;height:24px}.info-modal-content{padding:1.5rem}.info-modal-content h2{font-size:1.25rem}}
