:root{--bg: #060914;--bg-card: #0d1326;--bg-card2: #111828;--border: rgba(100, 180, 255, .12);--accent: #4fc3f7;--accent2: #00bcd4;--gold: #ffc107;--green: #66bb6a;--red: #ef5350;--amber: #ffa726;--text: #e8eaf6;--text-sub: #90a4ae;--text-muted: #546e7a;--radius: 14px;--radius-sm: 8px;--modal-bg: #0e1627;--shadow: 0 8px 36px rgba(0,0,0,.7);--winter: #a8e0ff;--summer: #ffdd00;--spring: #ffe575;--autumn: #ff8800}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;min-height:100vh;line-height:1.6}.hina-header{background:linear-gradient(135deg,#080e1e,#0d1a2e);border-bottom:1px solid var(--border);padding:0 20px;position:sticky;top:0;z-index:100}.header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:12px 0;flex-wrap:wrap}.back-link{color:var(--text-sub);text-decoration:none;font-size:.85rem;white-space:nowrap;transition:color .2s}.back-link:hover{color:var(--accent)}.header-title{flex:1}.header-title h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#a8e0ff,#4fc3f7,#00bcd4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.02em}.header-sub{font-size:.75rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.lang-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.lang-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.lang-select{background:var(--bg-card2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px;font-size:.85rem;cursor:pointer;outline:none}.lang-select:focus{border-color:var(--accent)}.today-banner{background:linear-gradient(135deg,#0d1b30,#0a1520,#0d1a32);border-bottom:1px solid var(--border);padding:20px}.today-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:20px}.today-moon-img{width:72px;height:72px;object-fit:contain;filter:drop-shadow(0 0 16px rgba(79,195,247,.5));flex-shrink:0}.today-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:2px}.today-name{font-size:1.4rem;font-weight:700;color:var(--accent);line-height:1.2}.today-day{font-size:.8rem;color:var(--text-sub);margin:2px 0 6px}.today-snippet{font-size:.82rem;color:var(--text-sub);max-width:540px;line-height:1.5}.rating-badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;border-radius:20px;padding:3px 10px;margin:4px 0}.rating-good{background:#66bb6a2e;color:var(--green);border:1px solid rgba(102,187,106,.35)}.rating-ok{background:#ffc1072e;color:var(--gold);border:1px solid rgba(255,193,7,.35)}.rating-avoid{background:#ef53502e;color:var(--red);border:1px solid rgba(239,83,80,.35)}.tab-nav{background:var(--bg-card);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:sticky;top:60px;z-index:90}.tab-nav::-webkit-scrollbar{display:none}.tab-nav-inner{max-width:1100px;margin:0 auto;display:flex}.tab-btn{flex-shrink:0;background:none;border:none;border-bottom:3px solid transparent;color:var(--text-sub);cursor:pointer;font-size:.85rem;font-weight:500;padding:14px 20px;white-space:nowrap;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--accent)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.hina-main{max-width:1100px;margin:0 auto;padding:24px 16px 60px}.tab-panel{display:none}.tab-panel.active{display:block}.cycle-nav-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:20px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.cycle-nav{display:flex;align-items:center;gap:10px}.cycle-arrow{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:1.1rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s;flex-shrink:0}.cycle-arrow:hover{background:#4fc3f726;border-color:var(--accent)}.cycle-info{text-align:center;min-width:140px}.cycle-range{font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap}.cycle-subtitle{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-top:2px}.date-jump-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:180px}.date-jump-wrap label{font-size:.78rem;color:var(--text-muted);white-space:nowrap}.date-jump-wrap input[type=date]{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.85rem;padding:6px 10px;cursor:pointer;outline:none;transition:border-color .2s;flex:1}.date-jump-wrap input[type=date]:focus{border-color:var(--accent)}.date-jump-wrap input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1) opacity(.5);cursor:pointer}.today-cycle-btn{background:#4fc3f71f;border:1px solid rgba(79,195,247,.3);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;font-size:.8rem;font-weight:600;padding:7px 14px;white-space:nowrap;transition:background .2s;display:none;align-items:center}.today-cycle-btn:hover{background:#4fc3f738}.phase-date{font-size:.68rem;color:var(--text-muted);letter-spacing:.01em}.phases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.phase-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 8px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;text-align:center;-webkit-user-select:none;user-select:none}.phase-card:hover{transform:translateY(-3px);box-shadow:0 6px 28px #4fc3f740;border-color:#4fc3f766}.phase-card.today{border-color:var(--accent);box-shadow:0 0 0 2px #4fc3f740,0 6px 28px #4fc3f74d}.phase-card.today:after{content:"Tonight";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--accent);color:#000;font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:10px;white-space:nowrap}.phase-img{width:56px;height:56px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(79,195,247,.3))}.phase-day{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.phase-name{font-size:.8rem;font-weight:600;color:var(--text);line-height:1.3}.phase-dot{width:8px;height:8px;border-radius:50%}.dot-good{background:var(--green)}.dot-ok{background:var(--gold)}.dot-avoid{background:var(--red)}.seasons-scroll{display:flex;flex-direction:column;gap:32px}.season-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;overflow:hidden;display:grid;grid-template-columns:auto 1fr;gap:0}@media (max-width: 600px){.season-card{grid-template-columns:1fr}}.season-moon{background:#0000004d;display:flex;align-items:center;justify-content:center;padding:32px 24px}.season-moon img{width:100px;height:100px;object-fit:contain;filter:drop-shadow(0 0 18px rgba(168,224,255,.4))}.season-content{padding:28px 28px 28px 24px}.season-maori{font-size:1.7rem;font-weight:800;letter-spacing:.02em;line-height:1.1}.season-english{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;font-weight:500;margin-bottom:20px;opacity:.75}.season-winter .season-maori,.season-winter .season-english{color:var(--winter)}.season-summer .season-maori,.season-summer .season-english{color:var(--summer)}.season-spring .season-maori,.season-spring .season-english{color:var(--spring)}.season-autumn .season-maori,.season-autumn .season-english{color:var(--autumn)}.season-month-block{margin-bottom:18px}.season-month-block h4{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:4px}.season-range{font-weight:400;color:var(--text-sub);font-size:.8rem}.season-month-block p{font-size:.85rem;color:var(--text-sub);line-height:1.65}.wb-inner{display:flex;flex-direction:column;gap:24px}.wb-log-card,.wb-chart-card,.wb-history-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.wb-log-card h2{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:6px}.wb-phase-label{font-size:.85rem;color:var(--text-sub);margin-bottom:18px}.wb-phase-label strong{color:var(--accent)}.emotion-btns{display:flex;gap:12px;flex-wrap:wrap}.emo-btn{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--bg-card2);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;padding:14px 20px;transition:transform .15s,border-color .15s,background .15s;min-width:80px}.emo-btn:hover{transform:translateY(-2px)}.emo-btn.emo-happy:hover,.emo-btn.emo-happy.selected{border-color:var(--green);background:#66bb6a26}.emo-btn.emo-ok:hover,.emo-btn.emo-ok.selected{border-color:var(--gold);background:#ffc10726}.emo-btn.emo-low:hover,.emo-btn.emo-low.selected{border-color:#ef9a9a;background:#ef53501a}.emo-icon{font-size:1.8rem}.emo-label{font-size:.75rem;color:var(--text-sub);font-weight:500}.wb-saved-msg{margin-top:12px;font-size:.8rem;color:var(--green);min-height:18px}.chart-toggle{display:flex;gap:8px;margin-bottom:16px}.chart-btn{background:var(--bg-card2);border:1px solid var(--border);border-radius:8px;color:var(--text-sub);cursor:pointer;font-size:.82rem;padding:7px 14px;transition:all .2s}.chart-btn.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.chart-wrap{position:relative;min-height:220px;display:flex;align-items:center;justify-content:center}.chart-empty{color:var(--text-muted);font-size:.85rem;text-align:center;padding:20px;max-width:340px}#emotionChart{max-height:260px}.wb-history-card h3{font-size:.9rem;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.history-list{list-style:none;display:flex;flex-direction:column;gap:8px}.history-item{display:flex;align-items:center;gap:12px;font-size:.84rem;padding:8px 12px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.history-emo{font-size:1.2rem}.history-phase{color:var(--accent);font-weight:600}.history-date{color:var(--text-muted);margin-left:auto;font-size:.78rem}.history-empty{color:var(--text-muted);font-size:.85rem}.about-inner{max-width:720px;margin:0 auto}.about-hero{text-align:center;padding:28px 0 32px}.about-moon{width:90px;height:90px;object-fit:contain;filter:drop-shadow(0 0 24px rgba(168,224,255,.6));margin-bottom:14px}.about-hero h2{font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,#a8e0ff,#4fc3f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-subtitle{color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-top:4px}.about-body p{color:var(--text-sub);font-size:.95rem;line-height:1.75;margin-bottom:16px}.about-body em{color:var(--accent);font-style:normal}.about-languages{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-top:24px}.about-languages h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:8px}.about-languages>p{font-size:.85rem;color:var(--text-sub);margin-bottom:14px}.lang-list{list-style:none;display:flex;flex-direction:column;gap:8px}.lang-list li{font-size:.88rem;color:var(--text-sub);padding:8px 12px;background:var(--bg);border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.lang-list li strong{color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:500;display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .25s}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--modal-bg);border:1px solid var(--border);border-radius:24px 24px 0 0;width:100%;max-width:680px;max-height:90dvh;overflow-y:auto;padding:28px 24px 40px;position:relative;transform:translateY(30px);transition:transform .25s}.modal-overlay.open .modal{transform:translateY(0)}@media (min-width: 700px){.modal-overlay{align-items:center}.modal{border-radius:24px;max-height:85vh}}.modal-close{position:absolute;top:16px;right:16px;background:#ffffff14;border:none;border-radius:50%;color:var(--text);cursor:pointer;font-size:1rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:#ffffff26}.modal-header{display:flex;gap:20px;align-items:flex-start;margin-bottom:24px}.modal-moon-img{width:88px;height:88px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 0 20px rgba(79,195,247,.45))}.modal-header-info{flex:1;min-width:0}.modal-day-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:4px}.modal-today-badge{display:inline-block;background:var(--accent);color:#000;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 9px;border-radius:10px;margin-bottom:6px}.modal-title{font-size:1.5rem;font-weight:800;color:var(--text);line-height:1.2;margin-bottom:0}.modal-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.edit-name-btn{display:none;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.82rem;padding:3px 6px;flex-shrink:0;transition:color .2s,border-color .2s}body.logged-in .edit-name-btn{display:inline-flex}.edit-name-btn:hover{color:var(--accent);border-color:#4fc3f74d}.modal-title-edit{display:none;flex-direction:column;gap:6px;margin-bottom:8px}.modal-name-input{background:var(--bg);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:1.1rem;font-weight:700;padding:6px 10px;outline:none;width:100%}.modal-name-input::placeholder{color:var(--text-muted);font-weight:400;font-size:.85rem}.modal-name-actions{display:flex;gap:8px}.modal-name-confirm,.modal-name-cancel{border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.82rem;font-weight:600;padding:6px 14px;transition:opacity .2s}.modal-name-confirm{background:var(--accent2);color:#000}.modal-name-cancel{background:var(--border);color:var(--text-muted)}.modal-name-confirm:hover,.modal-name-cancel:hover{opacity:.8}.modal-name-saved-msg{font-size:.78rem;color:var(--green);min-height:14px;margin-bottom:4px}.modal-other-names{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.lang-chip{font-size:.72rem;background:#4fc3f71a;color:var(--accent);border:1px solid rgba(79,195,247,.25);border-radius:12px;padding:2px 9px}.modal-body{display:flex;flex-direction:column;gap:20px}.modal-section h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600;margin-bottom:8px}.modal-section p{font-size:.9rem;color:var(--text-sub);line-height:1.65}.modal-notes{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.88rem;padding:12px;resize:vertical;min-height:80px;outline:none;transition:border-color .2s}.modal-notes:focus{border-color:var(--accent)}.save-note-btn{margin-top:8px;background:var(--accent2);border:none;border-radius:var(--radius-sm);color:#000;cursor:pointer;font-size:.85rem;font-weight:600;padding:9px 18px;transition:opacity .2s}.save-note-btn:hover{opacity:.85}.note-saved-msg{font-size:.78rem;color:var(--green);margin-top:6px;min-height:16px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#4fc3f733;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4fc3f766}@media (max-width: 480px){.phases-grid{grid-template-columns:repeat(4,1fr);gap:8px}.phase-card{padding:10px 4px 8px}.phase-img{width:42px;height:42px}.phase-name{font-size:.72rem}.today-name{font-size:1.1rem}.modal-moon-img{width:68px;height:68px}.modal-title{font-size:1.25rem}}.tide-location-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.55rem}.tide-loc-btn{padding:.35rem .85rem;border-radius:1.2rem;border:1px solid rgba(168,224,255,.3);background:#a8e0ff12;color:#a8e0ff;font-size:.8rem;cursor:pointer;transition:background .18s}.tide-loc-btn:hover{background:#a8e0ff2e}.tide-station-name{font-size:.78rem;color:#a8e0ff8c;margin-bottom:.65rem;min-height:1.1em;font-style:italic}.tide-map-wrap{margin-bottom:.75rem}#tideMap{height:220px;border-radius:.6rem;border:1px solid rgba(168,224,255,.2);margin-bottom:.5rem}.tide-confirm-btn{width:100%;padding:.45rem;border-radius:.5rem;border:none;background:#a8e0ff1f;color:#a8e0ff;cursor:pointer;font-size:.85rem;transition:background .18s}.tide-confirm-btn:hover{background:#a8e0ff38}.tide-loading{font-size:.82rem;color:#a8e0ff8c;margin:.5rem 0;font-style:italic}.tide-error{font-size:.8rem;color:#ff6b6b;margin:.5rem 0}.tide-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}.tide-block{background:#a8e0ff0a;border:1px solid rgba(168,224,255,.1);border-radius:.55rem;padding:.55rem .7rem}.tide-block-full{grid-column:1 / -1}.tide-block-header{font-size:.7rem;color:#a8e0ff73;text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:.4rem}.tide-row{font-size:.82rem;color:#c5deea;padding:.12rem 0;font-variant-numeric:tabular-nums}.tide-bite-major{color:#a8e0ff;font-weight:600}.tide-bite-minor{color:#a8e0ffa6}@media (max-width: 480px){.tide-grid{grid-template-columns:1fr}#tideMap{height:180px}}.requires-auth{display:none}.requires-no-auth,body.logged-in .requires-auth{display:block}body.logged-in .requires-no-auth{display:none}.auth-prompt{font-size:.85rem;color:#a8e0ff8c;margin:.25rem 0}.auth-prompt a{color:#a8e0ff;text-decoration:underline}.auth-prompt a:hover{color:#fff}.wb-auth-prompt{padding:2rem 1rem;text-align:center}
