@layer reset,base,layout,components,utilities;@layer base{:root{--c-deep: oklch(.25 .06 240);--c-navy: oklch(.3 .08 240);--c-ocean: oklch(.45 .12 230);--c-teal: oklch(.6 .14 195);--c-aqua: oklch(.75 .12 195);--c-sky: oklch(.88 .06 220);--c-foam: oklch(.95 .02 220);--c-white: #ffffff;--c-dark: oklch(.15 .04 230);--c-coral: oklch(.65 .2 25);--c-coral-light:oklch(.8 .12 25);--c-report: oklch(.65 .18 55);--c-report-light: oklch(.85 .1 55);--c-easy: oklch(.65 .18 150);--c-medium: oklch(.7 .16 80);--c-hard: oklch(.6 .22 25);--c-gray-100: oklch(.96 .01 240);--c-gray-200: oklch(.9 .01 240);--c-gray-300: oklch(.8 .01 240);--c-gray-500: oklch(.6 .01 240);--c-gray-700: oklch(.4 .01 240);--c-gray-900: oklch(.2 .01 240);--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 30px rgba(0,0,0,.14);--shadow-card: 0 2px 8px rgba(0,0,0,.06);--ease: cubic-bezier(.4,0,.2,1);--dur: .2s;--ff: "Noto Sans KR", system-ui, sans-serif}}@layer reset{*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100dvh;font-family:var(--ff);font-size:15px;line-height:1.6;color:var(--c-gray-900);background:var(--c-foam)}body.app-view{height:100dvh;overflow:hidden;display:flex;flex-direction:column}img,svg{display:block;max-width:100%}button,input,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}}@layer layout{.landing{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:url(/Where2dive_first_background2.png) center / cover no-repeat,linear-gradient(180deg,#001e2b,#001324 40%,#000b16,#000214);background:url(/Where2dive_first_background2.png) center / cover no-repeat,linear-gradient(180deg,color(xyz 0.009 0.011 0.03),color(xyz 0.006 0.006 0.025) 40%,color(xyz 0.003 0.003 0.014),#000214);overflow:hidden}.landing.hidden{display:none}.landing__scene{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:none}.landing__svg{width:100%;height:100%}.light-ray{animation:lightRay 4s ease-in-out infinite}.light-ray--2{animation-delay:1s}.light-ray--3{animation-delay:2s}.light-ray--4{animation-delay:3s}.diver{opacity:0}.diver--1{animation:diverCycle 12s ease-in-out infinite}.diver--2{animation:diverCycle 12s ease-in-out 4s infinite}.diver--3{animation:diverCycle 12s ease-in-out 8s infinite}.marine{will-change:transform}.marine--turtle{animation:swimAcross 18s linear infinite;transform:translate(-100px)}.marine--turtle{animation-delay:0s}.marine--turtle g{transform-origin:center}.marine--shark{animation:swimAcross 14s linear infinite;animation-delay:6s;transform:translate(-100px)}.marine--hammerhead{animation:swimAcross 16s linear infinite;animation-delay:10s;transform:translate(-100px)}.bubble{animation:bubbleRise 6s ease-in infinite}.bubble--1{animation-duration:7s;animation-delay:0s}.bubble--2{animation-duration:5s;animation-delay:1.2s}.bubble--3{animation-duration:8s;animation-delay:.5s}.bubble--4{animation-duration:6s;animation-delay:2.5s}.bubble--5{animation-duration:7.5s;animation-delay:1.8s}.bubble--6{animation-duration:5.5s;animation-delay:3s}.bubble--7{animation-duration:6.5s;animation-delay:.8s}.bubble--8{animation-duration:7s;animation-delay:2s}.reg-bubble{animation:bubbleRise 4s ease-in infinite}.reg-bubble--1{animation-delay:0s;animation-duration:3s}.reg-bubble--2{animation-delay:1s;animation-duration:3.5s}.reg-bubble--3{animation-delay:2s;animation-duration:4s}.landing__card{position:relative;z-index:1;width:100%;max-width:380px;background:#ffffff14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:var(--sp-8) var(--sp-6);display:flex;flex-direction:column;align-items:center;gap:var(--sp-5);color:var(--c-white);box-shadow:0 8px 32px #0000004d}.landing__logo{display:flex;align-items:center;gap:var(--sp-3);font-size:1.6rem;font-weight:700;color:var(--c-white)}.landing__logo img{width:48px;height:48px;object-fit:contain}.landing__tagline{font-size:.95rem;color:#fff9;text-align:center}.landing__form{width:100%;display:flex;flex-direction:column;gap:var(--sp-3)}.landing__field{width:100%}.landing__input{width:100%;padding:var(--sp-3) var(--sp-4);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);background:#ffffff0f;color:var(--c-white);font-size:.9rem;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease)}.landing__input::placeholder{color:#ffffff59}.landing__input:focus{outline:none;border-color:var(--c-aqua);background:#ffffff1a}.landing__submit{width:100%;padding:var(--sp-3) var(--sp-4);border:none;border-radius:var(--r-md);background:var(--c-ocean);color:var(--c-white);font-size:.95rem;font-weight:600;cursor:pointer;transition:background var(--dur) var(--ease)}.landing__submit:hover{background:var(--c-teal)}.landing__error{font-size:.8rem;color:var(--c-coral-light);text-align:center}.landing__field-error{font-size:.75rem;color:var(--c-coral-light);margin-top:var(--sp-1)}.landing__field-error--success{color:var(--c-easy)}.landing__nickname-row{display:flex;gap:var(--sp-2)}.landing__nickname-row .landing__input{flex:1;min-width:0}.landing__check-btn{flex-shrink:0;padding:var(--sp-2) var(--sp-3);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-md);background:#ffffff14;color:var(--c-white);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--dur) var(--ease)}.landing__check-btn:hover{background:#ffffff26}.landing__check-btn:disabled{opacity:.5;cursor:not-allowed}.landing__submit:disabled{opacity:.45;cursor:not-allowed}.landing__submit:disabled:hover{background:var(--c-ocean)}.landing__terms{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-2)}.landing__terms-divider{height:1px;background:#ffffff1a;margin:var(--sp-1) 0}.landing__terms-item{display:flex;align-items:center;gap:var(--sp-2);cursor:pointer;font-size:.8rem;color:#ffffffbf;position:relative}.landing__terms-item--all{font-weight:600;color:var(--c-white);font-size:.85rem}.landing__terms-item input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.landing__terms-check{flex-shrink:0;width:18px;height:18px;border:1.5px solid rgba(255,255,255,.3);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all var(--dur) var(--ease)}.landing__terms-check:after{content:"";width:10px;height:10px;border-radius:2px;background:var(--c-aqua);transform:scale(0);transition:transform var(--dur) var(--ease)}.landing__terms-item input:checked+.landing__terms-check{border-color:var(--c-aqua)}.landing__terms-item input:checked+.landing__terms-check:after{transform:scale(1)}.landing__terms-label{flex:1;line-height:1.3}.landing__terms-tag{font-size:.7rem;font-weight:600}.landing__terms-tag--req{color:var(--c-coral-light)}.landing__terms-tag--opt{color:#fff6}.landing__terms-link{flex-shrink:0;font-size:.7rem;color:var(--c-aqua);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.landing__terms-link:hover{color:var(--c-white)}.landing__recovery{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);width:100%}.landing__recovery-link{background:none;border:none;color:#ffffff80;font-size:.78rem;cursor:pointer;transition:color var(--dur) var(--ease)}.landing__recovery-link:hover{color:var(--c-aqua)}.landing__recovery-sep{color:#fff3;font-size:.75rem}.landing__recovery-form{width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.landing__recovery-title{font-size:1rem;font-weight:600;color:var(--c-white);text-align:center;margin:0}.landing__recovery-msg{font-size:.8rem;text-align:center;line-height:1.4;word-break:break-all}.landing__recovery-msg--success{color:var(--c-easy)}.landing__recovery-msg--error{color:var(--c-coral-light)}.landing__recovery-desc{font-size:.82rem;color:#fff9;text-align:center;margin:0 0 .6rem}.find-account-result{margin-top:.8rem;padding:.8rem;border-radius:8px;background:#ffffff0f;text-align:center;font-size:.85rem;line-height:1.6;color:var(--c-white)}.find-account-result p{margin:.2rem 0}.find-result--success{color:var(--c-easy);font-weight:600}.find-result--fail{color:var(--c-coral-light);font-weight:600}.find-account-result .landing__submit{margin-top:.6rem;width:100%}.landing__back-link{background:none;border:none;color:#ffffff73;font-size:.78rem;cursor:pointer;transition:color var(--dur) var(--ease)}.landing__back-link:hover{color:var(--c-aqua)}.landing__demo{font-size:.75rem;color:#fff6;text-align:center}.landing__tabs{display:flex;width:100%;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);overflow:hidden}.landing__tab{flex:1;padding:var(--sp-2);background:transparent;color:#ffffff80;font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--dur) var(--ease);border:none}.landing__tab.active{background:var(--c-ocean);color:var(--c-white)}.landing__tab:hover:not(.active){color:#fffc;background:#ffffff0f}.landing__divider{width:100%;display:flex;align-items:center;gap:var(--sp-3);color:#ffffff59;font-size:.8rem}.landing__divider:before,.landing__divider:after{content:"";flex:1;height:1px;background:#ffffff26}.landing__google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-md);background:#ffffff0f;color:var(--c-white);font-size:.9rem;cursor:pointer;transition:background var(--dur) var(--ease)}.landing__google-btn:hover{background:#ffffff1f}.landing__google-btn svg{flex-shrink:0;display:inline-block}.landing__lang{display:inline-flex;align-self:center;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-full);overflow:hidden}.landing__lang .lang-toggle__btn{color:#ffffff80}.landing__lang .lang-toggle__btn:hover{color:var(--c-white);background:#ffffff14}.landing__lang .lang-toggle__btn.active{background:var(--c-ocean);color:var(--c-white)}.landing__lang .lang-select{background:#ffffff1a;border-color:#ffffff4d;color:#fffc}.app-hidden{display:none!important}.header__logout{padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-size:.75rem;font-weight:600;color:var(--c-gray-300);border:1px solid var(--c-ocean);background:transparent;cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap;margin-left:var(--sp-2);position:relative;z-index:10}.header__logout:hover{color:var(--c-white);background:#ffffff14;border-color:var(--c-coral)}.header__login{padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-size:.75rem;font-weight:600;color:var(--c-white);border:1px solid var(--c-ocean);background:var(--c-ocean);cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap;margin-left:var(--sp-2);position:relative;z-index:10}.header__login:hover{background:#007e9a;background:oklch(.55 .15 220);border-color:#007e9a;border-color:oklch(.55 .15 220)}@keyframes diverCycle{0%,8%{opacity:0}12%,28%{opacity:1}33%,to{opacity:0}}@keyframes swimAcross{0%{transform:translate(-100px,300px)}25%{transform:translate(25vw,280px)}50%{transform:translate(50vw,320px)}75%{transform:translate(75vw,290px)}to{transform:translate(calc(100vw + 100px),310px)}}@keyframes bubbleRise{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:1}50%{transform:translateY(-450px) translate(15px)}to{transform:translateY(-920px) translate(-10px);opacity:0}}@keyframes lightRay{0%,to{opacity:.03}50%{opacity:.08}}}@layer layout{.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}.hidden{display:none!important}.header{position:sticky;top:0;z-index:900;background:var(--c-deep);color:var(--c-white);box-shadow:var(--shadow-md);flex-shrink:0}.header__inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-3) var(--sp-6)}.header__logo{display:flex;align-items:center;gap:var(--sp-2);font-weight:700;font-size:1.2rem;white-space:nowrap;color:var(--c-white)}.header__icon{flex-shrink:0;width:32px;height:32px;object-fit:contain}.header__nav{display:flex;gap:var(--sp-1);margin-left:auto}.nav-btn{padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);font-size:.875rem;font-weight:500;color:var(--c-gray-300);transition:all var(--dur) var(--ease)}.nav-btn:hover{color:var(--c-white);background:#ffffff14}.nav-btn.active{color:var(--c-white);background:var(--c-ocean)}.lang-toggle{display:inline-flex;border:1px solid var(--c-ocean);border-radius:var(--r-full);overflow:hidden;margin-left:var(--sp-2);flex-shrink:0}.lang-toggle__btn{padding:var(--sp-1) var(--sp-3);font-size:.75rem;font-weight:600;color:var(--c-gray-300);transition:all var(--dur) var(--ease);white-space:nowrap}.lang-toggle__btn:hover{color:var(--c-white);background:#ffffff14}.lang-toggle__btn.active{background:var(--c-ocean);color:var(--c-white)}.lang-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:#ffffff14;color:var(--c-gray-200);border:1px solid var(--c-ocean);border-radius:var(--r-full);padding:var(--sp-1) var(--sp-4) var(--sp-1) var(--sp-3);font-size:.75rem;font-weight:600;cursor:pointer;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2399aab5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:all var(--dur) var(--ease)}.lang-select:hover{background-color:#ffffff26;color:var(--c-white)}.lang-select:focus{border-color:var(--c-ocean-light);box-shadow:0 0 0 2px #0077b64d}.lang-select option{background:var(--c-dark);color:var(--c-gray-200)}.header__mobile-filter-toggle{display:none;align-items:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-full);font-size:.8rem;font-weight:500;color:var(--c-aqua);border:1px solid var(--c-ocean)}.filter-bar{background:var(--c-white);border-bottom:1px solid var(--c-gray-200);box-shadow:var(--shadow-sm);z-index:800;flex-shrink:0}.filter-bar__inner{max-width:1440px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-6)}.filter-group{flex:1 1 0;min-width:70px;display:flex;flex-direction:column;gap:2px}.filter-group--activity{flex:none;min-width:auto;flex-direction:row}.filter-group--country{flex:1 1 0;min-width:90px}.filter-label{font-size:.68rem;font-weight:600;color:var(--c-gray-500);white-space:nowrap;padding-left:2px;line-height:1}.filter-input,.filter-select{width:100%;padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-gray-200);border-radius:var(--r-md);background:var(--c-gray-100);font-size:.875rem;transition:border-color var(--dur) var(--ease);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--c-teal);box-shadow:0 0 0 3px #60c8be33}.filter-input::placeholder{color:var(--c-gray-300)}.filter-reset{padding:var(--sp-2) var(--sp-4);border-radius:var(--r-md);font-size:.8rem;font-weight:500;color:var(--c-gray-500);border:1px solid var(--c-gray-200);transition:all var(--dur) var(--ease);white-space:nowrap}.filter-reset:hover{color:var(--c-coral);border-color:var(--c-coral)}.main{flex:1;min-height:0;overflow:hidden}.main__inner{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:0;height:100%}.main__inner.show-list{grid-template-columns:1fr 360px}.cards-panel.map-hidden{display:none}.map-panel{position:relative;border-right:1px solid var(--c-gray-200)}.map{width:100%;height:100%;min-height:300px;z-index:1}.cards-panel{overflow-y:auto;padding:var(--sp-4) var(--sp-4);background:var(--c-foam)}.cards-panel__count{font-size:.8rem;color:var(--c-gray-500);margin-bottom:var(--sp-3);padding-left:var(--sp-1)}.cards-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-4)}.footer{text-align:center;padding:0;font-size:.6rem;color:var(--c-gray-500);border-top:1px solid var(--c-gray-200);background:var(--c-white);flex-shrink:0}.footer a{color:var(--c-ocean);text-decoration:underline}.footer a:hover{color:var(--c-teal)}}@layer components{.card{background:var(--c-white);border-radius:var(--r-lg);box-shadow:var(--shadow-card);padding:var(--sp-5);transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);display:flex;flex-direction:column;gap:var(--sp-3);cursor:default}.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.card__header{display:flex;justify-content:space-between;align-items:flex-start}.card__tag{display:inline-block;padding:2px 10px;border-radius:var(--r-full);font-size:.7rem;font-weight:500;background:var(--c-sky);color:var(--c-ocean)}.card__fav{font-size:1.3rem;line-height:1;color:var(--c-gray-300);transition:color var(--dur) var(--ease),transform var(--dur) var(--ease)}.card__fav:hover{transform:scale(1.2)}.card__fav.active{color:var(--c-coral)}.card__name{font-size:1.1rem;font-weight:700;color:var(--c-gray-900);line-height:1.3}.card__location{font-size:.8rem;color:var(--c-gray-500)}.card__stats{display:flex;gap:var(--sp-4);flex-wrap:wrap}.card__stat{display:flex;flex-direction:column;gap:2px}.card__stat-label{font-size:.7rem;color:var(--c-gray-500);text-transform:uppercase;letter-spacing:.03em}.card__stat-value{font-size:.9rem;font-weight:600;color:var(--c-gray-700)}.card__badges{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.badge{display:inline-block;padding:2px 8px;border-radius:var(--r-full);font-size:.7rem;font-weight:500;background:var(--c-gray-100);color:var(--c-gray-700)}.badge--season{background:var(--c-aqua);color:var(--c-deep)}.badge--activity{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:var(--r-full)}.badge--activity-skin{background:color-mix(in oklch,var(--c-teal) 18%,white);color:var(--c-ocean)}.badge--activity-scuba{background:color-mix(in oklch,var(--c-ocean) 18%,white);color:var(--c-deep)}.activity-toggle{display:inline-flex;border:1px solid var(--c-gray-200);border-radius:var(--r-md);overflow:hidden;background:var(--c-gray-100)}.activity-toggle__btn{display:flex;align-items:center;gap:4px;padding:var(--sp-2) var(--sp-3);font-size:.8rem;font-weight:500;color:var(--c-gray-500);border-right:1px solid var(--c-gray-200);transition:all var(--dur) var(--ease);white-space:nowrap}.activity-toggle__count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 5px;border-radius:var(--r-full);font-size:.65rem;font-weight:700;background:var(--c-gray-200);color:var(--c-gray-500);line-height:1}.activity-toggle__btn.active .activity-toggle__count{background:#ffffff40;color:var(--c-white)}.activity-toggle__btn:last-child{border-right:none}.activity-toggle__btn:hover{color:var(--c-gray-700);background:var(--c-gray-200)}.activity-toggle__btn.active{background:var(--c-ocean);color:var(--c-white)}.autocomplete{position:relative}.autocomplete .filter-input{padding-right:2rem}.autocomplete__clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--c-gray-500);border-radius:50%;transition:color var(--dur) var(--ease)}.autocomplete__clear:hover{color:var(--c-coral)}.autocomplete__list{position:absolute;top:100%;left:0;right:0;z-index:900;max-height:220px;overflow-y:auto;background:var(--c-white);border:1px solid var(--c-gray-200);border-radius:var(--r-md);box-shadow:var(--shadow-md);margin-top:4px}.autocomplete__item{padding:var(--sp-2) var(--sp-3);font-size:.85rem;color:var(--c-gray-700);cursor:pointer;transition:background var(--dur) var(--ease)}.autocomplete__item:hover,.autocomplete__item.active{background:var(--c-sky);color:var(--c-ocean)}.card__difficulty{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;padding:2px 10px;border-radius:var(--r-full)}.card__difficulty--beginner{background:color-mix(in oklch,var(--c-easy) 20%,white);color:var(--c-easy)}.card__difficulty--intermediate{background:color-mix(in oklch,var(--c-medium) 20%,white);color:var(--c-medium)}.card__difficulty--advanced{background:color-mix(in oklch,var(--c-hard) 20%,white);color:var(--c-hard)}.card__difficulty-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.card__actions{display:flex;gap:var(--sp-2);margin-top:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);border-radius:var(--r-md);font-size:.85rem;font-weight:600;transition:all var(--dur) var(--ease);white-space:nowrap}.btn--primary{background:var(--c-ocean);color:var(--c-white)}.btn--primary:hover{background:var(--c-teal)}.btn--secondary{background:var(--c-gray-100);color:var(--c-gray-700);border:1px solid var(--c-gray-200)}.btn--secondary:hover{border-color:var(--c-gray-300);background:var(--c-gray-200)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-12) var(--sp-4);text-align:center;color:var(--c-gray-500)}.empty-state p{font-size:.95rem}.empty-state__sub{font-size:.8rem;color:var(--c-gray-300)}.marker{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 3px 8px #00000059;border:2.5px solid var(--c-white)}.marker--beginner{background:var(--c-easy)}.marker--intermediate{background:var(--c-medium)}.marker--advanced{background:var(--c-hard)}.marker__inner{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:none;transform:rotate(45deg)}.marker__inner svg{display:block;width:20px;height:20px;overflow:visible}.popup{min-width:220px;padding:12px 14px 10px}.popup__name{font-weight:700;font-size:1rem;margin-bottom:4px}.popup__location{font-size:.75rem;color:#64748b;margin-bottom:8px}.popup__badges{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:4px;margin-bottom:8px}.popup__badge{flex-shrink:0;font-size:.7rem;padding:2px 7px;border-radius:99px;background:#e2e8f0;color:#334155}.popup__badge--beginner{background:#dcfce7;color:#166534}.popup__badge--intermediate{background:#ffedd5;color:#9a3412}.popup__badge--advanced{background:#fee2e2;color:#991b1b}.popup__marine{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.popup__marine-tag{font-size:.68rem;padding:2px 6px;border-radius:99px;background:#e0f2fe;color:#0369a1}.popup__meta{font-size:.8rem;color:var(--c-gray-500);margin-bottom:8px}.popup__meta span{margin-right:8px}.popup__btn{display:block;width:100%;padding:4px 12px;border-radius:var(--r-sm);background:var(--c-ocean);color:var(--c-white);font-size:.8rem;font-weight:600;cursor:pointer;border:none;text-align:center}.popup__btn:hover{background:var(--c-teal)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--sp-4);animation:fadeIn var(--dur) var(--ease)}.modal{position:relative;background:var(--c-white);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);max-width:640px;width:100%;max-height:85dvh;overflow-y:auto;animation:slideUp .3s var(--ease)}.modal__close{position:sticky;top:0;float:right;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--c-gray-500);background:var(--c-white);border-radius:50%;margin:var(--sp-3) var(--sp-3) 0 0;z-index:2;box-shadow:var(--shadow-sm)}.modal__close:hover{color:var(--c-gray-900)}.modal__body{padding:0 var(--sp-6) var(--sp-6)}.modal__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-4)}.modal__title{font-size:1.4rem;font-weight:700;color:var(--c-gray-900);line-height:1.3}.modal__subtitle{font-size:.85rem;color:var(--c-gray-500);margin-top:2px}.modal__fav{font-size:1.5rem;color:var(--c-gray-300);transition:color var(--dur) var(--ease)}.modal__fav.active{color:var(--c-coral)}.modal__fav:hover{transform:scale(1.15)}.modal__desc{font-size:.9rem;color:var(--c-gray-700);line-height:1.7;margin-bottom:var(--sp-5)}.modal__section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--c-ocean);margin-bottom:var(--sp-3)}.modal__stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-5)}.modal__stat-card{background:var(--c-gray-100);border-radius:var(--r-md);padding:var(--sp-3);text-align:center}.modal__stat-card__label{font-size:.7rem;color:var(--c-gray-500);text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}.modal__stat-card__value{font-size:1rem;font-weight:700;color:var(--c-gray-900)}.modal__tags{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-5)}.modal__tag{padding:4px 12px;border-radius:var(--r-full);font-size:.78rem;font-weight:500;background:var(--c-sky);color:var(--c-ocean)}.modal__highlights{margin-bottom:var(--sp-5)}.modal__highlights li{font-size:.875rem;color:var(--c-gray-700);padding:var(--sp-1) 0;padding-left:var(--sp-5);position:relative}.modal__highlights li:before{content:"";position:absolute;left:0;top:10px;width:8px;height:8px;border-radius:50%;background:var(--c-teal)}.modal__location{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-bottom:var(--sp-5);padding:var(--sp-3) var(--sp-4);background:var(--c-gray-100);border-radius:var(--r-md);font-size:.85rem}.modal__location-coords{color:var(--c-gray-500);font-family:monospace}.modal__location-link{color:var(--c-ocean);text-decoration:none;font-weight:600;white-space:nowrap}.modal__location-link:hover{color:var(--c-teal)}.modal__actions{display:flex;gap:var(--sp-3);margin-top:var(--sp-5);padding-top:var(--sp-4);border-top:1px solid var(--c-gray-200)}.modal__action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3);border:1px solid var(--c-gray-200);border-radius:var(--r-md);background:var(--c-white);font-size:.85rem;font-weight:600;color:var(--c-deep);cursor:pointer;transition:all var(--dur) var(--ease)}.modal__action-btn:hover,.modal__action-btn--primary{background:var(--c-ocean);color:var(--c-white);border-color:var(--c-ocean)}.modal__action-btn--primary:hover{background:var(--c-deep);border-color:var(--c-deep)}.modal__action-btn--danger{color:var(--c-coral);border-color:var(--c-coral)}.modal__action-btn--danger:hover{background:var(--c-coral);color:var(--c-white)}.myspot-detail__content{margin-bottom:var(--sp-2)}.myspot-detail__row{display:flex;padding:var(--sp-3) 0;border-bottom:1px solid var(--c-gray-100);font-size:.9rem}.myspot-detail__row:last-child{border-bottom:none}.myspot-detail__label{min-width:90px;font-weight:600;color:var(--c-gray-500)}.myspot-detail__value{flex:1;color:var(--c-gray-900)}.modal__weather{background:linear-gradient(135deg,var(--c-deep),var(--c-navy));border-radius:var(--r-md);padding:var(--sp-5);color:var(--c-white);margin-bottom:var(--sp-4)}.modal__weather-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--c-aqua);margin-bottom:var(--sp-4)}.modal__weather-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--sp-3)}.weather-item{text-align:center}.weather-item__label{font-size:.7rem;color:var(--c-gray-300);margin-bottom:4px}.weather-item__value{font-size:1.1rem;font-weight:700}.weather-loading{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-4)}.weather-error{text-align:center;padding:var(--sp-3);font-size:.85rem}.weather-error__retry{display:inline-block;margin-top:var(--sp-2);padding:4px 14px;border-radius:var(--r-sm);background:var(--c-coral);color:var(--c-white);font-size:.8rem;font-weight:600;cursor:pointer;border:none}.dive-score-card{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);border-radius:var(--r-md);margin-bottom:var(--sp-4);background:#ffffff14}.dive-score-card__icon{font-size:2.4rem;line-height:1}.dive-score-card__info{flex:1}.dive-score-card__stars{margin-bottom:2px}.dive-star{font-size:1.1rem;color:#ffffff40}.dive-star--filled{color:#fbbf24}.dive-score-card__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--c-gray-300);margin-bottom:2px}.dive-score-card__msg{font-size:.85rem;font-weight:600}.dive-score-card--s5 .dive-score-card__msg{color:#34d399}.dive-score-card--s4 .dive-score-card__msg{color:#6ee7b7}.dive-score-card--s3 .dive-score-card__msg{color:#fbbf24}.dive-score-card--s2 .dive-score-card__msg{color:#fb923c}.dive-score-card--s1 .dive-score-card__msg{color:#f87171}.weather-forecast{margin-top:var(--sp-4)}.weather-forecast__title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--c-aqua);margin-bottom:var(--sp-3)}.weather-forecast__scroll{display:flex;gap:var(--sp-2);overflow-x:auto;padding-bottom:var(--sp-2);-webkit-overflow-scrolling:touch;scrollbar-width:thin}.weather-forecast__scroll::-webkit-scrollbar{height:4px}.weather-forecast__scroll::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.weather-forecast__day{flex:0 0 auto;width:72px;text-align:center;padding:var(--sp-3) var(--sp-2);border-radius:var(--r-sm);background:#ffffff0f;display:flex;flex-direction:column;align-items:center;gap:4px}.weather-forecast__day:first-child{background:#ffffff1f}.weather-forecast__day-label{font-size:.7rem;font-weight:600;color:var(--c-gray-200)}.weather-forecast__day-icon{font-size:1.4rem;line-height:1}.weather-forecast__day-temp{display:flex;gap:4px;font-size:.8rem;font-weight:600}.weather-forecast__temp-hi{color:var(--c-white)}.weather-forecast__temp-lo{color:var(--c-gray-400)}.weather-forecast__day-wave{font-size:.65rem;color:var(--c-gray-300)}.weather-forecast__day-stars{display:flex;gap:1px}.weather-forecast__day-stars .dive-star{font-size:.6rem}.spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--c-aqua);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.logbook-stats{margin-bottom:var(--sp-4)}.logbook-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-bottom:var(--sp-4)}.logbook-stats__card{background:linear-gradient(135deg,var(--c-deep),var(--c-navy));border-radius:var(--r-md);padding:var(--sp-3) var(--sp-2);text-align:center;color:var(--c-white)}.logbook-stats__icon{font-size:1.2rem;margin-bottom:2px}.logbook-stats__value{font-size:1.2rem;font-weight:700}.logbook-stats__label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--c-aqua);margin-top:2px}.stat-details{display:flex;flex-direction:column;gap:var(--sp-4);margin-bottom:var(--sp-4)}.stat-details__section{background:var(--c-white);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);box-shadow:0 1px 3px #0000000f}.stat-details__section h4{font-size:.85rem;font-weight:700;color:var(--c-deep);margin-bottom:var(--sp-3)}.stat-detail__row{display:flex;justify-content:space-between;padding:var(--sp-2) 0;border-bottom:1px solid var(--c-gray-100);font-size:.85rem}.stat-detail__row:last-child{border-bottom:none}.stat-detail__row span:first-child{color:var(--c-gray-500)}.stat-detail__row span:last-child{font-weight:600;color:var(--c-deep)}.stat-detail__list{list-style:none;padding:0;margin:0}.stat-detail__list li{display:flex;justify-content:space-between;padding:var(--sp-2) 0;border-bottom:1px solid var(--c-gray-100);font-size:.85rem}.stat-detail__list li:last-child{border-bottom:none}.stat-detail__count{font-weight:600;color:var(--c-ocean)}.stat-chart{display:flex;align-items:flex-end;gap:2px;height:100px;padding-top:var(--sp-2)}.stat-chart__col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.stat-chart__bar{width:100%;min-height:2px;background:linear-gradient(180deg,var(--c-ocean),var(--c-teal));border-radius:3px 3px 0 0;font-size:.6rem;color:var(--c-white);text-align:center;padding-top:2px;transition:height .3s ease}.stat-chart__label{font-size:.6rem;color:var(--c-gray-400);margin-top:4px;white-space:nowrap}.logbook-add-btn{margin-bottom:var(--sp-4);width:100%}.log-card{background:var(--c-white);border-radius:var(--r-lg);box-shadow:var(--shadow-card);padding:var(--sp-5);display:flex;flex-direction:row;gap:var(--sp-4);align-items:flex-start;margin-bottom:var(--sp-3)}.log-card__icons{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;padding-top:2px}.log-card__flag{font-size:1.8rem;line-height:1}.log-card__activity-wrap{display:flex;align-items:center;justify-content:center;width:36px;height:36px}.log-card__activity-icon{width:36px;height:36px;object-fit:contain}.log-card__header{display:flex;justify-content:space-between;align-items:center}.log-card__date{font-size:.8rem;color:var(--c-gray-500)}.log-card__spot{font-size:1rem;font-weight:700;color:var(--c-gray-900)}.log-card__stats{display:flex;gap:var(--sp-4);flex-wrap:wrap}.log-card__memo{font-size:.85rem;color:var(--c-gray-700);border-left:3px solid var(--c-aqua);padding-left:var(--sp-3);margin:var(--sp-1) 0}.log-card__actions{display:flex;gap:var(--sp-2);justify-content:flex-end}.log-card__actions button{padding:var(--sp-1) var(--sp-3);border-radius:var(--r-sm);font-size:.75rem;font-weight:600;border:1px solid var(--c-gray-200);color:var(--c-gray-500);transition:all var(--dur) var(--ease)}.log-card__actions button:hover{color:var(--c-ocean);border-color:var(--c-ocean)}.log-card__actions .log-delete-btn:hover{color:var(--c-coral);border-color:var(--c-coral)}.log-card--has-media{display:flex;flex-direction:row;gap:var(--sp-4);align-items:flex-start}.log-card__body{display:flex;flex-direction:column;gap:var(--sp-3);min-width:0;flex:1}.log-card__media{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-top:var(--sp-4)}.log-card__thumb{position:relative;width:100%;aspect-ratio:1;border-radius:var(--r-sm);overflow:hidden;cursor:pointer}.log-card__thumb img,.log-card__thumb video{width:100%;height:100%;object-fit:cover}.log-card__thumb--video:after{content:"▶";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--c-white);background:#00000059;pointer-events:none}.log-form{display:flex;flex-direction:column;gap:var(--sp-4)}.log-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.log-form__field{display:flex;flex-direction:column;gap:var(--sp-1)}.log-form__field label{font-size:.8rem;font-weight:600;color:var(--c-gray-700)}.log-form__field input,.log-form__field textarea,.log-form__field select{padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-gray-200);border-radius:var(--r-md);background:var(--c-gray-100);font-size:.875rem;transition:border-color var(--dur) var(--ease)}.log-form__field input:focus,.log-form__field textarea:focus,.log-form__field select:focus{outline:none;border-color:var(--c-teal);box-shadow:0 0 0 3px #60c8be33}.log-time-selects{display:flex;align-items:center;gap:var(--sp-1)}.log-time-select{padding:var(--sp-2) var(--sp-1);border:1px solid var(--c-gray-200);border-radius:var(--r-md);background:var(--c-gray-100);font-size:.875rem;transition:border-color var(--dur) var(--ease);min-width:0}.log-time-select:focus{outline:none;border-color:var(--c-teal);box-shadow:0 0 0 3px #60c8be33}.log-time-select--ampm{flex:0 0 auto}.log-time-select--hour,.log-time-select--min{flex:1 1 0}.log-time-colon{font-weight:700;font-size:.875rem;color:var(--c-gray-500)}.log-form__hint{font-size:.75rem;color:var(--c-gray-300)}.log-form__toggle{display:flex;gap:var(--sp-4)}.log-form__radio{display:flex;align-items:center;gap:var(--sp-1);font-size:.85rem;cursor:pointer}.log-activity-switch{display:flex;background:var(--c-gray-100);border-radius:var(--r-lg);padding:4px;gap:4px}.log-activity-switch__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border:none;border-radius:var(--r-md);background:transparent;color:var(--c-gray-500);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--dur) var(--ease)}.log-activity-switch__btn:hover{background:var(--c-gray-200);color:var(--c-gray-700)}.log-activity-switch__btn.active{background:var(--c-ocean);color:var(--c-white);box-shadow:0 2px 8px #00000026}.log-activity-switch__btn.active:hover{background:var(--c-ocean)}.log-activity-switch__icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.log-activity-switch__icon svg{width:18px;height:18px}.log-form__actions{display:flex;gap:var(--sp-3);justify-content:flex-end;margin-top:var(--sp-2)}.map-pick-row{display:flex;align-items:center;gap:var(--sp-3)}.map-pick-coords{font-size:.8rem;color:var(--c-gray-500)}.map-pick-banner{position:absolute;top:0;left:0;right:0;z-index:600;background:var(--c-deep);color:var(--c-white);padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;justify-content:center;gap:var(--sp-4);font-size:.9rem;font-weight:500}.map-pick-banner .btn{font-size:.8rem;padding:var(--sp-1) var(--sp-4)}#map.map--picking{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='40' viewBox='0 0 28 40'%3E%3Cpath d='M14 0C6.27 0 0 6.27 0 14c0 10.5 14 26 14 26s14-15.5 14-26C28 6.27 21.73 0 14 0z' fill='%23E74C3C' stroke='%23fff' stroke-width='1.5'/%3E%3Ccircle cx='14' cy='13' r='5' fill='%23fff'/%3E%3C/svg%3E") 14 40,crosshair!important}#map.map--picking .leaflet-container,#map.map--picking .leaflet-interactive,#map.map--picking .leaflet-pane,#map.map--picking .leaflet-tile-pane,#map.map--picking .leaflet-overlay-pane,#map.map--picking *{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='40' viewBox='0 0 28 40'%3E%3Cpath d='M14 0C6.27 0 0 6.27 0 14c0 10.5 14 26 14 26s14-15.5 14-26C28 6.27 21.73 0 14 0z' fill='%23E74C3C' stroke='%23fff' stroke-width='1.5'/%3E%3Ccircle cx='14' cy='13' r='5' fill='%23fff'/%3E%3C/svg%3E") 14 40,crosshair!important}.marker--personal{width:32px;height:32px;border-radius:50%;background:var(--c-coral);border:2px solid var(--c-white);box-shadow:0 0 8px #ff643c66;display:flex;align-items:center;justify-content:center;transform:none}.marker--personal svg{width:16px;height:16px}.card--personal{border-left:4px solid var(--c-coral)}.card__tag--personal{background:color-mix(in oklch,var(--c-coral) 18%,white);color:var(--c-coral)}.fab--add-spot{position:absolute;bottom:24px;right:24px;z-index:500;width:44px;height:44px;border-radius:50%;background:var(--c-coral);color:var(--c-white);font-size:1.4rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.fab--add-spot:hover{transform:scale(1.1);box-shadow:0 6px 18px #00000040}.info-fab{display:none}.footer__info-btn{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--c-ocean);color:var(--c-white);font-size:.6rem;font-weight:700;cursor:pointer;transition:background var(--dur) var(--ease);border:none;line-height:1;flex-shrink:0}.footer__info-btn:hover{background:var(--c-teal)}.info-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2100;background:#00000073;display:flex;align-items:center;justify-content:center;padding:var(--sp-4)}.info-modal{background:var(--c-white);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);max-width:480px;width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.info-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6) var(--sp-3)}.info-modal__title{font-size:1.1rem;font-weight:700;color:var(--c-gray-900);margin:0}.info-modal__close{width:32px;height:32px;font-size:1.3rem;line-height:1;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);transition:background var(--dur) var(--ease)}.info-modal__close:hover{background:var(--c-gray-100)}.info-modal__content{padding:var(--sp-2) var(--sp-6) var(--sp-4);overflow-y:auto;white-space:pre-line;line-height:1.75;font-size:.9rem;color:var(--c-gray-700)}.info-modal__footer{padding:var(--sp-3) var(--sp-6) var(--sp-5);display:flex;justify-content:center}.info-modal__ok{min-width:120px}.myspot-toggle{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);font-size:.8rem;font-weight:500;color:var(--c-gray-500);cursor:pointer;white-space:nowrap;border:1px solid var(--c-gray-200);border-radius:var(--r-md);transition:all var(--dur) var(--ease)}.myspot-toggle:hover{color:var(--c-coral);border-color:var(--c-coral)}.myspot-toggle input[type=checkbox]{accent-color:var(--c-coral)}.filter-bar.logbook-hidden{display:none}#log-scuba-fields.hidden{display:none!important}.page{max-width:800px;margin:0 auto;padding:var(--sp-8) var(--sp-6);line-height:1.8;color:var(--c-gray-900)}.page h1{font-size:2rem;font-weight:700;color:var(--c-deep);margin-bottom:var(--sp-6);line-height:1.3}.page h2{font-size:1.3rem;font-weight:700;color:var(--c-ocean);margin-top:var(--sp-8);margin-bottom:var(--sp-3)}.page h3{font-size:1.1rem;font-weight:600;color:var(--c-gray-700);margin-top:var(--sp-6);margin-bottom:var(--sp-2)}.page p{margin-bottom:var(--sp-4);color:var(--c-gray-700)}.page ul,.page ol{margin-bottom:var(--sp-4);padding-left:var(--sp-6)}.page ul{list-style:disc}.page ol{list-style:decimal}.page li{margin-bottom:var(--sp-2);color:var(--c-gray-700)}.page a{color:var(--c-ocean);text-decoration:underline}.page a:hover{color:var(--c-teal)}.policy-table{width:100%;border-collapse:collapse;margin-bottom:var(--sp-4);font-size:.9rem}.policy-table th,.policy-table td{border:1px solid var(--c-gray-200);padding:var(--sp-2) var(--sp-3);text-align:left;color:var(--c-gray-700)}.policy-table th{background:var(--c-gray-50, #f8f9fa);font-weight:600;color:var(--c-gray-900)}.guide-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:var(--sp-4);border-radius:var(--r-md);border:1px solid var(--c-gray-200)}.guide-table-wrap .policy-table{margin-bottom:0;border:none;min-width:520px}@media (max-width: 480px){.guide-table-wrap{border:none;overflow:visible}.guide-table-wrap .policy-table,.guide-table-wrap .policy-table thead,.guide-table-wrap .policy-table tbody,.guide-table-wrap .policy-table th,.guide-table-wrap .policy-table td,.guide-table-wrap .policy-table tr{display:block;min-width:unset}.guide-table-wrap .policy-table thead{display:none}.guide-table-wrap .policy-table tbody tr{border:1px solid var(--c-gray-200);border-radius:var(--r-md);margin-bottom:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--c-gray-50, #f8f9fa)}.guide-table-wrap .policy-table td{border:none;border-bottom:1px solid var(--c-gray-100);padding:var(--sp-2) 0;display:flex;gap:var(--sp-2)}.guide-table-wrap .policy-table td:last-child{border-bottom:none}.guide-table-wrap .policy-table td:before{content:attr(data-label);font-weight:600;color:var(--c-gray-900);min-width:60px;flex-shrink:0;font-size:.8rem}}.page code{background:var(--c-gray-50, #f8f9fa);padding:1px 5px;border-radius:3px;font-size:.85em}.contact-result{margin-top:var(--sp-4);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);font-weight:600;font-size:.9rem}.contact-result--success{background:#48bb781f;color:#276749}.contact-result--error{background:#f565651f;color:#c53030}.page .page__update{font-size:.85rem;color:var(--c-gray-500);margin-bottom:var(--sp-6)}.footer__inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:4px 20px 2px;text-align:left}.footer__section-title{font-size:.6rem;font-weight:700;color:var(--c-gray-700);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px;line-height:1.2;display:flex;align-items:center;gap:var(--sp-2)}.footer__links{display:flex;flex-direction:column;gap:0}.footer__links a{font-size:.6rem;line-height:1.6;color:var(--c-gray-500);text-decoration:none;transition:color var(--dur) var(--ease)}.footer__links a:hover{color:var(--c-ocean)}.footer__desc{font-size:.6rem;color:var(--c-gray-500);line-height:1.3}.footer__bottom{max-width:1000px;margin:0 auto;padding:2px 20px;border-top:1px solid var(--c-gray-200);text-align:center;font-size:.55rem;color:var(--c-gray-300)}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:1500;background:var(--c-deep);color:var(--c-white);padding:var(--sp-4) var(--sp-6);display:flex;align-items:center;justify-content:center;gap:var(--sp-4);font-size:.85rem;box-shadow:0 -2px 12px #0003}.cookie-banner.hidden{display:none}.cookie-banner__text{flex:1;max-width:700px;line-height:1.5}.cookie-banner__text a{color:var(--c-aqua);text-decoration:underline}.cookie-banner__btn{padding:var(--sp-2) var(--sp-5);border:none;border-radius:var(--r-md);background:var(--c-ocean);color:var(--c-white);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--dur) var(--ease)}.cookie-banner__btn:hover{background:var(--c-teal)}.cookie-banner__actions{display:flex;gap:var(--sp-2);flex-shrink:0}.cookie-banner__btn--all{background:var(--c-ocean);color:var(--c-white)}.cookie-banner__btn--essential{background:transparent;color:var(--c-gray-300);border:1px solid var(--c-gray-500)}.cookie-banner__btn--essential:hover{background:#ffffff1a}.page-header{background:var(--c-deep);color:var(--c-white);padding:var(--sp-4) var(--sp-6);display:flex;align-items:center;justify-content:space-between}.page-header__logo{display:flex;align-items:center;gap:var(--sp-2);font-weight:700;font-size:1.1rem;color:var(--c-white);text-decoration:none}.page-header__logo img{border-radius:4px}.page-header__nav{display:flex;gap:var(--sp-4)}.page-header__nav a{color:var(--c-gray-300);font-size:.85rem;text-decoration:none;transition:color var(--dur) var(--ease)}.page-header__nav a:hover{color:var(--c-white)}.page-header__nav .lang-toggle-btn,.page-header__nav .lang-select{background:#ffffff26;color:var(--c-white);border:1px solid rgba(255,255,255,.3);border-radius:var(--r-sm);padding:2px 10px;font-size:.75rem;font-weight:700;cursor:pointer;transition:background var(--dur) var(--ease);align-self:center}.page-header__nav .lang-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:20px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23ffffff'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.page-header__nav .lang-select option{background:var(--c-dark);color:var(--c-gray-200)}.page-header__nav .lang-toggle-btn:hover,.page-header__nav .lang-select:hover{background:#ffffff40}}@layer utilities{.leaflet-popup-content-wrapper{border-radius:var(--r-md)!important;font-family:var(--ff)!important;box-shadow:var(--shadow-md)!important}.leaflet-popup-content{margin:12px 16px!important}}@media (max-width: 1024px){.main__inner{grid-template-columns:1fr;height:100%}.main__inner.show-list{grid-template-columns:1fr}.map-panel{border-right:none;border-bottom:1px solid var(--c-gray-200);height:100%}.cards-panel{max-height:none}.cards-panel.map-hidden{display:none}}.mobile-activity-tabs{display:none}@media (max-width: 768px){.header__inner{padding:var(--sp-2) var(--sp-4)}.header__nav,.header__logout,.header__login{display:none}.lang-toggle:not(.mobile-drawer .lang-toggle){display:inline-flex;margin-left:auto;border-color:var(--c-ocean)}.lang-toggle:not(.mobile-drawer .lang-toggle) .lang-toggle__btn{padding:var(--sp-1) var(--sp-2);font-size:.7rem}.header__mobile-filter-toggle{display:inline-flex;margin-left:var(--sp-2)}.filter-bar{display:none!important}.filter-bar__inner{flex-direction:column;padding:var(--sp-3) var(--sp-4)}.filter-group,.filter-group--activity{min-width:100%}.activity-toggle{width:100%}.activity-toggle__btn{flex:1;text-align:center;justify-content:center}.mobile-activity-tabs{display:flex;align-items:center;gap:4px;padding:6px 8px;background:var(--c-white);border-bottom:1px solid var(--c-gray-200);flex-shrink:0}.mobile-activity-tabs.logbook-hidden{display:none}.mobile-activity-tabs__btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:2px;padding:6px 2px;border-radius:var(--r-full);background:var(--c-gray-100);color:var(--c-gray-700);font-size:.68rem;font-weight:500;white-space:nowrap;border:none;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.mobile-activity-tabs__btn.active{background:var(--c-ocean);color:var(--c-white)}.mobile-activity-tabs__count{display:inline-flex;align-items:center;justify-content:center;min-width:1.2em;padding:0 .2em;border-radius:var(--r-full);background:#ffffff40;font-size:.6rem;line-height:1.3}.mobile-activity-tabs__btn.active .mobile-activity-tabs__count{background:#ffffff4d}.main__inner{height:calc(100dvh - 148px)}.map-panel{height:100%}.map{min-height:unset}.cards-panel{padding:var(--sp-3);padding-bottom:calc(var(--sp-3) + 56px)}.footer{display:none}html,body{overflow-x:hidden}.logbook-stats__grid{grid-template-columns:repeat(2,1fr)}.log-form__grid{grid-template-columns:1fr}.log-card__media{gap:var(--sp-2)}.log-media-preview__item{width:64px;height:64px}.modal{max-width:100%;margin:var(--sp-2)}.modal__body{padding:0 var(--sp-4) var(--sp-4)}.cookie-banner{flex-direction:column;text-align:center;bottom:56px}.footer__inner{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;gap:var(--sp-2)}.page-header__nav{flex-wrap:wrap;justify-content:center;gap:var(--sp-3)}}.mobile-tab-bar{display:none}@media (max-width: 768px){.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:950;background:var(--c-deep);border-top:1px solid rgba(255,255,255,.08);height:56px;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#fff6;font-size:.6rem;font-weight:500;transition:color var(--dur) var(--ease);padding:var(--sp-1) 0;-webkit-tap-highlight-color:transparent}.mobile-tab svg{stroke:currentColor}.mobile-tab:hover,.mobile-tab.active{color:var(--c-aqua)}}.mobile-drawer-overlay,.mobile-drawer{display:none}@media (max-width: 768px){.mobile-drawer-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#00000080;opacity:0;transition:opacity .25s var(--ease);pointer-events:none}.mobile-drawer-overlay.visible{opacity:1;pointer-events:auto}.mobile-drawer-overlay.hidden{display:block;opacity:0;pointer-events:none}.mobile-drawer{display:flex;flex-direction:column;position:fixed;bottom:0;left:0;right:0;z-index:1200;background:var(--c-deep);border-radius:var(--r-lg) var(--r-lg) 0 0;max-height:70vh;transform:translateY(100%);transition:transform .3s var(--ease);overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-drawer.visible{transform:translateY(0)}.mobile-drawer.hidden{display:flex;transform:translateY(100%)}.mobile-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5) var(--sp-2)}.mobile-drawer__title{font-size:1rem;font-weight:700;color:var(--c-white)}.mobile-drawer__close{color:#ffffff80;font-size:1.5rem;line-height:1;padding:var(--sp-1)}.mobile-drawer__close:hover{color:var(--c-white)}.mobile-drawer__body{padding:var(--sp-2) var(--sp-5) var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-3)}.mobile-drawer__section{display:flex;flex-direction:column;gap:var(--sp-2)}.mobile-drawer__row{display:flex;align-items:center;justify-content:space-between;color:#ffffffb3;font-size:.85rem;padding:var(--sp-2) 0}.mobile-drawer__row .lang-toggle{display:inline-flex;margin-left:0}.mobile-drawer__btn{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;font-size:.85rem;color:#ffffffb3;transition:color var(--dur) var(--ease)}.mobile-drawer__btn:hover{color:var(--c-white)}.mobile-drawer__btn--logout{color:var(--c-coral-light)}.mobile-drawer__btn--logout:hover{color:var(--c-coral)}.mobile-drawer__btn--danger{color:#f87171!important}.mobile-drawer__btn--danger:hover{color:#ef4444!important}.mobile-drawer__item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;font-size:.85rem;color:#ffffffb3;transition:color var(--dur) var(--ease);width:100%;background:transparent}.mobile-drawer__item--danger{color:var(--c-coral)}.mobile-drawer__item--danger:hover{background:#ff63471a}.mobile-drawer__section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;padding:var(--sp-2) 0 var(--sp-1)}.mobile-drawer__divider{height:1px;background:#ffffff14;margin:var(--sp-1) 0}.mobile-drawer__link{display:block;padding:var(--sp-2) 0;font-size:.85rem;color:#fff9;text-decoration:none;transition:color var(--dur) var(--ease)}.mobile-drawer__link:hover{color:var(--c-aqua)}.mobile-drawer__copyright{font-size:.7rem;color:#ffffff40;text-align:center;padding-top:var(--sp-3)}}.search-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1100;opacity:0;transition:opacity .3s ease}.search-sheet-overlay.visible{opacity:1}.search-sheet-overlay.hidden{display:none!important}.search-sheet{position:fixed;bottom:0;left:0;right:0;max-height:80vh;background:var(--c-white);border-radius:var(--r-lg) var(--r-lg) 0 0;z-index:1200;box-shadow:0 -4px 20px #00000026;transform:translateY(100%);transition:transform .3s ease;display:flex;flex-direction:column}.search-sheet.visible{transform:translateY(0)}.search-sheet.hidden{display:none!important}.search-sheet__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-4) var(--sp-2);flex-shrink:0}.search-sheet__title{font-size:1.1rem;font-weight:600;color:var(--c-gray-900);margin:0}.search-sheet__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--c-gray-500);background:none;border:none;cursor:pointer;border-radius:var(--r-full);transition:background var(--dur) var(--ease)}.search-sheet__close:hover{background:var(--c-gray-100)}.search-sheet__input-wrap{position:relative;margin:0 var(--sp-4) var(--sp-3);flex-shrink:0}.search-sheet__input-icon{position:absolute;left:var(--sp-3);top:50%;transform:translateY(-50%);color:var(--c-gray-500);pointer-events:none}.search-sheet__input{width:100%;padding:var(--sp-3) var(--sp-10) var(--sp-3) calc(var(--sp-3) + 24px);border:1.5px solid var(--c-gray-200);border-radius:var(--r-md);font-size:.95rem;background:var(--c-gray-100);color:var(--c-gray-900);outline:none;transition:border-color var(--dur) var(--ease);box-sizing:border-box}.search-sheet__input:focus{border-color:var(--c-ocean);background:var(--c-white)}.search-sheet__input-clear{position:absolute;right:var(--sp-2);top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--c-gray-500);background:none;border:none;cursor:pointer;border-radius:var(--r-full)}.search-sheet__input-clear:hover{background:var(--c-gray-200)}.search-sheet__results{list-style:none;margin:0;padding:0;overflow-y:auto;max-height:40vh;flex:1;min-height:0}.search-sheet__result-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);cursor:pointer;transition:background var(--dur) var(--ease)}.search-sheet__result-item:hover,.search-sheet__result-item:active{background:var(--c-gray-100)}.search-sheet__result-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);background:var(--c-gray-100);color:var(--c-gray-700);flex-shrink:0}.search-sheet__result-icon--country{background:#bef;background:oklch(.92 .06 220);color:var(--c-ocean)}.search-sheet__result-icon--spot{background:#ffd8d4;background:oklch(.92 .08 25);color:var(--c-coral)}.search-sheet__result-text{display:flex;flex-direction:column;min-width:0}.search-sheet__result-name{font-size:.9rem;font-weight:500;color:var(--c-gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-sheet__result-sub{font-size:.75rem;color:var(--c-gray-500)}.search-sheet__no-results{padding:var(--sp-6) var(--sp-4);text-align:center;color:var(--c-gray-500);font-size:.9rem}.search-sheet__filters{border-top:1px solid var(--c-gray-200);padding:var(--sp-3) var(--sp-4) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3);flex-shrink:0}.search-sheet__filter-group{display:flex;flex-direction:column;gap:var(--sp-1)}.search-sheet__label{font-size:.8rem;font-weight:600;color:var(--c-gray-700)}.search-sheet__filter-input,.search-sheet__filter-select{width:100%;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--c-gray-200);border-radius:var(--r-sm);font-size:.85rem;background:var(--c-white);color:var(--c-gray-900);box-sizing:border-box}.search-sheet__filter-input:focus,.search-sheet__filter-select:focus{border-color:var(--c-ocean);outline:none}.search-sheet__filter-row{display:flex;gap:var(--sp-3)}.search-sheet__filter-group--half{flex:1;min-width:0}.search-sheet__reset{align-self:flex-start;padding:var(--sp-2) var(--sp-4);border-radius:var(--r-sm);border:1px solid var(--c-gray-300);background:var(--c-white);color:var(--c-gray-700);font-size:.8rem;cursor:pointer;transition:background var(--dur) var(--ease)}.search-sheet__reset:hover{background:var(--c-gray-100)}#sheet-country-autocomplete{position:relative}#sheet-country-list{position:absolute;bottom:100%;left:0;right:0;max-height:150px;overflow-y:auto;background:var(--c-white);border:1px solid var(--c-gray-200);border-radius:var(--r-sm);box-shadow:var(--shadow-md);z-index:10;margin-bottom:var(--sp-1)}@media (min-width: 1200px){.main__inner:not(.show-list) .cards-grid{grid-template-columns:repeat(2,1fr)}}.review-section{border-top:1px solid var(--c-gray-200);margin-top:var(--sp-6);padding-top:var(--sp-5)}.review-section__header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-bottom:var(--sp-4)}.review-section__title{font-size:1rem;font-weight:700;color:var(--c-gray-900)}.review-section__write-btn{padding:var(--sp-2) var(--sp-4);font-size:.8rem;font-weight:600;color:var(--c-white);background:var(--c-ocean);border-radius:var(--r-sm);transition:background var(--dur) var(--ease);white-space:nowrap}.review-section__write-btn:hover{background:var(--c-teal)}.review-summary{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4)}.review-summary__avg{font-size:1.8rem;font-weight:700;color:var(--c-gray-900);line-height:1}.review-summary__stars{display:flex;gap:2px}.review-summary__star{font-size:1.2rem;color:var(--c-gray-300)}.review-summary__star--filled{color:#daa500;color:oklch(.75 .18 85)}.review-summary__count{font-size:.8rem;color:var(--c-gray-500)}.review-sort{margin-bottom:var(--sp-3)}.review-sort__select{padding:var(--sp-1) var(--sp-3);border:1px solid var(--c-gray-200);border-radius:var(--r-sm);font-size:.8rem;background:var(--c-white);color:var(--c-gray-700)}.review-list{display:flex;flex-direction:column;gap:var(--sp-3)}.review-card{background:var(--c-gray-100);border-radius:var(--r-md);padding:var(--sp-4)}.review-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-2)}.review-card__author{font-size:.85rem;font-weight:600;color:var(--c-gray-900)}.review-card__date{font-size:.75rem;color:var(--c-gray-500)}.review-card__stars{display:flex;gap:1px;margin-bottom:var(--sp-2)}.review-card__star{font-size:.9rem;color:var(--c-gray-300)}.review-card__star--filled{color:#daa500;color:oklch(.75 .18 85)}.review-card__title{font-size:.9rem;font-weight:600;color:var(--c-gray-900);margin-bottom:var(--sp-1)}.review-card__content{font-size:.85rem;color:var(--c-gray-700);line-height:1.5;margin-bottom:var(--sp-2);white-space:pre-wrap;word-break:break-word}.review-card__visit{font-size:.75rem;color:var(--c-gray-500);margin-bottom:var(--sp-2)}.review-card__media{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-2)}.review-card__thumb{width:64px;height:64px;border-radius:var(--r-sm);overflow:hidden;cursor:pointer;position:relative;flex-shrink:0}.review-card__thumb img{width:100%;height:100%;object-fit:cover}.review-card__thumb--video:after{content:"▶";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;background:#00000059;border-radius:var(--r-sm)}.review-card__actions{display:flex;gap:var(--sp-2);margin-top:var(--sp-2)}.review-card__actions button{font-size:.75rem;padding:var(--sp-1) var(--sp-2);border-radius:var(--r-sm);transition:color var(--dur) var(--ease),background var(--dur) var(--ease);color:var(--c-gray-500)}.review-card__actions button:hover{background:var(--c-gray-200)}.review-card__edit-btn:hover{color:var(--c-ocean)}.review-card__delete-btn:hover{color:var(--c-coral)}.review-card__report-btn{color:var(--c-gray-500);font-size:.75rem;padding:var(--sp-1) var(--sp-2);border-radius:var(--r-sm);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.review-card__report-btn:hover{color:var(--c-coral);background:#ff63471a}.report-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000080}.report-dialog__content{background:var(--c-surface);border-radius:var(--r-lg);padding:var(--sp-4);width:min(90vw,320px)}.report-dialog__title{font-size:1rem;font-weight:600;margin-bottom:var(--sp-3)}.report-dialog__option{display:block;width:100%;text-align:left;padding:var(--sp-2) var(--sp-3);border-radius:var(--r-sm);font-size:.9rem;color:var(--c-text);transition:background var(--dur) var(--ease)}.report-dialog__option:hover{background:var(--c-gray-100)}.report-dialog__cancel{display:block;margin-top:var(--sp-3);width:100%;text-align:center;padding:var(--sp-2);font-size:.85rem;color:var(--c-gray-500)}.review-empty{text-align:center;padding:var(--sp-6) 0;color:var(--c-gray-500);font-size:.85rem}.review-star-input{display:flex;gap:var(--sp-1)}.review-star{font-size:2rem;cursor:pointer;color:var(--c-gray-300);transition:color var(--dur) var(--ease),transform var(--dur) var(--ease);-webkit-user-select:none;user-select:none;line-height:1}.review-star:hover{transform:scale(1.15)}.review-star--active{color:#daa500;color:oklch(.75 .18 85)}.review-char-count{text-align:right;font-size:.7rem;color:var(--c-gray-500);margin-top:var(--sp-1)}.review-media-hint{font-size:.75rem;color:var(--c-gray-500);margin-bottom:var(--sp-2)}.review-media-preview{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-2)}.review-media-preview__item{position:relative;width:80px;height:80px;border-radius:var(--r-sm);overflow:hidden}.review-media-preview__item img,.review-media-preview__item video{width:100%;height:100%;object-fit:cover}.review-media-preview__remove{position:absolute;top:2px;right:2px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--c-white);background:#0009;border-radius:var(--r-full);cursor:pointer;line-height:1}.review-media-preview__remove:hover{background:var(--c-coral)}.review-add-media-btn{font-size:.8rem}.review-upload-progress{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3)}.review-upload-bar{flex:1;height:6px;background:var(--c-gray-200);border-radius:var(--r-full);overflow:hidden}.review-upload-fill{height:100%;width:0%;background:var(--c-ocean);border-radius:var(--r-full);transition:width .2s ease}.review-upload-text{font-size:.75rem;color:var(--c-gray-500);min-width:32px;text-align:right}.log-media-hint{font-size:.75rem;color:var(--c-gray-500);margin-bottom:var(--sp-2)}.log-media-preview{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-2)}.log-media-preview__item{position:relative;width:80px;height:80px;border-radius:var(--r-sm);overflow:hidden}.log-media-preview__item img,.log-media-preview__item video{width:100%;height:100%;object-fit:cover}.log-media-preview__remove{position:absolute;top:2px;right:2px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--c-white);background:#0009;border-radius:var(--r-full);cursor:pointer;line-height:1}.log-media-preview__remove:hover{background:var(--c-coral)}.log-add-media-btn{font-size:.8rem}.log-upload-progress{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3)}.log-upload-bar{flex:1;height:6px;background:var(--c-gray-200);border-radius:var(--r-full);overflow:hidden}.log-upload-fill{height:100%;width:0%;background:var(--c-ocean);border-radius:var(--r-full);transition:width .2s ease}.log-upload-text{font-size:.75rem;color:var(--c-gray-500);min-width:32px;text-align:right}.media-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#000000eb;display:flex;align-items:center;justify-content:center}.media-viewer-overlay.hidden{display:none}.media-viewer__close{position:absolute;top:var(--sp-4);right:var(--sp-4);width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fffc;cursor:pointer;z-index:10;border-radius:var(--r-full);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.media-viewer__close:hover{color:var(--c-white);background:#ffffff1a}.media-viewer__nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#ffffffb3;cursor:pointer;z-index:10;border-radius:var(--r-full);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.media-viewer__nav:hover{color:var(--c-white);background:#ffffff1a}.media-viewer__nav--prev{left:var(--sp-3)}.media-viewer__nav--next{right:var(--sp-3)}.media-viewer__content{max-width:90vw;max-height:85vh;display:flex;align-items:center;justify-content:center}.media-viewer__content img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--r-sm)}.media-viewer__content video{max-width:90vw;max-height:85vh;border-radius:var(--r-sm)}.media-viewer__counter{position:absolute;bottom:var(--sp-6);left:50%;transform:translate(-50%);color:#ffffffb3;font-size:.85rem;z-index:10}@media (max-width: 768px){.review-star{font-size:1.6rem}.review-card__thumb{width:56px;height:56px}.review-media-preview__item{width:64px;height:64px}.media-viewer__nav{width:36px;height:36px;font-size:1.2rem}.media-viewer__close{width:36px;height:36px;font-size:1.4rem;top:var(--sp-2);right:var(--sp-2)}.review-summary__avg{font-size:1.4rem}}.header__profile{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--c-ocean);color:var(--c-white);cursor:pointer;transition:background .2s}.header__profile:hover{background:var(--c-teal)}.profile-header{display:flex;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-6)}.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--c-foam);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;color:var(--c-gray-300)}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-avatar--edit{width:80px;height:80px}.profile-header__info{flex:1;min-width:0}.profile-header__nickname{font-size:1.25rem;font-weight:700;color:var(--c-white);margin:0 0 var(--sp-1) 0}.profile-header__country{font-size:.85rem;color:var(--c-gray-300)}.profile-header__actions{display:flex;gap:var(--sp-2)}.profile-section{margin-bottom:var(--sp-6)}.profile-section__title{font-size:.9rem;font-weight:600;color:var(--c-teal);margin-bottom:var(--sp-3)}.profile-section__empty{font-size:.85rem;color:var(--c-gray-300)}.profile-bio{font-size:.9rem;color:var(--c-gray-200);line-height:1.5;white-space:pre-wrap}.profile-cert-card{display:flex;align-items:center;gap:var(--sp-3);background:var(--c-navy);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-2)}.profile-cert-card__info{flex:1;min-width:0}.profile-cert-card__org{font-size:.8rem;color:var(--c-teal);font-weight:600}.profile-cert-card__level{font-size:.9rem;color:var(--c-white)}.profile-cert-card__meta{font-size:.75rem;color:var(--c-gray-300)}.profile-cert-card__delete{background:none;border:none;color:var(--c-gray-300);cursor:pointer;font-size:1.1rem;padding:var(--sp-1)}.profile-cert-card__delete:hover{color:var(--c-coral)}.profile-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3)}.profile-stats__item{background:var(--c-navy);border-radius:var(--r-md);padding:var(--sp-3);text-align:center}.profile-stats__value{font-size:1.1rem;font-weight:700;color:var(--c-teal)}.profile-stats__label{font-size:.75rem;color:var(--c-gray-300);margin-top:var(--sp-1)}.profile-recent-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.85rem}.profile-recent-item__name{color:var(--c-white);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-recent-item__date{color:var(--c-gray-300);font-size:.75rem;flex-shrink:0;margin-left:var(--sp-2)}.profile-review-item{padding:var(--sp-3) 0;border-bottom:1px solid var(--c-gray-800)}.profile-review-item:last-child{border-bottom:none}.profile-review-item__header{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-1)}.profile-review-item__spot{font-size:.8rem;font-weight:600;color:var(--c-aqua);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-review-item__date{font-size:.75rem;color:var(--c-gray-400);flex-shrink:0}.profile-review-item__rating{margin-bottom:var(--sp-1)}.profile-review-item__title{font-size:.85rem;font-weight:500;color:var(--c-gray-100);margin-bottom:var(--sp-1)}.profile-review-item__content{font-size:.8rem;color:var(--c-gray-300);line-height:1.4;margin-bottom:var(--sp-2)}.profile-review-item__actions{display:flex;gap:var(--sp-2)}.profile-review-item__edit-btn,.profile-review-item__delete-btn{font-size:.75rem;padding:var(--sp-1) var(--sp-2);border-radius:var(--r-sm);border:1px solid var(--c-gray-600);background:transparent;color:var(--c-gray-300);cursor:pointer}.profile-review-item__delete-btn{color:var(--c-coral);border-color:var(--c-coral)}.profile-privacy-toggles{display:flex;flex-direction:column;gap:var(--sp-2)}.profile-privacy-toggle{display:flex;align-items:center;gap:var(--sp-2);font-size:.85rem;color:var(--c-gray-200);cursor:pointer}.profile-privacy-toggle input[type=checkbox]{accent-color:var(--c-teal)}.profile-edit-photo-wrap{display:flex;align-items:center;gap:var(--sp-3)}.profile-private-msg{text-align:center;padding:var(--sp-8) var(--sp-4);color:var(--c-gray-300);font-size:.9rem}.review-card__author--clickable{color:var(--c-teal);cursor:pointer}.review-card__author--clickable:hover{text-decoration:underline}.sighting-stat__location{font-size:.8rem;word-break:break-all}.sighting-list{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-3)}.sighting-card{background:var(--c-navy);border-radius:var(--r-md);padding:var(--sp-3)}.sighting-card__header{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-2)}.sighting-card__species{font-weight:600;font-size:.95rem}.sighting-card__date{font-size:.8rem;color:var(--c-gray-300);white-space:nowrap}.sighting-card__location{font-size:.85rem;color:var(--c-teal);margin-top:var(--sp-1)}.sighting-card__count{display:inline-block;font-size:.75rem;color:var(--c-gray-300);margin-top:var(--sp-1)}.sighting-card__notes{font-size:.85rem;color:var(--c-gray-200);margin-top:var(--sp-1);line-height:1.4}.sighting-card__photos{display:flex;gap:var(--sp-1);margin-top:var(--sp-2);overflow-x:auto}.sighting-card__photo{width:64px;height:64px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0}@media (max-width: 768px){.profile-header{flex-direction:column;text-align:center}.profile-stats__grid{grid-template-columns:repeat(2,1fr)}.header__profile{display:none}}.header__marine{background:none;border:none;color:var(--c-gray-300);cursor:pointer;padding:var(--sp-1);border-radius:var(--r-sm);transition:color var(--dur) var(--ease);display:flex;align-items:center}.header__marine:hover{color:var(--c-white)}.header__achievements{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--c-ocean);color:var(--c-white);cursor:pointer;transition:background .2s}.header__achievements:hover{background:var(--c-teal)}.achievements-counter{font-size:.85rem;color:var(--c-gray-300);margin-bottom:var(--sp-4)}.achievements-category{margin-bottom:var(--sp-6)}.achievements-category__title{font-size:.9rem;font-weight:600;color:var(--c-teal);margin-bottom:var(--sp-3)}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--sp-3)}.achievement-card{display:flex;flex-direction:column;align-items:center;padding:var(--sp-3) var(--sp-2);border-radius:var(--r-md);background:var(--c-navy);cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative}.achievement-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.achievement-card__icon{font-size:2rem;line-height:1;margin-bottom:var(--sp-1)}.achievement-card__name{font-size:.7rem;color:var(--c-white);text-align:center;line-height:1.2;word-break:keep-all}.achievement-card--locked{opacity:.4;filter:grayscale(1)}.achievement-card--locked .achievement-card__icon:after{content:"uD83DuDD12";position:absolute;bottom:var(--sp-1);right:var(--sp-1);font-size:.7rem}.achievement-card--unlocked{border:1px solid var(--c-teal)}.achievement-card--unlocked .achievement-card__check{position:absolute;top:4px;right:4px;width:16px;height:16px;border-radius:50%;background:var(--c-teal);color:var(--c-white);font-size:.6rem;display:flex;align-items:center;justify-content:center}.achievement-card__progress{width:100%;height:3px;background:#ffffff1a;border-radius:2px;margin-top:var(--sp-1);overflow:hidden}.achievement-card__progress-fill{height:100%;background:var(--c-teal);border-radius:2px;transition:width .3s}.achievement-detail-modal{background:var(--c-deep);border-radius:var(--r-lg);padding:var(--sp-8) var(--sp-6);max-width:320px;width:90%;margin:auto;text-align:center;position:relative}.achievement-detail__icon{font-size:4rem;margin-bottom:var(--sp-3)}.achievement-detail__name{font-size:1.2rem;font-weight:700;color:var(--c-white);margin-bottom:var(--sp-2)}.achievement-detail__desc{font-size:.9rem;color:var(--c-gray-300);margin-bottom:var(--sp-3)}.achievement-detail__date{font-size:.8rem;color:var(--c-gray-300);margin-bottom:var(--sp-4)}.achievement-toast{position:fixed;top:var(--sp-4);left:50%;transform:translate(-50%) translateY(-120%);background:var(--c-deep);border:1px solid var(--c-teal);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;gap:var(--sp-3);z-index:10000;box-shadow:0 4px 20px #00000080;transition:transform .4s cubic-bezier(.34,1.56,.64,1);max-width:360px;width:90%}.achievement-toast.visible{transform:translate(-50%) translateY(0)}.achievement-toast__icon{font-size:2rem;flex-shrink:0}.achievement-toast__title{font-size:.8rem;font-weight:600;color:var(--c-teal)}.achievement-toast__desc{font-size:.85rem;color:var(--c-white)}.profile-featured-badges{display:flex;gap:var(--sp-2);margin-top:var(--sp-1)}.profile-featured-badge{font-size:1.4rem;cursor:default}.achievements-featured-section{margin-top:var(--sp-6);padding-top:var(--sp-4);border-top:1px solid rgba(255,255,255,.08)}.achievements-featured-hint{font-size:.8rem;color:var(--c-gray-300);margin-bottom:var(--sp-3)}.achievement-card--selectable{cursor:pointer;-webkit-user-select:none;user-select:none}.achievement-card--selected{border:2px solid var(--c-coral);box-shadow:0 0 8px #ff7f504d}@media (max-width: 768px){.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr))}.header__achievements,.header__marine{display:none}}.status-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;border-radius:var(--r-full);padding:var(--sp-2) var(--sp-5);font-size:.8rem;z-index:9998;white-space:nowrap;box-shadow:var(--shadow-md);opacity:1;transition:opacity .3s var(--ease)}.status-toast.hidden{opacity:0;pointer-events:none}.status-toast--success{background:#059669}.status-toast--error{background:#dc2626}.mobile-drawer__icon{font-size:1rem}.blocked-user-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3)}.blocked-user-item__name{font-size:.85rem;color:var(--c-text)}.blocked-user-item__unblock{font-size:.75rem;color:var(--c-coral);padding:var(--sp-1) var(--sp-2);border-radius:var(--r-sm);transition:background var(--dur) var(--ease)}.blocked-user-item__unblock:hover{background:#ff63471a}.btn--report{background:var(--c-report);color:var(--c-white);border:none}.btn--report:hover{background:#b95e00;background:oklch(.58 .18 55)}.btn--report:disabled{opacity:.6;cursor:not-allowed}.map-context-menu{position:fixed;z-index:1100;background:var(--c-white);border-radius:var(--r-md);box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden}.map-context-menu.hidden{display:none}.map-context-menu__btn{display:block;width:100%;padding:var(--sp-3) var(--sp-4);border:none;background:transparent;font-size:.9rem;font-weight:500;color:var(--c-gray-900);cursor:pointer;text-align:left;transition:background var(--dur) var(--ease)}.map-context-menu__btn:hover{background:var(--c-foam)}.report-card{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-4);border:1px solid var(--c-gray-200);border-radius:var(--r-md);background:var(--c-white);transition:box-shadow var(--dur) var(--ease)}.report-card+.report-card{margin-top:var(--sp-3)}.report-card:hover{box-shadow:var(--shadow-sm)}.report-card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2)}.report-card__name{font-weight:600;font-size:.95rem;color:var(--c-deep)}.report-card__status{font-size:.75rem;font-weight:600;padding:var(--sp-1) var(--sp-2);border-radius:var(--r-full);white-space:nowrap}.report-card__status--pending{background:#ffe0ad;background:oklch(.92 .08 80);color:#704e00;color:oklch(.45 .12 80)}.report-card__status--reviewed{background:#b5e6ff;background:oklch(.9 .08 230);color:#004f6a;color:oklch(.4 .12 230)}.report-card__status--approved{background:#aef1bb;color:#005725;color:oklch(.4 .14 150)}.report-card__status--rejected{background:#ffd8d4;background:oklch(.92 .08 25);color:#932b2a}.report-card__meta{display:flex;align-items:center;gap:var(--sp-3);font-size:.8rem;color:var(--c-gray-500)}.report-card__type{font-size:.8rem;color:var(--c-gray-700)}.report-card__note{font-size:.8rem;padding:var(--sp-2) var(--sp-3);background:var(--c-foam);border-radius:var(--r-sm);color:var(--c-gray-700);margin-top:var(--sp-1)}.report-season-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-2)}.correction-fields-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-2)}.correction-entry{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-3);background:var(--c-gray-100);border-radius:var(--r-sm);margin-bottom:var(--sp-3)}.correction-entry__label{font-size:.85rem;font-weight:600;color:var(--c-deep)}.correction-entry__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.correction-entry__col label{display:block;font-size:.75rem;color:var(--c-gray-500);margin-bottom:var(--sp-1)}.correction-entry__col input,.correction-entry__col textarea{width:100%;padding:var(--sp-2);border:1px solid var(--c-gray-200);border-radius:var(--r-sm);font-size:.85rem}.correction-entry__col input[readonly]{background:var(--c-gray-100);color:var(--c-gray-500)}.correction-spot-name{font-size:.9rem;color:var(--c-ocean);font-weight:600;margin-bottom:var(--sp-3)}.empty-state__report-link{display:inline-block;margin-top:var(--sp-3);font-size:.85rem;color:var(--c-report);text-decoration:underline;text-underline-offset:3px;cursor:pointer;transition:color var(--dur) var(--ease)}.empty-state__report-link:hover{color:#ac5700;color:oklch(.55 .18 55)}.report-duplicate-warning{margin-top:var(--sp-2);padding:var(--sp-3);background:#ffeccd;background:oklch(.95 .06 80);border:1px solid oklch(.85 .1 80);border-radius:var(--r-sm);font-size:.8rem;color:#5f4200;color:oklch(.4 .12 80)}.report-duplicate-warning.hidden{display:none}.modal__action-btn--report{border-color:var(--c-report-light);color:var(--c-report)}.modal__action-btn--report:hover{background:var(--c-report);color:var(--c-white);border-color:var(--c-report)}.report-photo-preview{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:var(--sp-2)}.report-photo-preview__item{position:relative;width:80px;height:80px;border-radius:var(--r-sm);overflow:hidden}.report-photo-preview__item img{width:100%;height:100%;object-fit:cover}.report-photo-preview__remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border:none;border-radius:50%;background:#0009;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.report-progress{margin:var(--sp-3) 0}.report-progress.hidden{display:none}.report-progress__bar{height:4px;background:var(--c-gray-200);border-radius:var(--r-full);overflow:hidden}.report-progress__fill{height:100%;background:var(--c-report);width:0%;transition:width .3s ease}.char-counter{display:block;text-align:right;font-size:.75rem;color:var(--c-gray-500);margin-top:var(--sp-1)}.nickname-input-wrap{display:flex;gap:8px;align-items:center}.nickname-input-wrap input{flex:1;min-width:0}@media (max-width: 600px){.report-season-grid{grid-template-columns:repeat(3,1fr)}.correction-fields-list,.correction-entry__row{grid-template-columns:1fr}}.modal--marine{max-width:940px}.marine-guide__header{margin-bottom:var(--sp-4)}.marine-guide__title{font-size:1.3rem;font-weight:700;color:var(--c-gray-900);margin:0 0 var(--sp-3)}.marine-guide__progress{display:flex;align-items:center;gap:var(--sp-3)}.marine-guide__progress-bar{flex:1;height:10px;background:var(--c-gray-100);border-radius:var(--r-full);overflow:hidden}.marine-guide__progress-fill{height:100%;background:linear-gradient(90deg,#0077b6,#00b4d8);border-radius:var(--r-full);transition:width .5s ease}.marine-guide__progress-text{font-size:.8rem;color:var(--c-gray-500);white-space:nowrap}.marine-guide__chips{display:flex;gap:var(--sp-2);overflow-x:auto;padding-bottom:var(--sp-2);margin-bottom:var(--sp-3);scrollbar-width:none;-ms-overflow-style:none}.marine-guide__chips::-webkit-scrollbar{display:none}.marine-chip{display:flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--r-full);border:1.5px solid var(--c-gray-200);background:#fff;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:all .2s;color:var(--c-gray-600)}.marine-chip:hover{border-color:var(--c-ocean);color:var(--c-ocean)}.marine-chip.active{background:var(--c-ocean);color:#fff;border-color:var(--c-ocean)}.marine-guide__controls{display:flex;gap:var(--sp-2);align-items:center;margin-bottom:var(--sp-4);flex-wrap:wrap}.marine-guide__select{padding:6px 10px;border:1.5px solid var(--c-gray-200);border-radius:var(--r-md);font-size:.8rem;background:#fff;color:var(--c-gray-700);cursor:pointer}.marine-guide__toggle{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--c-gray-600);cursor:pointer;margin-left:auto}.marine-guide__toggle input{accent-color:var(--c-ocean)}.marine-guide__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3);margin-bottom:var(--sp-6)}@media (min-width: 600px){.marine-guide__grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 900px){.marine-guide__grid{grid-template-columns:repeat(5,1fr)}}.marine-card{display:flex;flex-direction:column;align-items:center;padding:var(--sp-3) var(--sp-2);border-radius:var(--r-lg);border:1.5px solid var(--c-gray-100);background:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s;position:relative;text-align:center;min-height:140px}.marine-card:hover{transform:scale(1.03);box-shadow:var(--shadow-md)}.marine-card--discovered{box-shadow:0 0 8px #0077b626}.marine-card--undiscovered{filter:grayscale(100%);opacity:.5}.marine-card--undiscovered:hover{filter:grayscale(50%);opacity:.7}.marine-card__image{width:100%;height:90px;overflow:hidden;border-radius:var(--r-md) var(--r-md) 0 0;background:var(--c-gray-50, #f0f4f8);margin-bottom:var(--sp-2);position:relative}@media (min-width: 600px){.marine-card__image{height:110px}}.marine-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.marine-card:hover .marine-card__image img{transform:scale(1.08)}.marine-card--undiscovered .marine-card__image img{filter:grayscale(100%) blur(2px);opacity:.5}.marine-card__emoji-fallback{font-size:48px;display:flex;align-items:center;justify-content:center;height:100%;background:var(--c-gray-50, #f0f4f8)}@media (min-width: 600px){.marine-card__emoji-fallback{font-size:64px}}.marine-card__emoji{font-size:48px;line-height:1;margin-bottom:var(--sp-2)}@media (min-width: 600px){.marine-card__emoji{font-size:64px}}.marine-card__name{font-size:.75rem;font-weight:600;color:var(--c-gray-800);line-height:1.2;margin-bottom:2px}.marine-card__scientific{font-size:.6rem;color:var(--c-gray-400);font-style:italic;margin-bottom:var(--sp-1);line-height:1.2}.marine-card__rarity{display:inline-block;padding:2px 8px;border-radius:var(--r-full);font-size:.6rem;font-weight:600;color:#fff}.marine-card__unknown{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:700;color:var(--c-gray-400);pointer-events:none}.marine-card__count{position:absolute;top:6px;right:6px;background:var(--c-ocean);color:#fff;font-size:.6rem;padding:1px 6px;border-radius:var(--r-full);font-weight:600}.marine-detail__hero{text-align:center;padding:var(--sp-4) 0}.marine-detail__image-wrap{position:relative;width:100%;max-height:220px;overflow:hidden;border-radius:var(--r-lg);margin-bottom:var(--sp-3);background:var(--c-gray-50, #f0f4f8)}@media (min-width: 600px){.marine-detail__image-wrap{max-height:280px}}.marine-detail__image-wrap img{width:100%;height:220px;object-fit:cover}@media (min-width: 600px){.marine-detail__image-wrap img{height:280px}}.marine-detail__credit{position:absolute;bottom:6px;right:8px;font-size:.6rem;color:#ffffffe6;background:#00000080;padding:2px 8px;border-radius:var(--r-full);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.marine-detail__credit a{color:inherit;text-decoration:underline;text-underline-offset:2px}.marine-detail__credit a:hover{opacity:.8}.marine-detail__emoji{font-size:80px;line-height:1}@media (min-width: 600px){.marine-detail__emoji{font-size:120px}}.marine-detail__name{font-size:1.3rem;font-weight:700;color:var(--c-gray-900);margin:var(--sp-2) 0 4px}.marine-detail__scientific{font-size:.85rem;color:var(--c-gray-400);font-style:italic;margin-bottom:var(--sp-3)}.marine-detail__badges{display:flex;gap:var(--sp-2);justify-content:center}.marine-detail__badge{display:inline-block;padding:3px 12px;border-radius:var(--r-full);font-size:.75rem;font-weight:600;color:#fff}.marine-detail__info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin:var(--sp-4) 0}.marine-detail__info-item{text-align:center;padding:var(--sp-3);border-radius:var(--r-md);background:var(--c-gray-50, #f8f9fa);border:1px solid var(--c-gray-100)}.marine-detail__info-label{font-size:.7rem;color:var(--c-gray-400);margin-bottom:4px;text-transform:uppercase}.marine-detail__info-value{font-size:.95rem;font-weight:600;color:var(--c-gray-800)}.marine-detail__section{margin-bottom:var(--sp-4)}.marine-detail__section-title{font-size:.85rem;font-weight:700;color:var(--c-gray-700);margin-bottom:var(--sp-2);padding-bottom:4px;border-bottom:1px solid var(--c-gray-100)}.marine-detail__section p{font-size:.85rem;color:var(--c-gray-600);line-height:1.6;margin:0}.marine-detail__funfact{background:linear-gradient(135deg,#fffdf0,#fff7e6);padding:var(--sp-3);border-radius:var(--r-md);border-left:3px solid #FFC107}.marine-detail__observation{background:var(--c-gray-50, #f8f9fa);padding:var(--sp-3);border-radius:var(--r-md)}.marine-detail__obs-stats{display:flex;gap:var(--sp-4);margin-bottom:var(--sp-3);font-size:.8rem;color:var(--c-gray-600)}.marine-detail__photos{display:flex;gap:var(--sp-2);overflow-x:auto;padding-bottom:var(--sp-2)}.marine-detail__photo{width:80px;height:80px;object-fit:cover;border-radius:var(--r-md);flex-shrink:0;cursor:pointer}.marine-detail__notes{font-size:.8rem;color:var(--c-gray-600);margin-top:var(--sp-2)}.marine-detail__empty{font-size:.8rem;color:var(--c-gray-400);text-align:center;padding:var(--sp-4) 0}.marine-detail__actions{display:flex;gap:var(--sp-2);margin-top:var(--sp-4);flex-wrap:wrap}.marine-detail__record-btn{flex:1}.marine-detail__fav-btn{min-width:100px}.marine-detail__delete-btn{padding:8px 12px;background:var(--c-gray-100);color:var(--c-gray-500);border:none;border-radius:var(--r-md);cursor:pointer}.marine-detail__delete-btn:hover{background:#fee2e2;color:#dc3545}.marine-record__title{font-size:1.1rem;font-weight:700;margin:0 0 var(--sp-2)}.marine-record__species{font-size:1rem;color:var(--c-ocean);font-weight:600;margin-bottom:var(--sp-4)}.marine-record__field{margin-bottom:var(--sp-3)}.marine-record__field label{display:block;font-size:.8rem;font-weight:600;color:var(--c-gray-600);margin-bottom:4px}.marine-record__submit{width:100%;margin-top:var(--sp-3)}.marine-stats{padding:var(--sp-4);background:var(--c-gray-50, #f8f9fa);border-radius:var(--r-lg);margin-top:var(--sp-4)}.marine-stats__title{font-size:.95rem;font-weight:700;color:var(--c-gray-800);margin-bottom:var(--sp-3)}.marine-stats__row{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2);font-size:.8rem;color:var(--c-gray-600)}.marine-stats__row>span:first-child{min-width:90px;white-space:nowrap}.marine-stats__bar{flex:1;height:6px;background:var(--c-gray-200);border-radius:var(--r-full);overflow:hidden}.marine-stats__bar-fill{height:100%;background:linear-gradient(90deg,#0077b6,#00b4d8);border-radius:var(--r-full);transition:width .3s}.marine-stats__count{font-size:.7rem;color:var(--c-gray-400);min-width:36px;text-align:right}.marine-stats__rarity-row{display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--c-gray-200);font-size:.8rem;color:var(--c-gray-600)}.marine-stats__rarity-row>div{display:flex;gap:var(--sp-2)}.marine-stats__rarity-dot{display:inline-block;padding:2px 8px;border-radius:var(--r-full);font-size:.65rem;font-weight:600;color:#fff}.marine-stats__most{margin-top:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--c-gray-200);font-size:.8rem;color:var(--c-gray-600)}.modal__tag--link{cursor:pointer;border:1.5px solid var(--c-ocean);color:var(--c-ocean);transition:background .15s,color .15s}.modal__tag--link:hover{background:var(--c-ocean);color:#fff}.region-popup-wrapper .leaflet-popup-content{margin:0!important;padding:0!important}.region-popup-wrapper .leaflet-popup-content-wrapper{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:0;overflow:hidden}.region-popup{padding:var(--sp-4) var(--sp-5) var(--sp-4);font-family:var(--ff);min-width:260px;cursor:default}.region-popup__title{font-size:1.15rem;font-weight:700;color:var(--c-gray-900);margin-bottom:var(--sp-2)}.region-popup__header{display:flex;flex-wrap:wrap;gap:var(--sp-1) var(--sp-2);align-items:center;margin-bottom:var(--sp-3)}.region-popup__stat{font-size:.82rem;color:var(--c-gray-700);margin-right:var(--sp-1)}.diff-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:1px 7px;border-radius:var(--r-full);line-height:1.6}.diff-badge--beginner{background:#bff4c9;color:#00481d;color:oklch(.35 .15 150)}.diff-badge--intermediate{background:#ffe0ad;background:oklch(.92 .08 80);color:#5f4200;color:oklch(.4 .15 80)}.diff-badge--advanced{background:#ffd8d4;background:oklch(.92 .1 25);color:#8a0012;color:oklch(.4 .18 25)}.region-popup__countries{max-height:260px;overflow-y:auto;margin-bottom:var(--sp-3);border:1px solid var(--c-gray-200);border-radius:var(--r-md)}.region-popup__countries::-webkit-scrollbar{width:4px}.region-popup__countries::-webkit-scrollbar-thumb{background:var(--c-gray-300);border-radius:2px}.region-accordion{border-bottom:1px solid var(--c-gray-200)}.region-accordion:last-child{border-bottom:none}.region-accordion__header{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) var(--sp-3);font-size:.88rem;font-weight:600;color:var(--c-gray-900);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--dur) var(--ease)}.region-accordion__header:hover{background:var(--c-gray-100)}.region-accordion__chevron{font-size:.75rem;color:var(--c-gray-500);transition:transform var(--dur) var(--ease)}.region-accordion__body{padding:0 var(--sp-3) var(--sp-2)}.region-area{margin-bottom:var(--sp-1)}.region-area__title{font-size:.78rem;font-weight:600;color:var(--c-ocean);margin-bottom:2px;margin-top:var(--sp-1)}.region-area__spots{font-size:.8rem;line-height:1.7;color:var(--c-gray-700)}.region-popup__spot-link{color:var(--c-teal);cursor:pointer;transition:color var(--dur) var(--ease);text-decoration:none}.region-popup__spot-link:hover{color:var(--c-ocean);text-decoration:underline}.region-popup__explore{display:block;width:100%;padding:var(--sp-2) 0;border:none;border-radius:var(--r-sm);background:var(--c-ocean);color:var(--c-white);font-size:.88rem;font-weight:600;cursor:pointer;transition:background var(--dur) var(--ease)}.region-popup__explore:hover{background:var(--c-navy)}.mobile-drawer__section--danger{border-top:1px solid rgba(220,53,69,.2);margin-top:var(--sp-2);padding-top:var(--sp-2)}.mobile-drawer__btn--danger{color:#dc3545!important}.mobile-drawer__btn--danger svg{stroke:#dc3545}.mobile-drawer__btn--danger:hover{color:#c82333!important}.btn--danger{background:#dc3545;color:#fff;border:none;padding:var(--sp-2) var(--sp-4);border-radius:var(--r-md);cursor:pointer;font-weight:600}.btn--danger:hover{background:#c82333}.btn--danger:disabled{opacity:.6;cursor:not-allowed}#delete-account-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1200}#delete-account-overlay.hidden{display:none}.delete-account-modal{background:var(--c-deep);border-radius:var(--r-lg);padding:var(--sp-6);max-width:420px;width:90%;color:var(--c-white)}.delete-account-modal h3{color:#dc3545;margin-bottom:var(--sp-3);font-size:1.1rem}.delete-account-modal>p{color:var(--c-gray-300);font-size:.9rem;line-height:1.5;margin-bottom:var(--sp-4);white-space:pre-line}.delete-account-modal__actions{display:flex;gap:var(--sp-3);justify-content:flex-end}.delete-account-reauth{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid rgba(255,255,255,.1)}.delete-account-reauth p{color:var(--c-gray-300);font-size:.85rem;margin-bottom:var(--sp-3)}.delete-account-reauth input{width:100%;margin-bottom:var(--sp-3)}.delete-account-progress{display:flex;align-items:center;gap:var(--sp-3);margin-top:var(--sp-3);color:var(--c-gray-300);font-size:.9rem}.delete-account-error{color:#dc3545;font-size:.85rem;margin-top:var(--sp-3)}.profile-delete-section{margin-top:var(--sp-6);padding:var(--sp-4) var(--sp-6);border-top:1px solid rgba(255,255,255,.08);text-align:center}.delete-account-modal__title{color:#dc3545;font-size:1.1rem;margin-bottom:var(--sp-3)}.delete-account-modal__message{color:var(--c-gray-300);font-size:.9rem;line-height:1.5;margin-bottom:var(--sp-4);white-space:pre-line}.delete-account-reauth__actions{display:flex;gap:var(--sp-2);flex-wrap:wrap}.profile-delete-section .btn--danger{font-size:.85rem;padding:var(--sp-2) var(--sp-4)}.home-panel{display:none;overflow-y:auto;background:linear-gradient(180deg,#00141a,#000714 40%,#01030a);background:linear-gradient(180deg,color(xyz 0.004 0.006 0.017),#000714 40%,#01030a);color:var(--c-white)}@media (min-width: 769px){.home-panel.active{display:block;width:380px;min-width:380px;height:100%;border-right:1px solid rgba(255,255,255,.08)}.main__inner.show-home{grid-template-columns:380px 1fr}.main__inner.show-home .map-panel{display:block}}@media (max-width: 768px){.home-panel.active{display:block;height:100%;padding-bottom:80px}}.home-panel__inner{max-width:100%;padding:var(--sp-4)}.home__greeting{margin-bottom:var(--sp-4)}.home__greeting-title{font-size:1.15rem;font-weight:700;margin:0 0 2px}.home__greeting-sub{font-size:.78rem;color:#ffffffb3;margin:0}.home__hero{text-align:center;margin-bottom:var(--sp-5);padding:var(--sp-5) 0}.home__hero-title{font-size:1.2rem;font-weight:700;margin:0 0 var(--sp-2);line-height:1.4;white-space:pre-line}.home__hero-sub{font-size:.82rem;color:#ffffffbf;margin:0 0 var(--sp-4)}.home__hero-cta{display:inline-block;padding:var(--sp-2) var(--sp-5);background:var(--c-ocean);color:var(--c-white);border:none;border-radius:var(--r-full);font-size:.85rem;font-weight:600;cursor:pointer}.home__hero-cta:hover{background:var(--c-teal)}.home__stats{display:flex;align-items:center;gap:var(--sp-3);background:#ffffff1a;border-radius:var(--r-md);padding:var(--sp-3);margin-bottom:var(--sp-4);flex-wrap:wrap}.home__stat{text-align:center;flex:1;min-width:50px}.home__stat-value{display:block;font-size:1.1rem;font-weight:700;color:var(--c-aqua)}.home__stat-value--sm{font-size:.8rem;font-weight:500;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.home__stat-label{font-size:.65rem;color:#ffffffb3;margin-top:2px}.home__stat-divider{width:1px;height:24px;background:#ffffff1a}.home__section{margin-bottom:var(--sp-4)}.home__section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-2)}.home__section-title{font-size:.9rem;font-weight:600;margin:0}.home__section-meta{font-size:.72rem;color:#ffffffa6}.home__season-scroll{display:flex;gap:var(--sp-2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--sp-2)}.home__season-scroll::-webkit-scrollbar{display:none}.home__season-card{min-width:130px;flex-shrink:0;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);padding:var(--sp-2) var(--sp-3);cursor:pointer}.home__season-card:hover{background:#ffffff1a}.home__season-badge{display:inline-block;font-size:.6rem;font-weight:600;color:#34d399;background:#34d39926;padding:2px 6px;border-radius:var(--r-sm);margin-bottom:var(--sp-1)}.home__season-name{font-size:.82rem;font-weight:600;margin:0 0 3px}.home__season-meta{font-size:.7rem;color:#ffffffb3}.home__recommend-card{background:linear-gradient(135deg,#0d6e5640,#0d4f3c59);border:1px solid rgba(52,211,153,.2);border-radius:var(--r-md);padding:var(--sp-3);display:flex;align-items:center;gap:var(--sp-3);cursor:pointer}.home__recommend-card:hover{background:#0d6e5666}.home__recommend-icon{width:40px;height:40px;border-radius:var(--r-md);background:#34d39926;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.home__recommend-info{flex:1;min-width:0}.home__recommend-name{font-size:.85rem;font-weight:600;margin:0 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home__recommend-meta{font-size:.72rem;color:#ffffffbf;display:flex;gap:var(--sp-2)}.home__recommend-score{color:#34d399;font-weight:500}.home__recommend-loading{text-align:center;padding:var(--sp-3);font-size:.78rem;color:#ffffffa6}.home__marine-progress{background:#ffffff0d;border-radius:var(--r-md);padding:var(--sp-3)}.home__marine-bar{height:5px;background:#ffffff14;border-radius:3px;overflow:hidden;margin-bottom:var(--sp-2)}.home__marine-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--c-ocean),var(--c-aqua));transition:width .5s ease}.home__marine-recent{font-size:.7rem;color:#ffffffa6;margin:0}.home__features-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2);margin-top:var(--sp-2)}.home__feature-card{background:#ffffff1a;border-radius:var(--r-md);padding:var(--sp-2) var(--sp-3);text-align:center}.home__feature-icon{font-size:1.2rem;margin-bottom:2px}.home__feature-name{display:block;font-size:.75rem;font-weight:600;margin-bottom:1px}.home__feature-desc{display:block;font-size:.65rem;color:#ffffffa6}.home__discover-card{background:linear-gradient(135deg,#ffffff14,#ffffff08);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:var(--sp-4);cursor:pointer;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.home__discover-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.home__discover-body{display:flex;flex-direction:column;gap:var(--sp-1)}.home__discover-name{font-size:1.05rem;font-weight:700;color:var(--c-white);margin:0}.home__discover-meta{font-size:.78rem;color:#fff9;margin:0}.home__discover-desc{font-size:.82rem;color:#ffffffbf;margin:var(--sp-1) 0 0;line-height:1.45}.home__discover-link{display:inline-block;margin-top:var(--sp-2);font-size:.8rem;font-weight:600;color:var(--c-ocean);transition:color var(--dur) var(--ease)}.home__discover-card:hover .home__discover-link{color:#00c1e9;color:oklch(.75 .15 220)}.home__login-banner{display:flex;align-items:center;justify-content:space-between;background:#34d39914;border:1px solid rgba(52,211,153,.25);border-radius:var(--r-md);padding:var(--sp-3);margin-top:var(--sp-3)}.home__login-banner-text{font-size:.78rem;color:#ffffffd9}.home__login-banner-btn{padding:var(--sp-2) var(--sp-3);background:#34d399;color:var(--c-dark);border:none;border-radius:var(--r-full);font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap}.fab--home{display:none!important}.landing__browse-btn{width:100%;padding:var(--sp-2);background:none;border:none;color:#ffffff80;font-size:.82rem;text-decoration:underline;text-underline-offset:3px;cursor:pointer}.landing__browse-btn:hover{color:var(--c-aqua)}.login-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-8) var(--sp-4);text-align:center;min-height:300px}.login-prompt__icon{font-size:2.5rem;margin-bottom:var(--sp-4)}.login-prompt__message{font-size:.9rem;color:#fff9;white-space:pre-line;line-height:1.5;margin:0 0 var(--sp-4)}.login-prompt__btn{padding:var(--sp-3) var(--sp-6);background:#34d399;color:var(--c-dark);border:none;border-radius:var(--r-full);font-size:.85rem;font-weight:600;cursor:pointer}.map-login-pill{position:absolute;top:12px;right:60px;z-index:500;display:flex;align-items:center;gap:6px;padding:6px 14px;background:#34d399;color:var(--c-dark);border:none;border-radius:var(--r-full);font-size:.78rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #0003}.map-login-pill.hidden{display:none}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0a1628f7;display:flex;flex-direction:column;align-items:center;justify-content:center}.onboarding-overlay.hidden{display:none}.onboarding__skip{position:absolute;top:16px;right:16px;background:none;border:none;color:#ffffff80;font-size:.85rem;cursor:pointer}.onboarding__content{width:100%;max-width:360px;padding:0 var(--sp-4)}.onboarding__step{display:none;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-3)}.onboarding__step.active{display:flex}.onboarding__icon{font-size:3rem;margin-bottom:var(--sp-2)}.onboarding__title{font-size:1.3rem;font-weight:700;margin:0}.onboarding__desc{font-size:.85rem;color:#fff9;white-space:pre-line;line-height:1.5;margin:0}.onboarding__features-row{display:flex;gap:var(--sp-2);margin:var(--sp-2) 0}.onboarding__feature-chip{display:flex;align-items:center;gap:4px;padding:var(--sp-2) var(--sp-3);background:#ffffff0f;border-radius:var(--r-full);font-size:.78rem;color:#ffffffb3}.onboarding__nav{display:flex;gap:var(--sp-3);margin-top:var(--sp-2)}.onboarding__btn{padding:var(--sp-3) var(--sp-6);border:none;border-radius:var(--r-full);font-size:.9rem;font-weight:600;cursor:pointer}.onboarding__btn--primary{background:var(--c-ocean);color:var(--c-white)}.onboarding__btn--primary:hover{background:var(--c-teal)}.onboarding__btn--secondary{background:#ffffff1a;color:#ffffffb3}.onboarding__dots{position:absolute;bottom:40px;display:flex;gap:8px}.onboarding__dot{width:8px;height:8px;border-radius:50%;background:#fff3}.onboarding__dot.active{background:var(--c-aqua)}.dive-type-freediving{color:#6ecfb0}.dive-type-scuba{color:#e8937a}.dive-icon{display:inline-flex;align-items:center;vertical-align:middle}.review-edit-btn:hover{background:#47c8e01a}.review-delete-btn:hover{background:#ff44441a}.cert-step-select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#1b2838;color:#fff;font-size:14px;margin-bottom:8px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.cert-step-select:focus{border-color:#47c8e0;outline:none}#dive-game-modal canvas{border:2px solid rgba(71,200,224,.3);box-shadow:0 0 30px #47c8e026}.home__greeting{background:#0d1b2a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,171,64,.25);border-radius:16px;padding:16px 20px;margin-bottom:16px;box-shadow:0 4px 24px #00000040,inset 0 1px #ffffff0f}.home__greeting-title{background:linear-gradient(90deg,#ffd166,#f4845f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home__greeting-sub{color:#ffffff8c}.home__greeting img,.greeting-avatar{border:2px solid rgba(255,209,102,.4)!important;box-shadow:0 0 12px #ffab4033!important}.home__stats{background:#ffffff0f!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1)!important;border-radius:14px!important;box-shadow:0 4px 24px #00000040,inset 0 1px #ffffff0f}.home__stat-value{background:linear-gradient(180deg,#ffab40,#ffd166);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800!important}.home__stat-value--sm{background:none!important;-webkit-text-fill-color:rgba(255,255,255,.9)!important;color:#ffffffe6!important;font-weight:500!important}.home__stat-label{color:#fff9}.home__stat-divider{background:#ffffff1a}.home__section-title{color:#f0f4f8;letter-spacing:-.2px}.home__section-meta{color:#7ec87e;font-weight:600}.home__season-card{background:#ffffff0f!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1)!important;border-radius:12px!important;transition:all .25s ease;box-shadow:0 4px 24px #00000040,inset 0 1px #ffffff0f}.home__season-card:hover{background:#ffffff17!important;border-color:#ffd16640!important;transform:translateY(-2px);box-shadow:0 8px 32px #0000004d,0 0 20px #ffd1660f!important}.home__season-badge{background:linear-gradient(135deg,#7ec87e,#c8e64c)!important;color:#0b1622!important;border:none!important;font-weight:700;font-size:11px;padding:3px 12px;border-radius:20px;box-shadow:0 2px 8px #7ec87e4d}.home__season-name{color:#f0f4f8}.home__season-meta{color:#ffab40}.home__recommend-card{background:linear-gradient(135deg,#f4845f47,#ffab4026)!important;border:1px solid rgba(244,132,95,.2)!important;transition:all .25s ease;box-shadow:0 4px 24px #0003,inset 0 1px #ffffff0a}.home__recommend-card:hover{background:linear-gradient(135deg,#f4845f2e,#ffab401a)!important;border-color:#ffd1664d!important;transform:translateY(-2px);box-shadow:0 8px 32px #0000004d,0 0 20px #ffab4014!important}.home__recommend-icon{background:#f4845f4d!important;border:1px solid rgba(244,132,95,.2)}.home__recommend-name{color:#ffd166!important}.home__recommend-score{color:#ffab40!important;font-weight:600}.home__marine-progress{background:#ffffff0f!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:12px}.home__marine-bar{background:#ffffff14!important;border-radius:10px}.home__marine-bar-fill{background:linear-gradient(90deg,#7ec87e,#c8e64c,#ffd166)!important;box-shadow:0 0 12px #7ec87e4d}.home__marine-recent{color:#ffffff80;font-size:.75rem}#home-marine-count{color:#ffd166;font-weight:700}.badge--activity-skin{background:#6ecfb026!important;color:#6ecfb0!important;border:1px solid rgba(110,207,176,.25)!important;padding:2px 10px;border-radius:6px}.badge--activity-scuba{background:#f4845f26!important;color:#f4845f!important;border:1px solid rgba(244,132,95,.25)!important;padding:2px 10px;border-radius:6px}.badge--season{background:linear-gradient(135deg,#7ec87e40,#c8e64c33)!important;color:#7ec87e!important;border:1px solid rgba(126,200,126,.3)!important;font-weight:600}.card__difficulty--beginner{background:#7ec87e26!important;color:#7ec87e!important}.card__difficulty--intermediate{background:#ffd16626!important;color:#ffd166!important}.card__difficulty--advanced{background:#f4845f26!important;color:#f4845f!important}.star-filled,.star-icon.active,[class*=star-filled]{color:#ffd166}.star-empty,.star-icon,[class*=star-empty]{color:#fff3}.home-panel hr{border:none;height:1px;background:linear-gradient(90deg,transparent,rgba(255,209,102,.15),transparent);margin:20px 0}.home-panel::-webkit-scrollbar{width:4px}.home-panel::-webkit-scrollbar-track{background:transparent}.home-panel::-webkit-scrollbar-thumb{background:#ffab404d;border-radius:4px}.home__feature-card{background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:14px;transition:all .2s ease}.home__feature-card:hover{background:#ffffff17;border-color:#ffd16633;box-shadow:0 6px 24px #00000040}.home__login-banner{background:linear-gradient(135deg,#ffab4014,#f4845f0d);border:1px solid rgba(255,209,102,.15);border-radius:12px}.home__login-banner-btn{background:linear-gradient(135deg,#ffab40,#f4845f)!important;color:#0b1622!important;font-weight:700}.field-required{color:var(--c-coral);margin-left:2px}.country-select-wrap{position:relative}.country-input{width:100%;padding:var(--sp-2) var(--sp-3);padding-right:32px;border:1px solid var(--c-gray-300);border-radius:var(--r-md);font-size:.85rem;background:var(--c-gray-100);box-sizing:border-box}.country-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.1rem;color:var(--c-gray-500);cursor:pointer;padding:2px 6px;line-height:1}#spot-country-list{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--c-white);border:1px solid var(--c-gray-300);border-radius:var(--r-md);box-shadow:0 4px 12px #00000026;z-index:100;list-style:none;margin:4px 0 0;padding:0}#spot-country-list li{padding:var(--sp-2) var(--sp-3);cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:8px}#spot-country-list li:hover,#spot-country-list li.active{background:var(--c-gray-100)}#spot-country-list li .country-flag{font-size:1.1rem}.species-input-wrap{position:relative}.species-input{width:100%;padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-gray-200);border-radius:var(--r-md);font-size:.85rem;background:var(--c-gray-100);box-sizing:border-box}#spot-species-list{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--c-white);border:1px solid var(--c-gray-300);border-radius:var(--r-md);box-shadow:0 4px 12px #00000026;z-index:100;list-style:none;margin:4px 0 0;padding:0}#spot-species-list li{padding:var(--sp-2) var(--sp-3);cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:8px}#spot-species-list li:hover,#spot-species-list li.active{background:var(--c-gray-100)}#spot-species-list li .species-emoji{font-size:1.1rem}#spot-species-list li .species-custom{color:var(--c-ocean);font-style:italic}.species-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--sp-2)}.species-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:color-mix(in oklch,var(--c-aqua) 20%,white);color:var(--c-ocean);border-radius:var(--r-full);font-size:.78rem;font-weight:500}.species-tag__remove{background:none;border:none;color:var(--c-gray-500);cursor:pointer;font-size:.9rem;line-height:1;padding:0 2px}.species-tag__remove:hover{color:var(--c-coral)}
