*,:after,:before{box-sizing:border-box}:root{--blue:#0b3d91;--text:#111;--muted:#667085;--border:#ddd}body,html{height:100%}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.4;margin:0}.app,body{background:#fff;color:#111;color:var(--text)}.app{min-height:100vh}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.banner{box-shadow:0 2px 4px #00000026;display:block;font-size:16px;font-weight:500;line-height:1.5;margin:0;padding:16px 20px;text-align:center;white-space:pre-line}.banner--info{background:#eaf4ff;border:1px solid #9ec5fe;color:#0b3d91}.banner--warn{background:#fff7e0;border:1px solid #ffd38a;color:#a65b00}.banner--promo{background:linear-gradient(135deg,#6b5b95,#0b3d91);border:none;color:#fff;font-weight:600}.banner-link{color:inherit;font-weight:600;text-decoration:underline}.banner-link:hover{opacity:.9;text-decoration:none}.banner--clickable{cursor:pointer}.banner--clickable,.banner--clickable:hover{text-decoration:none}.banner span,.banner-link{font-weight:700;text-align:center}.banner--promo span:before{content:"🦑🎉 "}.banner--promo span:after{content:" 🎉🦑"}.topbar{align-items:center;background:#0b3d91;background:var(--blue);box-shadow:0 2px 4px #00000026;color:#fff;display:flex;justify-content:space-between;padding:12px 20px}.brand{font-size:20px;font-weight:800;letter-spacing:.5px}.grow-spacer{flex:1 1 auto}.actions{gap:10px}.actions,.userbox{align-items:center;display:flex}.userbox{gap:8px}.hello{color:#e7eefc;font-weight:500;margin-right:6px}.btn{background:#fff;border:1px solid #ddd;border:1px solid var(--border);border-radius:6px;cursor:pointer;padding:6px 10px;transition:filter .15s ease,background .15s ease}.btn:hover{background:#f8f8f8}.btn:disabled{cursor:not-allowed;opacity:.6}.btn.primary{background:#0b3d91;background:var(--blue);border-color:#0b3d91;border-color:var(--blue);color:#fff}.btn.primary:hover{filter:brightness(1.05)}.btn.fullwidth{width:100%}.burger{align-items:center;background:#0000;border:1px solid #ffffff8c;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;height:36px;justify-content:center;line-height:0;padding:0;position:relative;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease;width:36px}.burger:hover{background:#ffffff14;border-color:#ffffffbf}.burger:focus-visible{box-shadow:0 0 0 3px #3b82f673;outline:none}.burger[aria-expanded=true]{background:#ffffff1f;border-color:#ffffffe6}.burger-lines,.burger-lines:after,.burger-lines:before{background:currentColor;border-radius:2px;content:"";display:block;height:2px;position:relative;width:20px}.burger-lines{position:relative}.burger-lines:before{left:0;position:absolute;top:-7px}.burger-lines:after{left:0;position:absolute;top:7px}.menu-wrap{position:relative}.nav-menu{background:#fff;border:1px solid #ddd;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 18px #00000014;color:#111;color:var(--text);left:0;min-width:200px;padding:6px;position:absolute;top:calc(100% + 6px);z-index:999}.nav-item{background:#0000;border:0;border-radius:6px;cursor:pointer;padding:8px 10px;text-align:left;width:100%}.nav-item:hover{background:#f7f7f7}.main{margin:0 auto;max-width:1100px;padding:16px}.section{margin-bottom:16px}.h3{margin-top:0}.spacer-12{height:12px}.tile-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.tile{background:#fff;border:1px solid #ddd;border:1px solid var(--border);border-radius:6px;cursor:pointer;padding:12px;text-align:left}.tile:hover{background:#fafafa}.tile-title{font-weight:600;margin-bottom:6px}.tile-sub{color:#666;font-size:13px}.debug-footer{background:#fafafa;border-top:1px solid #eee;font-size:12px;margin:0;padding:8px}.intro.card{background:#fff;border:1px solid #10182814;border-radius:10px;box-shadow:0 2px 6px #00000014;margin:20px auto;max-width:900px;padding:20px}.intro h3{color:#0b3d91;color:var(--blue);font-size:22px;margin-bottom:12px}.intro p{color:#344054;font-size:15px;line-height:1.5;margin-bottom:8px}.intro-tagline{color:#475467;margin:6px 0 10px}.intro-text{color:#344054;margin:6px 0 10px}.intro-powered{color:#475467;font-style:italic;margin-top:10px}.two-col{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr}@media (min-width:900px){.two-col{align-items:start;grid-template-columns:420px minmax(0,1fr)}}.two-col .col{min-width:0}.login-card{background:#fff;border:1px solid #10182814;border-radius:12px;box-shadow:0 1px 2px #1018280a,0 8px 24px #1018280f;padding:16px 18px}.login-title{color:#0b3d91;color:var(--blue);font-size:18px;font-weight:700;margin:0 0 4px}.login-subtitle{color:#667085;color:var(--muted);margin:0 0 12px}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-label{color:#1f2937;font-weight:600}.input{background:#fff;border:1px solid #c9c9c9;font-size:14px;padding:10px 12px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.input:focus{border-color:#84aef2;box-shadow:0 0 0 3px #3f83f833}.form-error{color:crimson;margin-top:12px}.topbar .btn:not(.burger){background:#fffffff2;border-color:#ffffffbf}.topbar .btn:not(.burger):hover{background:#fff}.table-wrap{overflow:auto}.table.admin-users{border-collapse:collapse;width:100%}.table.admin-users td,.table.admin-users th{border-bottom:1px solid #e9eef3;padding:10px 12px}.table.admin-users thead th{background:#fafcff;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:1}.table.admin-users tr:hover td{background:#fcfdff}.panel{background:#fff;border:1px solid #e6ecf2;border-radius:10px;padding:12px}.panel-head{margin-bottom:8px}.panel-title{font-size:18px;margin:0}.panel-tools{align-items:center;display:flex;gap:8px}.input{border:1px solid #d7dfe8;border-radius:8px;min-width:260px;padding:8px 10px}.input:focus{border-color:#9fb6ff;box-shadow:0 0 0 3px #557dff26;outline:none}.badge.role-badge{background:#f4f7fb;border:1px solid #d7dfe8;border-radius:999px;display:inline-block;font-size:12px;line-height:1.2;margin:2px 6px 2px 0;padding:3px 8px}.roles{white-space:nowrap}.muted{color:#8a95a3}.center{text-align:center}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Courier New,monospace}.sheet-backdrop{background:#00000040;inset:0;position:fixed;z-index:200}.sheet{background:#fff;box-shadow:-16px 0 32px #0000001a;display:flex;flex-direction:column;height:100%;position:fixed;right:0;top:0;width:420px;z-index:201}.sheet-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 20px}.sheet-body{overflow:auto;padding:16px 20px}.badge{border:1px solid #ddd;border-radius:999px;display:inline-block;font-size:12px;margin-right:6px;padding:2px 8px}.kv{grid-gap:8px 12px;display:grid;gap:8px 12px;grid-template-columns:140px 1fr}.kv dt{color:#666}.kv dd{margin:0}.table.table-tight td,.table.table-tight th{padding:8px 10px;vertical-align:middle}.role-badge{margin-bottom:4px;margin-right:6px}.table-hover tbody tr:hover{background:#fafafa}.click-hint td:last-child .btn.btn-small{opacity:.85}.click-hint:hover td:last-child .btn.btn-small{opacity:1}.btn-small{font-size:12px;padding:4px 10px}.panel-head{gap:12px;justify-content:space-between}.panel-head,.panel-head .tools{align-items:center;display:flex}.panel-head .tools{gap:8px}.home-page{display:flex;flex-direction:column;min-height:calc(100vh - 200px)}.hero-section{background:linear-gradient(135deg,#0b3d91,#1e5ba8 50%,#2d74c4);border-radius:16px;box-shadow:0 4px 20px #0b3d9126;margin-bottom:40px;padding:60px 40px;text-align:center}.hero-content{margin:0 auto;max-width:700px}.hero-title{color:#fff;font-size:42px;font-weight:800;margin:0 0 16px;text-shadow:0 2px 4px #0000001a}.hero-subtitle{color:#ffffffe6;font-size:20px;font-weight:400;margin:0}.feature-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto;max-width:1000px}.feature-card{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:32px 24px;text-align:center;transition:all .2s ease}.feature-card:hover{border-color:#0b3d91;border-color:var(--blue);box-shadow:0 8px 24px #0b3d9126;transform:translateY(-4px)}.feature-icon{font-size:48px;margin-bottom:8px}.feature-title{color:#111;color:var(--text);font-size:20px;font-weight:700;margin:0}.feature-description{color:#667085;color:var(--muted);font-size:14px;line-height:1.5;margin:0}.btn-home{align-items:center;background:#fff;border:2px solid #0b3d91;border:2px solid var(--blue);border-radius:8px;box-shadow:0 2px 8px #0b3d9126;color:#0b3d91;color:var(--blue);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;position:fixed;right:20px;top:70px;transition:all .2s ease;z-index:100}.btn-home:hover{background:#0b3d91;background:var(--blue);box-shadow:0 4px 12px #0b3d9140;color:#fff;transform:translateY(-2px)}.table-fixed{table-layout:fixed;width:100%}.table-fixed td,.table-fixed th,.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roles-wrap{display:flex;flex-wrap:wrap;gap:6px}.reef-location{color:#667085;font-size:.85rem;font-weight:500}.reef-error,.reef-loading{color:#667085;font-size:.9rem;padding:20px;text-align:center}.reef-error{color:#dc2626}.reef-content{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-top:8px}.reef-weather-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;padding:14px}.weather-header h3{font-size:.95rem;font-weight:600;margin:0 0 8px;opacity:.9}.weather-summary{font-size:.95rem;margin-bottom:10px;opacity:.95}.weather-temp{align-items:flex-start;display:flex;margin-bottom:6px}.temp-value{font-size:2.5rem;font-weight:300;line-height:1}.temp-unit{font-size:1.2rem;margin-left:4px;margin-top:6px;opacity:.9}.weather-feels-like{font-size:.85rem;opacity:.85}.reef-news-ticker{background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px;min-height:160px;padding:14px}.news-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.news-header h3{color:#111;font-size:.95rem;font-weight:600;margin:0}.news-indicators{display:flex;gap:5px}.news-dot{background:#d1d5db;border-radius:50%;height:7px;transition:all .3s ease;width:7px}.news-dot.active{background:#0b3d91;transform:scale(1.15)}.news-content{min-height:100px}.news-item{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.news-title{color:#111;font-size:.95rem;font-weight:500;line-height:1.3;margin:0 0 8px}.news-meta{align-items:center;color:#667085;display:flex;font-size:.8rem;justify-content:space-between;margin-bottom:10px}.news-source{font-weight:500}.news-time{color:#9ca3af}.news-link{color:#0b3d91;display:inline-block;font-size:.85rem;font-weight:500;text-decoration:none;transition:color .2s ease}.news-link:hover{color:#083270;text-decoration:underline}@media (max-width:768px){.reef-content{grid-template-columns:1fr}.temp-value{font-size:2rem}.temp-unit{font-size:1rem}}
/*# sourceMappingURL=main.246e7eb0.css.map*/