*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,SF Pro Text,Helvetica,Arial,sans-serif;background:#f2f2f7;min-height:100vh;display:flex;justify-content:center}#root{width:100%;max-width:430px;min-height:100vh;background:#fff;display:flex;flex-direction:column;position:relative}:root{--teal: #50a2ad;--teal-dark: #3a8a94;--navy: #1a2e4a;--red: #d64040;--green: #0f6e56;--amber: #854f0b;--bg: #ffffff;--bg2: #f2f2f7;--border: #e0e0e0;--text: #1a1a1a;--muted: #6b6b6b}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--bg2);outline:none;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--teal);background:#fff}button{cursor:pointer;font-family:inherit}.btn-primary{width:100%;padding:13px;background:var(--teal);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600}.btn-secondary{padding:8px 14px;background:var(--bg2);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500}.btn-teal{padding:8px 14px;background:var(--teal);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500}.card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin:0 16px}.section-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:0 16px;margin-bottom:6px}.list-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:0 16px}.list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.badge{display:inline-block;font-size:11px;padding:3px 9px;border-radius:20px;font-weight:500}.badge-green{background:#d4f0e8;color:#0f6e56}.badge-amber{background:#faeeda;color:#854f0b}.badge-blue{background:#e6f1fb;color:#185fa5}.badge-red{background:#fcebeb;color:#a32d2d}.alert-box{background:#faeeda;border:1px solid #fac775;border-radius:10px;padding:10px 14px;font-size:12px;color:#854f0b;margin:0 16px;line-height:1.6}.warn-box{background:#fcebeb;border:1px solid #f09595;border-radius:10px;padding:10px 14px;font-size:12px;color:#a32d2d;margin:0 16px;line-height:1.6}.info-box{background:#e6f1fb;border:1px solid #b5d4f4;border-radius:8px;padding:9px 12px;font-size:12px;color:#185fa5;line-height:1.5}.success-box{background:#d4f0e8;border:1px solid #5dcaa5;border-radius:10px;padding:10px 14px;font-size:13px;color:#085041;text-align:center;margin:0 16px}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.screen{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:14px 0 20px;background:var(--bg2)}.top-bar{background:var(--teal);padding:calc(10px + env(safe-area-inset-top,0px)) 18px 14px;color:#fff;flex-shrink:0}.top-bar-sub{font-size:11px;opacity:.65;text-transform:uppercase;letter-spacing:.05em}.top-bar-title{font-size:18px;font-weight:600}.bottom-nav{background:var(--bg);border-top:1px solid var(--border);display:flex;flex-shrink:0;padding:6px 0 calc(10px + env(safe-area-inset-bottom,0px))}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px 0}.nav-item .icon{font-size:18px;line-height:1.3}.nav-item .label{font-size:9px;color:var(--muted)}.nav-item.active .label{color:var(--teal);font-weight:600}.notice-card{background:var(--bg);border:1px solid var(--border);border-left:3px solid var(--teal);border-radius:10px;padding:10px 14px;margin:0 16px}.notice-card.urgent{border-left-color:var(--red)}.fg{display:flex;flex-direction:column;gap:5px}.fl{font-size:12px;font-weight:500;color:var(--muted)}.step-bar{display:flex;gap:4px;margin-bottom:16px}.step-seg{flex:1;height:3px;border-radius:2px}.flag-banner{border-radius:12px;padding:12px 16px;margin:0 16px;display:flex;align-items:center;gap:14px}.flag-swatch{width:38px;height:30px;border-radius:4px;flex-shrink:0;border:1px solid rgba(0,0,0,.12)}.tide-svg-wrap{display:block}.event-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;margin:0 16px;display:flex;gap:14px;padding:12px 16px}.event-date-box{background:var(--teal);color:#fff;border-radius:8px;width:42px;text-align:center;padding:4px 2px;flex-shrink:0}.event-month{font-size:9px;text-transform:uppercase;opacity:.75}.event-day{font-size:20px;font-weight:700;line-height:1.1}.rule-section{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:0 16px}.rule-header{padding:12px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);cursor:pointer}.rule-body{display:none}.rule-body.open{display:block}.rule-item{display:flex;gap:10px;padding:9px 16px;border-bottom:1px solid var(--border);align-items:flex-start}.rule-item:last-child{border-bottom:none}.rule-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:6px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 16px}.stat-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.stat-label{font-size:11px;color:var(--muted);margin-bottom:2px}.stat-value{font-size:24px;font-weight:600;color:var(--text)}.login-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;gap:14px;background:var(--bg)}.login-logo{width:68px;height:68px;background:var(--teal);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:32px}.login-title{font-size:22px;font-weight:700;color:var(--teal)}.login-sub{font-size:13px;color:var(--muted);text-align:center}.login-form{width:100%;display:flex;flex-direction:column;gap:10px}.error-text{color:var(--red);font-size:13px;text-align:center}.onboarding-wrap{flex:1;overflow-y:auto;padding:24px 20px;background:var(--bg)}
