:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#000}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app-container{background:#000;min-height:100vh;padding:0;margin:0}.app-header{text-align:center;padding:1.5rem 0 1rem;background:#000;color:#fff;border-bottom:1px solid #1a1a1a;position:relative}.search-reopen-btn{position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;padding:.75rem 1.25rem;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #22c55e4d}.search-reopen-btn:hover{background:linear-gradient(135deg,#4ade80,#22c55e);transform:translateY(-50%) scale(1.05);box-shadow:0 4px 12px #22c55e66}.search-reopen-btn:active{transform:translateY(-50%) scale(.98)}.app-header h1{margin:0;font-weight:600;font-size:1.75rem;letter-spacing:.02em;color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.app-header p{margin:.5rem 0 0;font-weight:400;font-size:.95rem;color:#8b9dc3;letter-spacing:.01em}.app-main{position:relative;min-height:70vh;padding:0 0 2rem;display:flex;justify-content:center;align-items:flex-start}.city-list-container{position:fixed;right:1rem;top:10rem;width:250px;max-height:600px;overflow-y:auto;background:#111;border-radius:8px;padding:1rem;z-index:10}.city-list{display:flex;flex-direction:column;gap:.5rem}.city-button{background:#222;color:#fff;border:1px solid #444;border-radius:4px;padding:.75rem 1rem;cursor:pointer;text-align:left;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.city-button:hover{background:#333}.city-button.active{background:#444;border-color:#666}.map-container{width:1200px;height:600px;box-shadow:0 8px 32px #0006;border-radius:12px;background:transparent;padding:8px;display:flex;align-items:center;justify-content:center;border:1px solid #1a1a1a}@media(max-width:1024px){.app-main{flex-direction:column;align-items:center;padding:3rem 1rem}.map-container{width:90vw;max-width:900px;height:500px;margin-top:2rem;margin-bottom:3rem;order:1}.city-list-container{position:relative;right:auto;top:auto;width:90vw;max-width:400px;max-height:400px;margin:2rem auto;order:2}.app-header h1{font-size:2rem}.app-header p{font-size:1rem}}@media(max-width:768px){.app-main{padding:1rem .5rem}.map-container{width:95vw;height:400px}.city-list-container{width:95vw;max-width:400px;max-height:300px}.app-header{padding:1.5rem 1rem .75rem}.app-header h1{font-size:1.75rem}.app-header p{font-size:1rem}.city-button{padding:.5rem .75rem;font-size:.9rem}}@media(max-width:480px){.map-container{height:300px}.app-header h1{font-size:1.5rem}.app-header p{font-size:.9rem}}.course-buttons-inline{display:flex;gap:.5rem;margin-top:.5rem}.course-button-inline{padding:.35rem .85rem;background:#232a36;color:#58a6ff;border:1.5px solid #2a3542;border-radius:6px;font-size:.92rem;font-weight:500;cursor:pointer;transition:background .18s,color .18s,border .18s,transform .12s;min-width:0;min-height:0;box-shadow:0 1px 4px #283c5a14}.course-button-inline:hover{background:#2a3a4d;color:#fff;border-color:#58a6ff;transform:translateY(-1px) scale(1.04)}.modal-overlay{position:fixed;inset:0;background:#000000a6;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .25s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.course-action-button{padding:.6rem 1.2rem;background:#232a36;color:#58a6ff;border:1.5px solid #2a3542;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;flex:1}.course-action-button:hover{background:#2a3a4d;color:#fff;border-color:#58a6ff;transform:translateY(-1px) scale(1.04)}.course-action-button:active{transform:translateY(0)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content{background:#1a1a1ad9;backdrop-filter:blur(40px) saturate(150%);-webkit-backdrop-filter:blur(40px) saturate(150%);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:90%;max-width:800px;height:85vh;overflow:hidden;box-shadow:0 8px 32px #0009,0 2px 8px #0006,inset 0 1px #ffffff0d;display:flex;flex-direction:column;animation:slideUp .4s cubic-bezier(.34,1.56,.64,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.06);background:#ffffff05;position:relative;min-height:80px;box-shadow:0 1px #ffffff08}.modal-title-container{flex:1;display:flex;align-items:center;justify-content:center;gap:1.25rem;margin:0 8rem;max-width:calc(100% - 16rem)}.modal-title-container>div{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:100%;gap:.35rem}.modal-header h2{margin:0;color:#fff;font-size:1.5rem;word-wrap:break-word;overflow-wrap:break-word;line-height:1.2}.modal-subtitle{font-size:1rem;color:#ddd;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.3}.modal-location{font-size:.75rem;color:#999;font-weight:400;line-height:1.2}.modal-favorite-btn{position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);min-width:60px;height:32px;padding:0 12px;border-radius:8px;background:linear-gradient(135deg,#ffc10714,#ffc10705);border:1.5px solid rgba(255,193,7,.25);color:#ffc107;font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;box-shadow:0 2px 8px #0000001a}.modal-favorite-btn:disabled{cursor:not-allowed;opacity:.6}.modal-favorite-btn:hover:not(:disabled){background:linear-gradient(135deg,#ffc10733,#ffc1071a);border-color:#ffc107;color:#ffc107;transform:translateY(-50%) scale(1.1);transform-origin:center;box-shadow:0 4px 16px #ffc1074d}.modal-favorite-btn.favorited{background:linear-gradient(135deg,#22c55e40,#22c55e26);border-color:#22c55e;color:#22c55e;box-shadow:0 2px 12px #22c55e66}.modal-favorite-btn.favorited:hover:not(:disabled){transform:translateY(-50%) scale(1.1);transform-origin:center;background:linear-gradient(135deg,#22c55e59,#22c55e40)}.modal-back{background:#4a9eff1a;border:1px solid rgba(74,158,255,.3);color:#4a9eff;font-size:.95rem;font-weight:600;padding:.5rem 1rem;cursor:pointer;border-radius:6px;display:flex;align-items:center;gap:.5rem;transition:all .2s;position:absolute;left:1.5rem}.modal-back:hover{background:#4a9eff33;border-color:#4a9eff;transform:translate(-2px)}.modal-close{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s;position:absolute;right:1.5rem}} .modal-close:hover{background:#333}.modal-tabs{display:flex;border-bottom:1px solid #333;background:#222}.modal-tabs .tab{flex:1;padding:1rem;background:none;border:none;color:#999;font-size:1rem;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.modal-tabs .tab:hover{color:#fff;background:#282828}.modal-tabs .tab.active{color:#fff;border-bottom-color:#58a6ff}.modal-body{padding:0 1.5rem 1.5rem;overflow-y:auto;flex:1;color:#fff}.loading{text-align:center;padding:2rem;color:#999}.loading-hourglass{font-size:3rem;display:inline-block;animation:pulse 1s ease-in-out infinite}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;gap:1.5rem;min-height:300px}.error-icon{font-size:4rem}.error-message h3{margin:0 0 .5rem;color:#ef4444;font-size:1.5rem}.error-message p{margin:0;color:#999;font-size:1rem}.retry-button{padding:.875rem 2rem;background:#58a6ff;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.retry-button:hover{background:#4a8fd8}.retry-button:active{transform:scale(.98)}.current-conditions{display:flex;flex-direction:column;gap:.5rem}.temp-display{text-align:center;padding:1rem 0}.temp-main{font-size:4rem;font-weight:700;color:#fff}.conditions{font-size:1.5rem;color:#999;margin-top:.5rem}.location-info-section{display:flex;justify-content:center;gap:3rem;padding:1.5rem;background:#222;border-radius:12px;margin:0 auto;max-width:600px}.location-info-item{display:flex;align-items:center;gap:.75rem}.location-icon{font-size:2rem}.location-info-text{display:flex;flex-direction:column;gap:.25rem}.location-label{font-size:.85rem;color:#999;text-transform:uppercase;letter-spacing:.05em}.location-value{font-size:1.1rem;font-weight:600;color:#fff}.weather-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.weather-item{text-align:center}.weather-item .label{font-size:.9rem;color:#999;margin-bottom:.5rem}.weather-item .value{font-size:1.25rem;font-weight:600;color:#fff}.hourly-forecast{display:flex;flex-direction:column;gap:.5rem;margin-top:0;padding-top:0;max-width:900px;margin-left:auto;margin-right:auto}.forecast-header{background:#2a2a2a!important;border-bottom:2px solid #444;font-weight:700;color:#aaa;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:10;margin-bottom:0}.forecast-header>*{font-size:.875rem!important;color:#aaa!important;font-weight:700!important}.hour-item{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 2fr;gap:1rem;padding:1rem;background:#222;border-radius:8px;align-items:center}.hour-item>*{text-align:center}.hour-golf-score{font-weight:700;font-size:.9rem}.hour-time{font-weight:600}.hour-temp{font-size:1.1rem;font-weight:600}.hour-wind{color:#999;font-size:.9rem}.hour-precip{color:#58a6ff;font-weight:600}.hour-conditions{color:#999;font-size:.9rem}.daily-forecast{display:flex;flex-direction:column;gap:.5rem;margin-top:0;padding-top:0;max-width:900px;margin-left:auto;margin-right:auto}.day-item{display:grid;grid-template-columns:1fr 1fr 1.5fr 1fr 1fr 2fr;gap:1rem;padding:1rem;background:#222;border-radius:8px;align-items:center}.day-item>*{text-align:center}.day-golf-score{font-weight:700;font-size:1rem}.day-name{font-weight:600;font-size:1.1rem}.day-temps{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.1rem}.day-temps .high{font-weight:600}.day-temps .separator{color:#666}.day-temps .low,.day-conditions{color:#999}.day-wind{color:#999;font-size:.9rem}.day-precip{color:#58a6ff;font-weight:600;font-size:.9rem}@media(max-width:768px){.hour-item,.day-item{grid-template-columns:1fr;gap:.5rem}.weather-grid{grid-template-columns:repeat(2,1fr)}.temp-main{font-size:3rem}}.golf-conditions-tab{padding:0;display:flex;flex-direction:column;gap:.5rem}.overall-score-card{display:flex;align-items:center;gap:2rem;padding:1.5rem;background:#ffffff0d;border-radius:12px}.score-circle{display:flex;flex-direction:column;align-items:center;justify-content:center;width:120px;height:120px;border:5px solid;border-radius:50%;flex-shrink:0}.score-value{font-size:2.5rem;font-weight:700}.score-max{font-size:1rem;opacity:.7}.score-recommendation h3{margin:0 0 .5rem;color:#fff;font-size:1.2rem}.score-recommendation p{margin:0;color:#bbb;font-size:1rem}.score-breakdown{display:flex;flex-direction:column;gap:.5rem}.score-breakdown h4{margin:0 0 .5rem;color:#fff;font-size:1.1rem}.factor-row{display:grid;grid-template-columns:1fr 2fr auto;gap:1rem;align-items:center}.factor-info{display:flex;flex-direction:column;gap:.25rem}.factor-label{color:#fff;font-weight:500}.factor-value{color:#bbb;font-size:.9rem}.factor-score-bar{height:24px;background:#ffffff1a;border-radius:12px;overflow:hidden}.factor-score-fill{height:100%;transition:width .3s ease}.factor-score-value{color:#fff;font-weight:700;font-size:1.1rem;min-width:40px;text-align:right}.optimal-ranges{background:#ffffff0d;padding:1.5rem;border-radius:12px}.optimal-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #333;padding-bottom:.5rem}.optimal-tab{flex:1;padding:.75rem 1rem;background:none;border:none;color:#999;font-size:.95rem;cursor:pointer;transition:all .2s;border-radius:6px 6px 0 0;font-weight:500}.optimal-tab:hover{color:#fff;background:#2a2a2a}.optimal-tab.active{color:#fff;background:#333;border-bottom:2px solid #58a6ff}.optimal-content h4,.optimal-ranges h4{margin:0 0 1rem;color:#fff;font-size:1.1rem}.ranges-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.range-item{display:flex;flex-direction:column;gap:.5rem}.range-icon{font-size:1.5rem}.range-label{color:#bbb;font-size:.9rem}.range-value{color:#fff;font-weight:500}.golf-score-badge{padding:.75rem 1rem;border-radius:8px;color:#fff;font-weight:700;text-align:center;margin-bottom:1rem}.golf-score-badge-text{padding:.75rem 1rem;border-radius:8px;background:#222;color:#fff;text-align:center;font-size:1.1rem}.hour-golf-score,.day-golf-score{font-weight:700;font-size:.9rem}@media(max-width:600px){.overall-score-card{flex-direction:column;text-align:center}.ranges-grid{grid-template-columns:1fr}.factor-row{grid-template-columns:1fr;gap:.5rem}.factor-score-bar{order:2}.factor-score-value{order:3;text-align:left}.location-info-section{flex-direction:column;gap:1.5rem;padding:1.25rem}.location-info-item{justify-content:center}}.county-cities-list{padding:1rem}.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.county-city-button{padding:.875rem 1rem;background:#2a2a2a;border:2px solid #333;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s;text-align:center}.county-city-button:hover{background:#333;border-color:#4a9eff;transform:translateY(-2px)}.golf-courses-tab{padding:2rem;display:flex;justify-content:center;align-items:center;min-height:300px}.coming-soon{text-align:center;color:#999}.coming-soon p{margin-top:1rem;font-size:1.1rem}.no-data{text-align:center;color:#999;padding:2rem;font-size:1rem}.golf-courses-list{display:flex;flex-direction:column;gap:.5rem}.course-item-wrapper{background:#222;border-radius:8px;overflow:hidden;position:relative}.selected-course-badge{background:linear-gradient(135deg,#ffc107,#ff9800);color:#000;font-size:.75rem;font-weight:700;padding:.4rem .75rem;text-align:center;letter-spacing:.5px;text-transform:uppercase;box-shadow:0 2px 8px #ffc1074d}.course-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;cursor:pointer;transition:background .2s}.course-item.selected-course{background:linear-gradient(135deg,#ffc10726,#ffc1070d);border-left:4px solid #ffc107}.course-item:hover{background:#2a2a2a}.course-item.selected-course:hover{background:linear-gradient(135deg,#ffc10733,#ffc10714)}.course-item-left{display:flex;flex-direction:column;gap:.4rem;flex:1}.course-name{font-weight:600;font-size:1rem;color:#fff}.course-subname{font-weight:400;color:#aaa}.course-location{color:#999;font-size:.85rem}.course-details{display:flex;align-items:center;color:#888;font-size:.85rem;margin-top:.2rem}.course-tees,.course-holes,.course-yardage{white-space:nowrap}.course-separator{margin:0 .4rem;color:#555}.course-expanded{padding:.75rem;border-top:1px solid #333;background:#1a1a1a;animation:expandDown .2s ease-out}@keyframes expandDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.expanded-row{padding:.4rem 0;color:#ccc;font-size:.9rem;line-height:1.4}.expanded-row strong{color:#fff;margin-right:.5rem}.tee-section{margin-top:.75rem}.tee-section-title{font-weight:600;color:#fff;margin-bottom:.5rem;font-size:.95rem}.tee-info{display:flex;gap:.5rem;padding:.3rem 0;color:#ccc;font-size:.85rem}.tee-name{font-weight:600;color:#4a9eff;min-width:80px}.tee-details{color:#aaa}.expanded-actions{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #333;display:flex;gap:.75rem}.no-courses{text-align:center;color:#999;padding:2rem}.no-courses p{font-size:1rem}.current-location-center{flex:1;display:flex;align-items:center;justify-content:center;min-height:48px;position:static;z-index:auto;margin-left:-160px}.search-modal-header{display:flex;align-items:center;justify-content:center;gap:2rem;position:relative}.current-location-center{position:absolute;left:70%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;min-width:180px;min-height:48px;z-index:2}.user-menu,.sign-in-btn{min-width:160px;max-width:220px;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;word-break:break-all}.sign-in-btn{align-items:flex-end;justify-content:center}.weather-modal-btn{background:none;border:none;padding:0;margin:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:120px;min-height:48px}.weather-modal-temp{font-size:1.5rem;font-weight:700;color:#fff;text-align:center}.weather-modal-city{font-size:1rem;font-weight:400;color:#fff;text-align:center}.initial-search-modal-overlay{position:fixed;inset:0;background:#000000a6;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);display:flex;align-items:center;justify-content:center;z-index:1000}.initial-search-modal{background:#000000f2;backdrop-filter:blur(40px) saturate(150%);-webkit-backdrop-filter:blur(40px) saturate(150%);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:90%;max-width:800px;height:85vh;overflow:hidden;box-shadow:0 8px 32px #0009,0 2px 8px #0006,inset 0 1px #ffffff0d;position:relative;display:flex;flex-direction:column}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#888;font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;z-index:10}.modal-close-btn:hover{background:#222;color:#fff}.search-modal-header{padding:.5rem 2rem .25rem;border-bottom:1px solid rgba(255,255,255,.06);background:#ffffff05;display:flex;justify-content:space-between;align-items:center;gap:2rem;box-shadow:0 1px #ffffff08}.header-logo-container{flex:1;display:flex;justify-content:flex-start;align-items:center}.header-logo{height:120px;width:auto;object-fit:contain}.search-modal-header h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:#f8f9fa}.search-modal-header p{margin:0;font-size:.95rem;color:#8b9dc3}.user-menu{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.user-email{font-size:.85rem;color:#8b9dc3}.sign-in-btn,.sign-out-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:.4rem .9rem;border-radius:7px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;min-width:0;min-height:0}.sign-in-btn:hover,.sign-out-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.sign-out-btn{background:linear-gradient(135deg,#666,#555);font-size:.85rem;padding:.5rem 1rem}.sign-out-btn:hover{box-shadow:0 4px 12px #0000004d}.search-type-tabs{display:flex;gap:0;padding:0 2rem;border-bottom:1px solid #222}.search-tab{flex:1;padding:1.25rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:#888;font-size:.95rem;cursor:pointer;transition:all .2s;font-weight:500}.search-tab:hover{color:#aaa;background:#ffffff08}.search-tab.active{color:#4a9eff;border-bottom-color:#4a9eff;background:#4a9eff0d}.search-input-container{padding:1.5rem 2rem}.search-modal-input{width:100%;padding:.875rem 1rem;background:#222;border:1px solid #333;border-radius:8px;color:#fff;font-size:1rem;outline:none;transition:all .2s;box-sizing:border-box}.search-modal-input:focus{border-color:#4a9eff;background:#252525;box-shadow:0 0 0 3px #4a9eff1a}.search-modal-input::placeholder{color:#666}.search-results{flex:1;overflow-y:auto;padding:0 2rem 2rem;min-height:200px}.results-list{display:flex;flex-direction:column;gap:.5rem}.result-item{padding:1rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;cursor:pointer;transition:all .2s}.result-item:hover{background:#252525;border-color:#3a3a3a;transform:translate(4px)}.result-item.selected{background:#252525;border-color:#4a9eff;transform:translate(4px);box-shadow:0 0 0 2px #4a9eff33}.result-name{font-size:1rem;font-weight:600;color:#fff;margin-bottom:.25rem}.result-details{font-size:.875rem;color:#888}.search-loading,.no-results,.search-hint{text-align:center;padding:2rem;color:#666;font-size:.95rem}.search-loading{color:#4a9eff}.no-results{color:#999}.search-results::-webkit-scrollbar{width:8px}.search-results::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.search-results::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.search-results::-webkit-scrollbar-thumb:hover{background:#444}.favorites-section{margin-bottom:1.5rem}.favorites-header{font-size:.875rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;padding:0 .25rem}.section-divider{font-size:.875rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.05em;margin:1.5rem 0 .75rem;padding:0 .25rem}.search-section{margin-top:1rem}.favorites-list{display:flex;flex-direction:column;gap:.75rem}.favorite-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;transition:all .2s}.favorite-item:hover{background:#252525;border-color:#3a3a3a}.favorite-content{flex:1;cursor:pointer}.favorite-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.favorite-name{font-size:1rem;font-weight:600;color:#fff}.favorite-score{font-size:1.125rem;font-weight:700;padding:.25rem .625rem;border-radius:6px;background:#0000004d;display:inline-flex;align-items:center;gap:.25rem}.favorite-score-loading{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.favorite-details{font-size:.875rem;color:#888}.favorite-remove-btn{width:32px;height:32px;border-radius:6px;background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:#ff6b6b;font-size:.95rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;line-height:1}.favorite-remove-btn:hover{background:#f44;border-color:#f44;color:#fff;transform:scale(1.1);box-shadow:0 2px 8px #f446}.no-favorites{text-align:center;padding:3rem 2rem}.no-favorites-icon{font-size:3rem;margin-bottom:1rem;opacity:.3}.no-favorites-text{font-size:1.125rem;font-weight:600;color:#666;margin-bottom:.5rem}.no-favorites-hint{font-size:.875rem;color:#555;max-width:300px;margin:0 auto;line-height:1.5}.no-favorites-mini{text-align:center;padding:1.5rem 1rem;background:#1a1a1a;border:1px dashed #333;border-radius:8px;color:#666;font-size:.875rem}.result-item{display:flex;align-items:center;gap:.75rem}.result-content{flex:1;padding:1rem;cursor:pointer}.favorite-btn{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#ffc10714,#ffc10705);border:1.5px solid rgba(255,193,7,.25);color:#ffc107;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-right:.5rem;box-shadow:0 2px 8px #0000001a}.favorite-btn:hover{background:linear-gradient(135deg,#ffc10733,#ffc1071a);border-color:#ffc107;color:#ffc107;box-shadow:0 4px 16px #ffc1074d}.favorite-btn.favorited{background:linear-gradient(135deg,#ffc10740,#ffc10726);border-color:#ffc107;color:#ffc107;box-shadow:0 2px 12px #ffc10766}.favorite-btn.favorited:hover{transform:scale(1.15) rotate(-5deg)}.result-item:hover .favorite-btn{opacity:1}@media(max-width:768px){.initial-search-modal{width:100%;height:100vh;max-width:100%;border-radius:0}.search-modal-header{padding:1.5rem 1rem .75rem}.search-modal-header h2{font-size:1.5rem}.search-type-tabs{padding:.75rem 1rem 0}.search-input-container{padding:1rem 1.5rem}.search-results{padding:0 1.5rem 1.5rem}}.auth-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.auth-modal{background:#1a1a1a;border-radius:16px;padding:2rem 2.5rem 2.5rem;max-width:450px;width:100%;min-height:620px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;border:1px solid #333}.auth-modal::-webkit-scrollbar{width:8px}.auth-modal::-webkit-scrollbar-track{background:#222;border-radius:10px}.auth-modal::-webkit-scrollbar-thumb{background:#444;border-radius:10px}.auth-modal::-webkit-scrollbar-thumb:hover{background:#555}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#999;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.auth-modal-close:hover{color:#fff}.auth-modal-header{text-align:center;margin-bottom:1.5rem}.auth-modal-header h2{color:#fff;font-size:1.5rem;margin:0 0 .5rem}.auth-modal-header p{color:#999;font-size:.875rem;margin:0;line-height:1.4}.auth-error{background:#dc3545;color:#fff;padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.85rem;text-align:center}.auth-message{background:#28a745;color:#fff;padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.85rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#ccc;font-size:.9rem;font-weight:500}.form-group input{background:#222;border:1px solid #333;color:#fff;padding:.875rem;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#4caf50;background:#2a2a2a}.form-group input::placeholder{color:#666}.form-group small{color:#888;font-size:.825rem}.auth-submit-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:.875rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.25rem}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{text-align:center;margin:1.25rem 0;position:relative}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:#333}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-divider span{color:#666;font-size:.875rem;background:#1a1a1a;padding:0 1rem;position:relative}.google-signin-btn{background:#fff;color:#333;border:1px solid #ddd;padding:.875rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .2s}.google-signin-btn:hover:not(:disabled){background:#f8f8f8;box-shadow:0 2px 8px #0000001a}.google-signin-btn:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{text-align:center;margin-top:1.25rem;color:#999;font-size:.875rem}.auth-toggle-btn{background:none;border:none;color:#4caf50;font-weight:600;cursor:pointer;padding:0;font-size:.9rem;text-decoration:underline;transition:color .2s}.auth-toggle-btn:hover{color:#45a049}.verification-success{text-align:center;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.verification-icon{font-size:4rem;margin-bottom:.5rem;animation:bounce .6s ease-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.verification-success h2{color:#4caf50;font-size:1.75rem;margin:0}.verification-success p{color:#ccc;font-size:1rem;line-height:1.6;margin:0}.verification-email{color:#fff;font-weight:600;font-size:1.1rem;padding:.5rem 1rem;background:#4caf501a;border-radius:8px;border:1px solid rgba(76,175,80,.3);margin:.5rem 0}.verification-instructions{max-width:350px;margin-top:.5rem!important;font-size:.95rem!important}@media(max-width:500px){.auth-modal{padding:1.5rem 1.25rem;max-height:95vh}.auth-modal-header{margin-bottom:1.25rem}.auth-modal-header h2{font-size:1.35rem}.auth-form{gap:.875rem}.verification-icon{font-size:3rem}.verification-success h2{font-size:1.5rem}}
