:root{--brand-dark: rgb(88, 61, 27);--brand-darker: rgb(55, 38, 17);--brand-medium: rgb(149, 104, 45);--brand-light: rgb(160, 144, 123);--brand-lighter: rgb(227, 220, 211);--brand-green-dark: #314c3b;--brand-green-darker: #253b2e;--color-background: #AADAFF;--text-dark: #333333;--text-light: #777777;--text-subtle: rgba(153, 153, 153, .5);--border-color: #cccccc;--border-color-dark: #333333;--surface-bg: rgba(255, 255, 255, .8);--surface-bg-dim: rgba(255, 255, 255, .8);--surface-bg-dim-light: rgba(255, 255, 255, .4);--border-radius: 8px;--shadow-main: 0 3px 10px rgb(0 0 0 / .4);--font-primary: "Raleway", sans-serif;--font-secondary: "Lato", sans-serif;--font-handwriting: "Sue Ellen Francisco", cursive}html,body{padding:0;margin:0;background-color:var(--color-background);overflow:hidden;width:100%;height:100%;font-family:var(--font-secondary);box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}.button-base,.btn{font-family:var(--font-primary);font-weight:900;text-transform:uppercase;background-color:var(--surface-bg-dim);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid grey;border-radius:var(--border-radius);box-shadow:0 2px 8px #0003;cursor:pointer;padding:.5rem 1rem;transition:all .2s;color:var(--brand-dark)}.button-base:hover,.btn:hover{background-color:#ffffffe6;transform:translateY(-1px)}.btn.primary{background-color:var(--brand-medium);color:#fff;border-color:var(--brand-dark)}.btn.primary:hover{background-color:var(--brand-dark)}.btn.secondary{background-color:var(--surface-bg);color:var(--brand-dark)}#map-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}#sidebar{position:absolute;top:10px;left:10px;width:500px;bottom:10px;z-index:10;background-color:var(--surface-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-main);display:flex;flex-direction:column;transition:transform .3s ease-in-out}#btn-mobile-menu{position:absolute;top:10px;left:10px;z-index:20;background-color:var(--surface-bg);border:2px solid var(--border-color);border-radius:50%;width:48px;height:48px;display:none;align-items:center;justify-content:center;box-shadow:var(--shadow-main);color:var(--brand-dark)}.mobile-only{display:none!important}.brand{padding:1rem;border-bottom:1px solid var(--border-color);background-color:#ffffff4d}.brand h1{margin:0;font-family:var(--font-primary);color:var(--brand-dark);font-size:1.5rem;font-weight:900;text-transform:uppercase}.sidebar-actions{padding:1rem;border-bottom:1px solid var(--border-color)}#voyage-list{flex:1;overflow-y:auto;padding:1rem}.list-item,.voyage-item{background-color:var(--surface-bg-dim-light);border:1px solid var(--border-color);border-radius:var(--border-radius);margin-bottom:5px;box-shadow:0 2px 8px #0000001a;padding:.75rem;cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.voyage-info{flex:1}.voyage-actions{display:flex;gap:.5rem;margin-left:.5rem}.btn-icon{background:none;border:none;cursor:pointer;padding:.2rem;color:var(--text-light);transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon .material-symbols-outlined{font-size:20px}.btn-icon:hover{color:var(--brand-medium);transform:scale(1.1)}.btn-icon.delete:hover,.btn-icon.delete-stop:hover{color:#d9534f}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(-360deg)}}.list-item:hover,.voyage-item:hover{background-color:#fff9;border-color:var(--brand-medium)}.voyage-item h3{margin:0 0 .3rem;font-family:var(--font-primary);font-weight:900;color:var(--brand-dark);font-size:1.1rem}.voyage-item p{margin:0;font-family:var(--font-secondary);color:var(--text-light);font-size:.9rem}#itinerary-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.voyage-header{padding:1rem;background-color:#ffffff4d;border-bottom:1px solid var(--border-color)}.voyage-header h2{margin:0;font-family:var(--font-primary);color:var(--brand-dark);font-size:1.2rem}#itinerary-list{flex:1;overflow-y:auto;padding:1rem}.day-item{background-color:var(--surface-bg-dim-light);border:1px solid var(--border-color);border-radius:var(--border-radius);margin-bottom:5px;padding:.75rem;cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.day-item:hover{background-color:#fff9}.day-item.selected{border-color:var(--brand-medium);border-width:2px;background-color:#95682d1a}.day-date{font-family:var(--font-primary);font-weight:900;color:var(--brand-dark)}.day-location{font-family:var(--font-secondary);color:var(--text-light);font-style:italic}.day-location.set{color:var(--brand-green-dark);font-style:normal;font-weight:700}.hidden{display:none!important}#modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:100}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--surface-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-main);padding:2rem;width:90%;max-width:400px;z-index:101}#modal-region-briefing{border-radius:20px}.modal h2{margin-top:0;font-family:var(--font-primary);font-weight:900;color:var(--brand-dark)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-family:var(--font-primary);font-weight:900;color:var(--brand-dark);font-size:.9rem}.form-group input{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;font-family:var(--font-secondary);font-size:1rem;background-color:#ffffffb3}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.marker span{font-family:var(--font-handwriting);width:45px;height:45px;background:#b8a48acc;border:solid 2px var(--brand-green-dark);border-radius:0 70% 70%;transform:rotate(-225deg);display:flex;justify-content:center;align-items:center;font-size:1.2rem;box-shadow:0 0 2px #000;color:var(--brand-dark)}.marker b{display:block;transform:rotate(225deg)}.briefing-body h3{font-family:var(--font-primary);color:var(--brand-medium);border-bottom:1px solid var(--border-color);padding-bottom:.3rem;margin-top:1.5rem}.briefing-body h4{margin:.5rem 0;color:var(--brand-dark)}.briefing-section{margin-bottom:1.5rem}.briefing-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.weather-box,.tide-box{background:#ffffff80;padding:1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);border-left:3px solid var(--brand-medium)}.facility-list{list-style:none;padding:0}.facility-item{background:#ffffff80;padding:.8rem;border-radius:var(--border-radius);border-left:3px solid var(--brand-medium);margin-bottom:5px}#user-floating-menu img.avatar{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color);object-fit:cover}@media (max-width: 768px){#btn-mobile-menu{display:flex}.mobile-only{display:flex!important}#sidebar{top:0;left:0;bottom:0;width:100%;height:100%;border-radius:0;border:none;z-index:200;transform:translate(-100%)}#app.menu-open #sidebar{transform:translate(0)}#modal-overlay{z-index:1000}.modal{width:100%!important;max-width:none!important;height:100%!important;max-height:none!important;top:0;left:0;transform:none;border-radius:0;display:flex;flex-direction:column;border:none;z-index:1001;padding:1rem}.briefing-body,.report-body,.modal-content-scroll{flex:1;overflow-y:auto;padding-left:0!important;padding-right:0!important}.briefing-grid{grid-template-columns:1fr}.briefing-table,.briefing-table tbody,.briefing-table tr,.briefing-table th,.briefing-table td{display:block;width:100%!important;box-sizing:border-box}.briefing-table tr{padding:.5rem 0;border-bottom:1px solid var(--border-color)}.briefing-th{background:none!important;color:var(--text-light);font-size:.75rem;text-transform:uppercase;padding-bottom:0!important}.briefing-td{padding-top:0!important}.briefing-table-label-width{width:auto!important;white-space:normal!important}.overview-table,.overview-table tbody,.overview-table tr,.overview-table td{display:block;width:100%!important;box-sizing:border-box;border-spacing:0}.overview-card{width:100%!important;margin-bottom:1rem;min-width:0!important}}#research-ticker{margin:1rem;padding:.8rem;background-color:var(--surface-bg-dim);border:1px solid var(--border-color);border-radius:var(--border-radius);display:flex;align-items:center;gap:10px;box-shadow:inset 0 2px 4px #0000000d}#research-ticker .material-symbols-outlined{color:var(--brand-medium)}#ticker-text{margin:0;font-family:var(--font-secondary);color:var(--text-dark);font-size:.9rem;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .3s ease-in-out}.report-body{font-family:var(--font-secondary);color:var(--text-dark)}.report-body img,.report-body canvas{border:1px solid var(--border-color-dark)}.report-day-header{padding:.8rem;border-left:5px solid var(--brand-medium);color:var(--brand-dark);font-family:var(--font-primary);margin-top:0;margin-bottom:.5rem;border-radius:0 var(--border-radius) var(--border-radius) 0}.report-day-date{margin-bottom:1.5rem;color:var(--text-light);font-family:var(--font-primary);padding-left:1rem}.briefing-header-icon{display:flex;align-items:center;gap:.5rem}.briefing-table{width:100%;margin-top:1rem;border-collapse:collapse;font-size:.9em;color:var(--text-dark)}.briefing-table thead{background:#0000000d;border-bottom:1px solid var(--border-color)}.briefing-th{text-align:left;font-weight:700;padding:4px 8px;vertical-align:top;background-color:var(--brand-lighter)}.briefing-td{padding:4px 8px;vertical-align:top}.briefing-td-icon{display:flex;align-items:center;gap:.5rem}.briefing-table-label-width{width:20ch;white-space:nowrap}.briefing-note{font-size:.8em;color:#999;margin-top:.5rem}.briefing-no-data{padding:8px}#auth-container{position:absolute;top:10px;right:50px;z-index:50}#user-floating-menu{background-color:var(--surface-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-main);padding:5px 10px 5px 5px;display:flex;align-items:center;gap:8px}#user-floating-menu img.avatar{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color);object-fit:cover;background-color:#ccc}#user-floating-menu .menu-actions{display:flex;gap:5px;border-left:1px solid var(--border-color);padding-left:8px}#user-floating-menu .btn-icon{background:none;border:1px solid transparent;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-dark);transition:all .2s;padding:0}#user-floating-menu .btn-icon:hover{background-color:#0000001a;color:var(--brand-dark)}#btn-login-floating{display:block}.login-btn-full{width:100%;display:block;box-sizing:border-box;text-align:center;padding:1rem;font-size:1.1rem}.report-body h3{color:var(--brand-dark);margin-top:1.5rem;margin-bottom:.5rem;border-bottom:1px solid #cccccc;padding-bottom:4px}.report-body h4{margin:.5rem 0;font-size:1.1rem;color:var(--brand-dark)}.report-day-header.brand-blue{border-left-color:#0077be}.report-day-header.brand-green{border-left-color:var(--brand-green-dark)}.w-auto{width:auto!important}#auth-container.full-screen-modal{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background-image:url(https://images.unsplash.com/photo-1534008897995-27a23e859048?ixlib=rb-4.0.3&auto=format&fit=crop&w=1920&q=80);background-size:cover;background-position:center;display:flex;justify-content:center;align-items:center;z-index:2000}#auth-container.full-screen-modal:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;z-index:-1}.login-box{background-color:var(--surface-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-main);padding:3rem;text-align:center;max-width:400px;width:90%;z-index:1}.login-box h1{font-family:var(--font-primary);color:var(--brand-dark);margin-top:0;margin-bottom:1rem;font-size:2.5rem}.login-box p{font-family:var(--font-secondary);color:var(--text-dark);margin-bottom:2rem;font-size:1.1rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-around{justify-content:space-around}.align-center{align-items:center}.align-start{align-items:flex-start}.gap-xs{gap:.2rem}.gap-sm{gap:.5rem}.gap-md{gap:1rem}.w-full{width:100%}.h-full{height:100%}.text-center{text-align:center}.text-right{text-align:right}.text-gray{color:#666}.text-dark{color:var(--text-dark)}.font-sm{font-size:.8rem}.font-xs{font-size:.9em}.mt-0{margin-top:0}.mt-xs{margin-top:.2rem}.mt-sm{margin-top:.5rem}.mt-md{margin-top:1rem}.mb-sm{margin-bottom:.5rem}.mb-md{margin-bottom:1rem}.ml-md{margin-left:1rem}.ml-sm{margin-left:.5rem}.p-sm{padding:.5rem}.relative{position:relative}.icon-align{vertical-align:middle}.icon-bottom{vertical-align:text-bottom}.icon-sm{font-size:12px}.icon-md{font-size:1rem}.icon-lg{font-size:1.2rem}.icon-xl{font-size:1.5rem}.capitalize{text-transform:capitalize}.modal-scrollable{max-width:800px;max-height:90vh;overflow-y:auto}.modal-header-row{border-bottom:1px solid #ddd;padding-bottom:.5rem;margin-bottom:1rem}.modal-content-scroll{flex:1;overflow-y:auto;padding:1rem}.loading-state{text-align:center;padding:3rem;color:#666}.loading-icon{font-size:3rem;margin-bottom:1rem}.error-state{text-align:center;padding:2rem;color:#d9534f}.error-text{color:red}.overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;width:100%;margin-bottom:1rem;box-sizing:border-box}.overview-grid.grid-cols-1{grid-template-columns:1fr}.overview-grid.grid-cols-2{grid-template-columns:repeat(2,1fr)}.overview-grid.grid-cols-3{grid-template-columns:repeat(3,1fr)}.overview-grid.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1000px){.overview-grid,.overview-grid.grid-cols-4,.overview-grid.grid-cols-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.overview-grid,.overview-grid.grid-cols-4,.overview-grid.grid-cols-3,.overview-grid.grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.overview-grid,.overview-grid.grid-cols-4,.overview-grid.grid-cols-3,.overview-grid.grid-cols-2,.overview-grid.grid-cols-1{grid-template-columns:1fr}}.overview-card{border:1px solid #ccc;border-radius:8px;padding:8px;background:#fff;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;min-width:0;box-sizing:border-box}.overview-date{font-weight:700;border-bottom:1px solid #eee;padding-bottom:5px;margin-bottom:5px;text-align:center;font-size:.9rem}.overview-location{font-size:.8rem;text-align:center;margin-bottom:5px;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-weather{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:5px}.overview-temp{font-size:1rem;font-weight:700}.overview-sun{display:flex;justify-content:space-around;font-size:.75rem;color:#666;margin-bottom:5px}.overview-chart{position:relative;height:120px;min-height:120px;width:100%}.overview-chart canvas{width:100%;height:100%}.report-title{text-align:center;border-bottom:2px solid #333;padding-bottom:.5rem}.report-dates{text-align:center;font-style:italic}.report-section-wrapper{margin-bottom:2rem;page-break-inside:avoid}.report-guide-bg{background:#00000008;padding:1rem;border-radius:8px}.report-map-container{margin-bottom:1.5rem;text-align:center}.report-map-img{max-width:100%;border-radius:4px;box-shadow:0 2px 4px #0000001a}.report-daily-wrapper{margin-bottom:3rem;page-break-inside:avoid}.ref-link{font-size:.8em;margin-top:.3rem;color:#666}.ref-anchor{margin-right:.3rem}.map-link-p{margin:.2rem 0;color:#666;font-size:.9em}.map-link-a{margin-left:5px}.facility-link{font-size:.8rem;margin-left:.5rem}.charter-list{padding-left:1.2rem;margin:.5rem 0}.no-data{color:#888;font-style:italic}.tide-chart-container{height:200px;width:100%;position:relative}#discovery-controls{position:absolute;bottom:30px;left:50%;transform:translate(-50%);background-color:var(--surface-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-main);padding:1rem 1.5rem;display:flex;align-items:center;gap:1.5rem;z-index:100;min-width:350px}.month-slider-container{flex:1;display:flex;flex-direction:column;gap:.5rem}.month-slider-container label{font-family:var(--font-primary);font-weight:900;font-size:1.1rem;color:var(--brand-dark)}#month-slider{width:100%;cursor:pointer}#month-display{color:var(--brand-medium)}.discovery-legend{display:flex;gap:1rem;justify-content:space-between;margin-top:.5rem;font-size:.75rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.25rem;color:var(--text-color);font-weight:500}.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot-standard{background-color:#0077be}.dot-regional{background-color:#ff9800}.dot-gem{background-color:#9c27b0}.dot-challenging{background-color:#d32f2f}.region-popup{max-width:250px}.region-popup h3{margin:0 0 .5rem;font-family:var(--font-primary)}.region-popup p{font-size:.9rem;margin:0 0 .5rem}.badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase}.badge-gem{background-color:#9c27b0;color:#fff}.badge-regional{background-color:#ff9800;color:#fff}.badge-standard{background-color:#0077be;color:#fff}.badge-challenging{background-color:#d32f2f;color:#fff}.bg-white{background-color:#fff}.shadow-sm{box-shadow:0 1px 3px #0000001a}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.text-xxl{font-size:2rem}.border-radius{border-radius:var(--border-radius)}.overflow-hidden{overflow:hidden}.brand-font{font-family:var(--font-primary)}.brand-blue{color:#0077be}.brand-green{color:var(--brand-green-dark)}.brand-red{color:#d9534f}.block{display:block}.mx-auto{margin-left:auto;margin-right:auto}.max-w-4xl{max-width:900px}.max-w-6xl{max-width:1200px}.p-md{padding:1rem}.p-lg{padding:1.5rem}.p-xl{padding:3rem}.mx-md{margin-left:1rem;margin-right:1rem}.btn-danger{color:#d9534f!important}.btn-danger:hover{color:#c9302c!important}.btn-text{background:none;border:none;padding:0;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem;font-weight:700}.shared-view{overflow-y:auto!important;background-color:#f5f5f5}.shared-container{margin-top:2rem;margin-bottom:2rem}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.text-left{text-align:left!important}.shared-report-content{max-width:800px;margin:2rem auto;padding:0 1rem;box-sizing:border-box}
