:root{
  --bg:#05080F; --tx:#EAF2FA; --tx2:#8FA3B8; --tx3:#566678;
  --cyan:#2BC6F4; --cyan2:#6FE6FF; --green:#33D277; --gold:#EDC877; --red:#FF5A53;
  --line:rgba(96,170,220,.15); --panel-a:rgba(20,33,52,.66); --panel-b:rgba(11,19,33,.66);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:'Pretendard','Apple SD Gothic Neo',sans-serif;color:var(--tx);letter-spacing:-.3px;
  -webkit-font-smoothing:antialiased;
  background:radial-gradient(140% 60% at 50% -8%,rgba(35,150,210,.16),transparent 58%),#04060c;
  display:flex;justify-content:center}
.phone{width:100%;max-width:460px;min-height:100vh;position:relative;
  background:radial-gradient(130% 55% at 50% -6%,rgba(35,150,210,.18),transparent 56%),var(--bg)}
svg{display:block}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}

/* 스크린 영역 */
#app{padding-bottom:96px;min-height:100vh}
.screen{animation:fade .25s ease}
/* 갯바위 공략집 — 단일HTML 에디터 임베드(탭바 위 전체 영역) */
.galbawi-wrap{position:fixed;top:0;left:50%;transform:translateX(-50%);width:100%;max-width:460px;bottom:calc(58px + env(safe-area-inset-bottom));z-index:6;background:#0a131c;overflow:hidden}
.galbawi-wrap iframe{width:100%;height:100%;border:0;display:block;background:#0a131c}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.statusbar{display:flex;justify-content:space-between;padding:12px 20px 0;font-size:13px;font-weight:600}
.statusbar .r{color:var(--tx2)}

/* 헤더/로고 */
.head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 6px}
.logo{display:flex;align-items:center;gap:9px}
.logo .em{width:30px;height:30px;filter:drop-shadow(0 0 6px rgba(237,200,119,.4))}
.logo .nm{font-size:19px;font-weight:800;background:linear-gradient(180deg,#F7E4A8,#D2A24E);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.head .ic{color:var(--tx2);display:flex;gap:14px;align-items:center}

.scr-top{display:flex;align-items:center;gap:12px;padding:12px 16px 4px}
.scr-top .back{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--tx);background:rgba(20,33,52,.5)}
.scr-top h2{font-size:16px;font-weight:700}

.sec{display:flex;align-items:baseline;justify-content:space-between;margin:24px 20px 12px}
.sec h3{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}
.sec .more{font-size:12.5px;color:var(--tx2)}

.card{background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line);border-radius:18px}
.kicker{font-size:11px;letter-spacing:2px;color:var(--tx3);text-transform:uppercase}

/* 히어로(날씨/안전) */
.hero{margin:12px 20px 0;border-radius:18px;overflow:hidden;position:relative;border:1px solid var(--line);
  min-height:170px}
.hero .sky{position:absolute;inset:0;
  background:radial-gradient(70px 46px at 74% 58%,rgba(255,216,150,.9),rgba(255,170,90,.4) 45%,transparent 72%),
   linear-gradient(180deg,#1e3350 0%,#3d4567 26%,#9c5a44 52%,#d68f4e 62%,#7c5359 70%,#0c1828 82%,#0a1422 100%)}
.hero .grd{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,8,15,.08),rgba(5,8,15,.82))}
.hero .inner{position:relative;padding:14px 16px 16px;min-height:170px;display:flex;flex-direction:column}
.safe{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#bff5d4;
  background:rgba(20,60,40,.5);border:1px solid rgba(51,210,119,.45);padding:6px 12px;border-radius:99px;
  box-shadow:0 0 16px rgba(51,210,119,.22);align-self:flex-start}
.safe .d{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.hero .pt{font-size:20px;font-weight:800;margin-top:auto}
.hero .wx{display:flex;gap:16px;margin-top:7px;font-size:13px;color:#dde7f1;flex-wrap:wrap}
.hero .wx span{display:inline-flex;align-items:center;gap:5px}
.hero .wx svg{color:var(--cyan2)}
.hero .score{position:absolute;right:16px;top:46px;text-align:center}
.hero .score b{font-size:34px;font-weight:800;line-height:1;display:block}
.hero .score small{font-size:11px;color:var(--tx2)}
.hero .score.good b{color:var(--green)} .hero .score.warn b{color:var(--gold)} .hero .score.bad b{color:var(--red)}

/* 등급 */
.rank{margin:12px 20px 0;padding:16px}
.rank .row{display:flex;align-items:center;gap:8px}
.rank .gd{display:inline-flex;align-items:center;gap:7px;font-size:15px;font-weight:800}
.rank .gd svg{filter:drop-shadow(0 0 5px rgba(237,200,119,.5))}
.rank .pos{margin-left:auto;font-size:13px;color:var(--tx2)}
.rank .pos b{color:var(--cyan2);font-weight:800;font-size:15px}
.bar{height:7px;border-radius:99px;background:rgba(255,255,255,.07);margin-top:13px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#2E8FFF,#36D6F5);
  box-shadow:0 0 12px rgba(54,214,245,.6)}
.rank .nx{font-size:12px;color:var(--tx2);margin-top:9px}
.rank .nx b{color:var(--tx)}

/* Bada 추천 배너 */
.bada-cta{margin:14px 20px 0;padding:16px;display:flex;align-items:center;gap:13px;
  background:linear-gradient(120deg,rgba(43,150,220,.18),rgba(20,33,52,.5));border:1px solid rgba(43,198,244,.3);border-radius:18px}
.bada-cta .av{width:42px;height:42px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:rgba(43,198,244,.12);border:1px solid rgba(43,198,244,.4);color:var(--cyan2)}
.bada-cta .tx b{font-size:14px;font-weight:700;display:block}
.bada-cta .tx span{font-size:12px;color:var(--tx2)}
.bada-cta .arr{margin-left:auto;color:var(--cyan2)}

/* 퀵액션 */
.qa{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px 20px 0}
.qa .item{display:flex;align-items:center;gap:11px;padding:15px 14px}
.qa .ico{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  background:rgba(43,198,244,.1);border:1px solid rgba(43,198,244,.28);color:var(--cyan2);flex:0 0 auto}
.qa .ico.gold{background:rgba(237,200,119,.1);border-color:rgba(237,200,119,.32);color:var(--gold)}
.qa .ico.green{background:rgba(51,210,119,.1);border-color:rgba(51,210,119,.32);color:var(--green)}
.qa .tx b{font-size:14px;font-weight:700;display:block} .qa .tx span{font-size:11px;color:var(--tx2)}

/* 리스트 카드 */
.list{padding:0 20px;display:flex;flex-direction:column;gap:12px}
.row{display:flex;align-items:center;gap:13px;padding:14px 16px}
.row .lead{width:40px;height:40px;border-radius:11px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:rgba(43,198,244,.08);border:1px solid var(--line);color:var(--cyan2);font-weight:800}
.row .lead.medal{background:rgba(237,200,119,.1);border-color:rgba(237,200,119,.3);color:var(--gold)}
.row .body{flex:1;min-width:0}
.row .body b{font-size:14.5px;font-weight:700;display:block}
.row .body span{font-size:12px;color:var(--tx2)}
.row .val{text-align:right}
.row .val b{font-size:16px;font-weight:800;color:var(--cyan2)} .row .val small{font-size:11px;color:var(--tx2)}

/* 칩/탭 필터 */
.chips{display:flex;gap:8px;padding:0 20px;overflow-x:auto;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;font-size:13px;font-weight:600;color:var(--tx2);padding:8px 14px;border-radius:99px;
  background:rgba(20,33,52,.5);border:1px solid var(--line)}
.chip.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-color:transparent;font-weight:700}

/* 계측 */
.scan{margin:14px 20px 0;height:240px;border-radius:20px;overflow:hidden;position:relative;border:1px solid var(--line);
  background:radial-gradient(120% 90% at 50% 40%,#10202e,#070d16 72%)}
.scan .fish{position:absolute;top:50%;left:50%;transform:translate(-50%,-48%);width:300px;opacity:.95;
  filter:drop-shadow(0 0 16px rgba(43,198,244,.5))}
.scan .fish svg{width:100%;color:var(--cyan)}
.scan .tick{position:absolute;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan2),transparent);box-shadow:0 0 14px var(--cyan);
  top:0;animation:sweep 2.6s ease-in-out infinite}
@keyframes sweep{0%{top:8px;opacity:0}12%{opacity:1}88%{opacity:1}100%{top:232px;opacity:0}}
/* 사진 기반 AR 계측 */
.scan.photo{background-size:cover;background-position:center}
.scan .camprompt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--tx2)}
.scan .camprompt .cic{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:rgba(43,198,244,.1);border:1px solid rgba(43,198,244,.3);color:var(--cyan2)}
.scan .splabel{position:absolute;top:12px;left:12px;right:12px;text-align:center;font-size:14px;font-weight:800;
  color:#fff;background:rgba(8,14,22,.6);border:1px solid rgba(43,198,244,.35);border-radius:10px;padding:7px 10px;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.scan .splabel em{font-style:normal;color:var(--green)}
.scan .mbox{position:absolute;border:2px solid var(--cyan2);border-radius:4px;box-shadow:0 0 16px rgba(43,198,244,.5),inset 0 0 20px rgba(43,198,244,.12)}
.scan .mline{position:absolute;height:3px;background:var(--green);box-shadow:0 0 10px var(--green);transform-origin:left center}
.scan .mline::before,.scan .mline::after{content:'';position:absolute;width:3px;height:13px;background:var(--green);top:-5px}
.scan .mline::before{left:0}.scan .mline::after{right:0}
.scan .mlen{position:absolute;font-size:14px;font-weight:800;color:#bfffd6;text-shadow:0 1px 4px rgba(0,0,0,.8);background:rgba(8,20,12,.5);padding:2px 7px;border-radius:6px}
.scan .refln{position:absolute;width:3px;background:var(--gold);box-shadow:0 0 8px rgba(237,200,119,.6)}
.scan .refln span{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:12px;font-weight:800;color:var(--gold);white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.8)}
.wchip{position:absolute;right:12px;bottom:54px;font-size:13px;font-weight:700;color:#fff;background:rgba(8,14,22,.66);border:1px solid var(--line);border-radius:9px;padding:7px 11px}
.sflsave{position:absolute;left:12px;right:12px;bottom:12px;border:0;border-radius:11px;padding:13px;font-size:14.5px;font-weight:800;color:#3a1d00;background:linear-gradient(90deg,#F7E4A8,#E0A94E);box-shadow:0 6px 18px rgba(224,169,78,.4);display:flex;align-items:center;justify-content:center;gap:7px}
.sflsave:disabled{filter:grayscale(.4);opacity:.7}
.scan .read{position:absolute;top:16px;left:14px;display:flex;flex-direction:column;gap:8px}
.pill{display:inline-flex;align-items:center;gap:8px;background:rgba(8,18,28,.66);border:1px solid rgba(43,198,244,.4);
  border-radius:10px;padding:8px 12px;font-size:14px;font-weight:700;box-shadow:0 0 18px rgba(43,198,244,.16)}
.pill .k{color:var(--tx2);font-weight:600;font-size:12.5px} .pill .v{color:var(--cyan2)}
.vfd{position:absolute;left:14px;bottom:14px;display:inline-flex;align-items:center;gap:8px;background:rgba(8,24,16,.7);
  border:1px solid rgba(51,210,119,.5);border-radius:10px;padding:8px 13px;font-size:14px;font-weight:800;color:#bff5d4}
.vfd svg{color:var(--green)}
.data{margin:18px 20px 0;display:flex;flex-direction:column;gap:12px}
.drow{display:flex;align-items:center;gap:14px;padding:15px 16px;border-radius:15px;
  background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line)}
.drow .ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:rgba(43,198,244,.1);border:1px solid rgba(43,198,244,.3);color:var(--cyan2);flex:0 0 auto}
.drow.ok .ic{background:rgba(51,210,119,.1);border-color:rgba(51,210,119,.4);color:var(--green)}
.drow .lab{font-size:13px;color:var(--tx2)} .drow .num{font-size:21px;font-weight:800;margin-top:1px}
.drow .num .u{font-size:13px;color:var(--tx2);font-weight:600;margin-left:2px}
.drow .num.c{color:var(--cyan2)} .drow .num.g{color:var(--green);font-size:18px}
.drow .sub{font-size:12px;color:var(--tx2);margin-top:2px}

/* 큰 버튼 */
.btn{margin:18px 20px 0;width:calc(100% - 40px);border:0;border-radius:14px;padding:16px;font-size:15.5px;font-weight:800;
  color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);box-shadow:0 8px 26px rgba(46,143,255,.36)}
.btn:active{filter:brightness(.97)}
.btn.ghost{background:transparent;color:var(--tx2);box-shadow:none;border:1px solid var(--line)}

/* Bada 화면 */
.bada-msg{margin:8px 20px 0;padding:18px}
.bada-msg .who{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--tx2)}
.bada-msg .who b{color:var(--tx)}
.bada-msg .msg{font-size:18px;font-weight:700;margin-top:12px;line-height:1.45}
.bada-msg .msg .c{color:var(--cyan2)}
.win{display:flex;align-items:center;margin-top:16px;padding:14px 16px;border-radius:13px;
  background:rgba(43,198,244,.08);border:1px solid rgba(43,198,244,.28)}
.win .l{font-size:13px;color:var(--tx2)} .win .p{margin-left:auto;font-size:26px;font-weight:800;color:var(--cyan2);
  text-shadow:0 0 16px rgba(43,198,244,.5)}
.strat{display:grid;grid-template-columns:1fr 1fr 1fr;gap:11px;padding:0 20px}
.st{padding:15px 8px;text-align:center;border-radius:15px;background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line)}
.st .ic{width:40px;height:40px;margin:0 auto 9px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(43,198,244,.1);border:1px solid rgba(43,198,244,.28);color:var(--cyan2)}
.st .l{font-size:11px;color:var(--tx2)} .st .v{font-size:14px;font-weight:800;margin-top:3px}
.st .v small{display:block;font-size:11px;color:var(--tx2);font-weight:600}

/* 알림/빈/로딩 */
.note{margin:14px 20px 0;padding:13px 15px;border-radius:13px;font-size:12.5px;color:var(--tx2);
  background:rgba(237,200,119,.06);border:1px solid rgba(237,200,119,.22);display:flex;gap:9px;align-items:flex-start}
.note svg{color:var(--gold);flex:0 0 auto;margin-top:1px}
.loading{padding:60px 0;text-align:center;color:var(--tx2);font-size:13px}
.spin{width:24px;height:24px;border:2.5px solid rgba(43,198,244,.2);border-top-color:var(--cyan2);border-radius:50%;
  margin:0 auto 12px;animation:rot .8s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}

/* 프로필 */
.profile{margin:14px 20px 0;padding:20px;display:flex;align-items:center;gap:14px}
.profile .av{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#2b4a66,#16242f);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--cyan2)}
.profile .nm{font-size:18px;font-weight:800} .profile .tier{font-size:12.5px;color:var(--gold);margin-top:2px}
.menu{margin:14px 20px 0;border-radius:16px;overflow:hidden;background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line)}
.menu a{display:flex;align-items:center;gap:13px;padding:15px 16px;font-size:14px}
.menu a+a{border-top:1px solid rgba(255,255,255,.05)}
.menu a svg{color:var(--cyan2)} .menu a .arr{margin-left:auto;color:var(--tx3)}

/* 선장 공지 실시간 팝업 */
.cap-alert{position:fixed;inset:0;z-index:80;max-width:460px;margin:0 auto;display:flex;align-items:flex-start;justify-content:center;padding-top:60px;pointer-events:none;animation:fade .2s both}
.cap-alert .ca-box{pointer-events:auto;width:calc(100% - 40px);background:linear-gradient(180deg,#173042,#0e2030);border:1px solid rgba(43,198,244,.45);border-radius:16px;padding:16px;box-shadow:0 16px 40px rgba(0,0,0,.5),0 0 26px rgba(43,198,244,.18);animation:up .35s cubic-bezier(.2,.9,.25,1) both}
.cap-alert .ca-h{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--cyan2)}
.cap-alert .ca-m{font-size:15px;font-weight:600;margin:9px 0 14px;line-height:1.5}
.cap-alert button{width:100%;border:0;border-radius:11px;padding:13px;font-weight:800;color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF)}

/* 결제 시트 (샌드박스 PG) */
.pay-dim{position:fixed;inset:0;z-index:70;max-width:460px;margin:0 auto;background:rgba(4,7,14,.62);display:flex;align-items:flex-end;animation:fade .25s both}
.pay-sheet{width:100%;background:linear-gradient(180deg,#161d2e,#0e1422);border:1px solid var(--line);border-radius:22px 22px 0 0;padding:12px 20px calc(20px + env(safe-area-inset-bottom));box-shadow:0 -20px 50px rgba(0,0,0,.5);animation:up .4s cubic-bezier(.2,.9,.25,1) both}
.pay-sheet .grab{width:38px;height:4px;border-radius:99px;background:rgba(255,255,255,.16);margin:0 auto 16px}
.pay-sheet h3{font-size:17px;font-weight:800}
.pay-sheet .amt{font-size:30px;font-weight:800;margin:8px 0 4px;letter-spacing:-1px}
.pay-sheet .ttl{font-size:13px;color:var(--tx2)}
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0 6px}
.pay-methods .m{display:flex;align-items:center;gap:9px;padding:14px;border-radius:13px;background:rgba(20,33,52,.5);border:1px solid var(--line);font-size:14px;font-weight:600;color:var(--tx)}
.pay-methods .m.on{border-color:var(--cyan2);background:rgba(43,198,244,.1)}
.pay-methods .m .dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--tx3);flex:0 0 auto}
.pay-methods .m.on .dot{border-color:var(--cyan2);background:radial-gradient(circle,var(--cyan2) 40%,transparent 45%)}
.pay-sheet .legal{font-size:10.5px;color:var(--tx3);margin:10px 0 0;line-height:1.5;text-align:center}
.pay-sheet .go{width:100%;border:0;border-radius:14px;padding:16px;font-size:16px;font-weight:800;color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);box-shadow:0 8px 24px rgba(46,143,255,.32);margin-top:12px}
.pay-sheet .go:disabled{filter:grayscale(.4);opacity:.75}
.pay-sheet .cancel{width:100%;background:none;border:0;color:var(--tx3);font-size:13px;padding:11px;margin-top:4px}
.pay-receipt{text-align:center;padding:8px 0}
.pay-receipt .ck{width:60px;height:60px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:rgba(51,210,119,.12);border:1px solid rgba(51,210,119,.4);color:var(--green)}
.pay-receipt .rows{margin:14px 0 0;border-top:1px solid var(--line)}
.pay-receipt .rw{display:flex;justify-content:space-between;padding:10px 2px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05)}
.pay-receipt .rw .k{color:var(--tx2)} .pay-receipt .rw .v{font-weight:600}

/* AI 예측 히트맵 (Predictive Analytics) */
.heat{margin:0 20px;border-radius:16px;overflow:hidden;border:1px solid var(--line);position:relative;background:#060d16;aspect-ratio:1/1}
.heat .layer{position:absolute;inset:-8%;display:grid;filter:blur(9px)}
.heat .pins{position:absolute;inset:0;z-index:3}
.heat .pin{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px}
.heat .pin .d{width:11px;height:11px;border-radius:50%;background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.18),0 0 10px rgba(255,255,255,.6)}
.heat .pin .p{font-size:10.5px;font-weight:800;color:#fff;background:rgba(8,14,22,.7);border:1px solid rgba(255,255,255,.25);padding:1px 6px;border-radius:99px;white-space:nowrap}
.heat .pin.top .d{background:var(--gold);box-shadow:0 0 0 5px rgba(237,200,119,.25),0 0 14px var(--gold)}
.heat .tag{position:absolute;top:10px;left:10px;z-index:4;font-size:11px;font-weight:700;color:var(--cyan2);background:rgba(8,14,22,.7);border:1px solid rgba(43,198,244,.4);padding:5px 11px;border-radius:99px}
.heat .legend{position:absolute;bottom:10px;left:10px;right:10px;z-index:4;display:flex;align-items:center;gap:8px;font-size:10px;color:var(--tx2)}
.heat .legend .bar{flex:1;height:6px;border-radius:99px;background:linear-gradient(90deg,#13386b,#2BC6F4,#7BE0A0,#EDC877,#FF6A4D)}
.hotlist{padding:12px 20px 0;display:flex;flex-direction:column;gap:10px}
.hotrow{display:flex;align-items:center;gap:11px;padding:12px 14px;border-radius:13px;background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line)}
.hotrow .rk{width:24px;height:24px;border-radius:7px;background:rgba(43,198,244,.12);border:1px solid rgba(43,198,244,.3);color:var(--cyan2);font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.hotrow .nm{flex:1;min-width:0}.hotrow .nm b{font-size:14px;font-weight:700;display:block}.hotrow .nm span{font-size:11.5px;color:var(--tx2)}
.hotrow .pp{text-align:right}.hotrow .pp b{font-size:17px;font-weight:800;color:var(--cyan2)}.hotrow .pp small{font-size:10px;color:var(--tx2);display:block}

/* 어복스토리 (소셜 피드) */
.feed{display:flex;flex-direction:column;gap:16px;padding:6px 16px 0}
.post{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel-a),var(--panel-b))}
.post .ph{display:flex;align-items:center;gap:10px;padding:12px 14px}
.post .ph .av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2b4a66,#16242f);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--cyan2);flex:0 0 auto}
.post .ph .nm{flex:1;min-width:0}
.post .ph .nm b{font-size:14px;font-weight:700;display:block}
.post .ph .nm span{font-size:11.5px;color:var(--tx2)}
.post .ph .more{color:var(--tx3)}
.post .pic{position:relative;aspect-ratio:1/1}
.t0{background:radial-gradient(120% 80% at 72% 18%,rgba(96,142,168,.4),transparent 60%),linear-gradient(160deg,#1c2730,#0f161d)}
.t1{background:radial-gradient(120% 80% at 70% 20%,rgba(168,140,96,.3),transparent 60%),linear-gradient(160deg,#262019,#13100c)}
.t2{background:radial-gradient(120% 80% at 68% 22%,rgba(96,150,140,.32),transparent 60%),linear-gradient(160deg,#16282a,#0c1718)}
.t3{background:radial-gradient(120% 80% at 74% 16%,rgba(120,110,170,.3),transparent 60%),linear-gradient(160deg,#1b1c2e,#0e0f1a)}
.post .pic .fishwm{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(43,198,244,.16)}
.post .pic .fishwm svg{width:72%}
.post .pic .len{position:absolute;right:12px;bottom:12px;font-size:34px;font-weight:800;color:rgba(255,255,255,.14);font-variant-numeric:tabular-nums}
.post .vf{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:#bff5d4;background:rgba(8,24,16,.6);border:1px solid rgba(51,210,119,.45);padding:5px 10px;border-radius:99px}
.post .vf svg{color:var(--green)}
.post .spec{position:absolute;left:12px;bottom:12px;font-size:16px;font-weight:800;text-shadow:0 1px 6px rgba(0,0,0,.7)}
.post .spec small{font-size:12px;color:#d7e0ec;font-weight:600}
.post .bd{padding:12px 14px}
.post .cap{font-size:13.5px;line-height:1.55}
.post .tags{margin-top:7px;display:flex;flex-wrap:wrap;gap:6px}
.post .tags a{font-size:11.5px;color:var(--cyan2)}
.post .spon{margin-top:11px;display:flex;align-items:center;gap:7px}
.post .spon .lab{font-size:10px;color:var(--tx3)}
.post .spon .b{font-size:10.5px;font-weight:800;letter-spacing:.5px;color:var(--gold);border:1px solid rgba(237,200,119,.35);padding:3px 8px;border-radius:6px}
.post .act{display:flex;align-items:center;gap:18px;padding:11px 14px;border-top:1px solid rgba(255,255,255,.05);color:var(--tx2);font-size:13px}
.post .act .b{display:inline-flex;align-items:center;gap:6px}
.post .act .b.on{color:var(--red)} .post .act .b.on svg{fill:var(--red);color:var(--red)}
.post .act .b b{color:var(--tx);font-weight:600;font-variant-numeric:tabular-nums}
.post .act .sh{margin-left:auto}
.story-strip{display:flex;flex-direction:column;gap:12px;padding:0 16px}

/* 로그인 / 온보딩 */
.auth{min-height:100vh;display:flex;flex-direction:column;padding:0 26px calc(34px + env(safe-area-inset-bottom))}
.auth .hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;padding-top:40px}
.auth .em{width:74px;height:74px;filter:drop-shadow(0 0 14px rgba(237,200,119,.45))}
.auth .nm{font-size:30px;font-weight:800;background:linear-gradient(180deg,#F7E4A8,#D2A24E);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-1px}
.auth .tag{font-size:14px;color:var(--tx2);line-height:1.6}
.auth .form{display:flex;flex-direction:column;gap:11px;margin-top:8px}
.auth input{width:100%;background:rgba(20,33,52,.55);border:1px solid var(--line);border-radius:13px;padding:15px 16px;color:var(--tx);font-size:15px;font-family:inherit}
.auth input::placeholder{color:var(--tx3)}
.auth input:focus{outline:none;border-color:rgba(43,198,244,.5)}
.auth .primary{width:100%;border:0;border-radius:14px;padding:16px;font-size:16px;font-weight:800;color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);box-shadow:0 8px 24px rgba(46,143,255,.32);margin-top:4px}
.auth .swap{text-align:center;font-size:13px;color:var(--tx2);margin-top:14px}
.auth .swap b{color:var(--cyan2)}
.auth .demo{margin-top:22px;border-top:1px solid var(--line);padding-top:18px}
.auth .demo .lab{font-size:11px;letter-spacing:1.5px;color:var(--tx3);text-align:center;margin-bottom:11px}
.auth .demo .row{display:flex;gap:10px}
.auth .demo button{flex:1;background:rgba(20,33,52,.55);border:1px solid var(--line);border-radius:12px;padding:13px;color:var(--tx);font-size:13px;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:3px}
.auth .demo button span{font-size:10.5px;color:var(--tx3);font-weight:500}
.auth .err{color:var(--red);font-size:12.5px;text-align:center;min-height:16px}
/* 온보딩(전자승선명부 1회성 가입 게이트) */
.auth .steps{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11px;color:var(--tx3);margin:2px 0 10px;flex-wrap:wrap}
.auth .steps span{padding:4px 9px;border-radius:99px;border:1px solid var(--line);white-space:nowrap}
.auth .steps span.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-color:transparent;font-weight:800}
.auth .steps span.done{color:var(--green);border-color:rgba(51,210,119,.4)}
.auth .steps i{color:var(--tx3);font-style:normal}
.auth .branch{background:rgba(43,198,244,.07);border:1px solid rgba(43,198,244,.22);border-radius:12px;padding:12px 14px;font-size:13px;line-height:1.6;color:var(--tx);margin-bottom:12px}
.auth .branch b{color:var(--cyan2)}
.auth .hint{color:var(--tx3);font-size:11.5px}
.auth b.hint{display:inline-block;margin-left:6px;color:var(--gold);letter-spacing:1px}
.auth input.otp{text-align:center;letter-spacing:8px;font-size:20px;font-weight:800}
.auth .seg{display:flex;gap:10px}
.auth .seg button{flex:1;background:rgba(20,33,52,.55);border:1px solid var(--line);border-radius:13px;padding:14px;color:var(--tx2);font-size:15px;font-weight:700;font-family:inherit}
.auth .seg button.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-color:transparent}
.auth .consent{display:flex;gap:10px;align-items:flex-start;font-size:12px;line-height:1.55;color:var(--tx2);text-align:left;padding:2px 0}
.auth .consent input{width:20px;height:20px;flex:0 0 20px;margin-top:1px;accent-color:#2E8FFF}
.auth .consent b{color:var(--cyan2)}
.auth .back-link{text-align:center;font-size:12.5px;color:var(--tx3);margin-top:6px;cursor:pointer}
.auth .upload{display:flex;align-items:center;justify-content:center;text-align:center;gap:8px;background:rgba(20,33,52,.55);border:1px dashed var(--line);border-radius:13px;padding:17px 14px;color:var(--tx2);font-size:14px;font-weight:600;cursor:pointer}
.auth .upload.done{border-style:solid;border-color:rgba(51,210,119,.45);color:var(--green);background:rgba(51,210,119,.07)}
.auth .upload.disabled{opacity:.45;pointer-events:none}
.auth .primary:disabled{opacity:.4;box-shadow:none;cursor:default}

/* ===== 해양 기상 지도 ===== */
.wm-adv{margin:10px 20px 0;border-radius:13px;padding:11px 14px;display:flex;flex-direction:column;gap:8px;border:1px solid var(--line);background:var(--panel-a)}
.wm-adv .hd{font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:6px;color:var(--tx)}
.wm-adv.none{flex-direction:row;align-items:center;color:var(--green);font-size:12.5px;font-weight:600;border-color:rgba(51,210,119,.3);background:rgba(51,210,119,.06)}
.wm-adv.adv{border-color:rgba(43,198,244,.35);background:rgba(43,198,244,.07)} .wm-adv.adv .hd{color:var(--cyan2)}
.wm-adv.warn{border-color:rgba(237,200,119,.4);background:rgba(237,200,119,.08)} .wm-adv.warn .hd{color:var(--gold)}
.wm-adv.crit{border-color:rgba(255,90,83,.5);background:rgba(255,90,83,.1)} .wm-adv.crit .hd{color:var(--red)}
.wm-adv .acs{display:flex;flex-wrap:wrap;gap:6px}
.ac{font-size:11px;font-weight:700;padding:4px 9px;border-radius:99px;border:1px solid var(--line);color:var(--tx2);white-space:nowrap}
.ac.advisory{color:var(--gold);border-color:rgba(237,200,119,.4)} .ac.warning{color:#ffd0cc;background:rgba(255,90,83,.16);border-color:rgba(255,90,83,.5)}
.ac.more{color:var(--cyan2);cursor:pointer}
.wm-tystrip{margin:10px 20px 0;border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;border:1px solid rgba(255,90,83,.4);background:linear-gradient(100deg,rgba(255,90,83,.12),rgba(20,33,52,.5))}
.wm-tystrip.warn{border-color:rgba(237,200,119,.4);background:linear-gradient(100deg,rgba(237,200,119,.1),rgba(20,33,52,.5))}
.wm-tystrip.adv{border-color:var(--line);background:var(--panel-a)}
.wm-tystrip .sp{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--red);background:rgba(255,90,83,.14);animation:wspin 3s linear infinite}
.wm-tystrip.warn .sp{color:var(--gold);background:rgba(237,200,119,.14)}
.wm-tystrip .tx{flex:1;display:flex;flex-direction:column;gap:2px}.wm-tystrip .tx b{font-size:14px}.wm-tystrip .tx span{font-size:11.5px;color:var(--tx2)}
.wm-tystrip .arr{color:var(--tx3)}
@keyframes wspin{to{transform:rotate(360deg)}}
.wm-card{margin:12px 20px 0;background:var(--panel-a);border:1px solid var(--line);border-radius:18px;padding:14px;backdrop-filter:blur(8px)}
.wm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.wm-head .ttl{font-size:14px;font-weight:800;display:flex;align-items:center;gap:5px}
.wm-head .sub{font-size:11px;color:var(--tx3);margin-top:2px}
.wm-head .scope{display:flex;background:rgba(11,19,33,.7);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.wm-head .scope button{padding:7px 13px;font-size:12px;font-weight:700;color:var(--tx2);background:transparent;font-family:inherit}
.wm-head .scope button.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF)}
.wm-map{position:relative;width:100%;aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:radial-gradient(120% 100% at 50% 0,#0a1830,#05080f);box-shadow:inset 0 0 40px rgba(0,0,0,.5),inset 0 0 0 1px var(--line)}
.wm-grid{position:absolute;inset:0;display:grid;grid-auto-rows:1fr;filter:blur(7px) saturate(1.12);transform:scale(1.08)}
.wm-grid i{display:block;width:100%;height:100%;cursor:pointer;transition:background .3s}
.wm-grid i.sel{box-shadow:inset 0 0 0 2px #fff}
.wm-grat{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent 0 24px,rgba(143,163,184,.07) 24px 25px),repeating-linear-gradient(90deg,transparent 0 24px,rgba(143,163,184,.07) 24px 25px)}
.zlab{position:absolute;transform:translate(-50%,-50%);font-size:9.5px;font-weight:700;color:#dce8f5;text-shadow:0 1px 4px #000;background:rgba(5,8,15,.4);padding:1px 5px;border-radius:6px;pointer-events:none;white-space:nowrap}
.wm-here{position:absolute;width:14px;height:14px;transform:translate(-50%,-50%);border-radius:50%;background:var(--cyan2);box-shadow:0 0 0 4px rgba(43,198,244,.3),0 0 14px var(--cyan);animation:wpulse 1.8s ease-out infinite}
@keyframes wpulse{0%{box-shadow:0 0 0 2px rgba(43,198,244,.5),0 0 12px var(--cyan)}70%{box-shadow:0 0 0 12px rgba(43,198,244,0),0 0 12px var(--cyan)}100%{box-shadow:0 0 0 2px rgba(43,198,244,0)}}
.wm-track{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.wm-track path{fill:none;stroke:#ff7a73;stroke-width:2;stroke-dasharray:4 3;vector-effect:non-scaling-stroke;opacity:.85;filter:drop-shadow(0 0 4px rgba(255,90,83,.6))}
.wm-tydot{position:absolute;width:6px;height:6px;transform:translate(-50%,-50%);border-radius:50%;background:rgba(255,140,120,.7);pointer-events:none}
.wm-ty{position:absolute;width:30px;height:30px;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;color:#fff;border-radius:50%;background:radial-gradient(circle,rgba(255,90,83,.5),rgba(255,90,83,.05));box-shadow:0 0 16px rgba(255,90,83,.7);animation:wspin 2.4s linear infinite}
.wm-ty .eye{position:absolute;width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 8px #fff}
.wm-badge{position:absolute;left:10px;bottom:10px;font-size:10px;color:var(--tx2);background:rgba(5,8,15,.55);border:1px solid var(--line);padding:3px 8px;border-radius:99px;display:flex;align-items:center;gap:5px;backdrop-filter:blur(4px)}
.wm-badge.live{color:var(--green);border-color:rgba(51,210,119,.4)}
.wm-badge.live .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:wpulse 1.6s ease-out infinite}
.wm-tynote{margin:10px 20px 0;font-size:11.5px;color:var(--tx2);background:var(--panel-a);border:1px solid var(--line);border-radius:12px;padding:10px 13px;display:flex;align-items:center;gap:7px;line-height:1.5}
.wm-tynote svg{color:var(--tx3);flex:0 0 auto}
/* 위성지도(Leaflet) 해양 기상 */
.wm-wrap{position:relative;margin:10px 20px 0;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.wm-leaflet{width:100%;height:360px;background:#08111f}
.wm-leaflet .leaflet-control-zoom{border:0;box-shadow:0 2px 10px rgba(0,0,0,.5)}
.wm-leaflet .leaflet-control-zoom a{background:rgba(11,19,33,.92);color:var(--tx);border-color:var(--line)}
.wm-leaflet .leaflet-control-zoom a:hover{background:rgba(20,33,52,.95)}
.leaflet-container{background:#08111f;font-family:inherit}
img.wm-heat,.wm-heat img{image-rendering:auto;mix-blend-mode:screen}
img.wm-temp,.wm-temp img,img.wm-heat.wm-temp{mix-blend-mode:screen;animation:wmShimmer 4.5s ease-in-out infinite}
@keyframes wmShimmer{0%,100%{filter:brightness(1) saturate(1);opacity:.62}50%{filter:brightness(1.13) saturate(1.18);opacity:.72}}
.wm-tyicon{filter:drop-shadow(0 0 7px rgba(255,108,92,.85))}
.wm-tyicon .ty-spin{display:flex;align-items:center;justify-content:center;width:42px;height:42px;color:#ff7a73;border-radius:50%;background:radial-gradient(circle,rgba(255,108,92,.34),rgba(255,108,92,0) 68%);animation:tySpin 3.4s linear infinite}
.wm-tyicon .ty-spin svg{filter:drop-shadow(0 0 2px rgba(255,210,200,.9))}
@keyframes tySpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.wm-rain{position:absolute;left:0;top:0;z-index:450;pointer-events:none}
.wm-wave{position:absolute;left:0;top:0;z-index:445;pointer-events:none;mix-blend-mode:screen}
/* 위성 화질 보정 + 갯바위/지점 조회 */
.leaflet-container .wm-sat{filter:contrast(1.07) saturate(1.13) brightness(1.03)}
.wm-leaflet .leaflet-tile{image-rendering:auto;-webkit-backface-visibility:hidden;backface-visibility:hidden}
.wm-coast{filter:drop-shadow(0 0 1.5px rgba(120,200,255,.55))}
.wm-pinicon .wm-pindot{display:block;width:16px;height:16px;border-radius:50%;background:radial-gradient(circle at 50% 40%,#7ff0ff,#2e8fff 62%,rgba(46,143,255,0) 74%);box-shadow:0 0 0 2px rgba(255,255,255,.9),0 0 12px rgba(54,214,245,.9);animation:wmPinPulse 1.8s ease-out infinite}
@keyframes wmPinPulse{0%{box-shadow:0 0 0 2px rgba(255,255,255,.9),0 0 0 0 rgba(54,214,245,.55)}70%{box-shadow:0 0 0 2px rgba(255,255,255,.9),0 0 0 13px rgba(54,214,245,0)}100%{box-shadow:0 0 0 2px rgba(255,255,255,.9),0 0 0 0 rgba(54,214,245,0)}}
.wm-poplf .leaflet-popup-content-wrapper{background:rgba(10,16,28,.95);color:var(--tx);border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 32px rgba(0,0,0,.55);backdrop-filter:blur(6px)}
.wm-poplf .leaflet-popup-content{margin:10px 12px;font-family:inherit;line-height:1.3}
.wm-poplf .leaflet-popup-tip{background:rgba(10,16,28,.95);border:1px solid var(--line)}
.wm-poplf a.leaflet-popup-close-button{color:var(--tx3);padding:7px 8px 0 0}
.wm-pop .ph{font-size:11px;color:var(--tx2);display:flex;align-items:center;gap:5px;margin-bottom:9px;white-space:nowrap}
.wm-pop .ph span{margin-left:auto;color:var(--cyan2);font-weight:700}
.wm-pop .pg{display:grid;grid-template-columns:1fr 1fr;gap:7px 16px;min-width:190px}
.wm-pop .pi{display:flex;align-items:baseline;justify-content:space-between;gap:8px;font-size:12px}
.wm-pop .pi>span{color:var(--tx3)}
.wm-pop .pi b{font-size:15px;font-weight:800;color:var(--cyan2);white-space:nowrap}
.wm-pop .pi b small{font-size:9.5px;font-weight:600;color:var(--tx3);margin-left:2px}
.wm-pop .pi.land{grid-column:1/3;justify-content:flex-start;gap:6px;color:var(--tx2);font-size:11.5px}
.wm-pop .ph .pp-ex{font-style:normal;font-size:9px;font-weight:800;color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-radius:5px;padding:1px 5px;letter-spacing:.3px}
.wm-loading{position:absolute;inset:0;z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:rgba(5,8,15,.78);color:var(--tx2);font-size:13px;backdrop-filter:blur(2px)}
.wm-loading svg{color:var(--cyan2);animation:wpulse 1.6s ease-out infinite}
.wm-wrap .wm-badge{z-index:500}
.wm-legend-ov{position:absolute;left:10px;right:10px;bottom:10px;z-index:500;display:flex;align-items:center;gap:8px;background:rgba(5,8,15,.5);border:1px solid var(--line);border-radius:99px;padding:5px 10px;backdrop-filter:blur(4px);font-size:10px;color:var(--tx2)}
.wm-legend-ov .bar{flex:1;height:6px;border-radius:99px}
.wm-time{display:flex;align-items:center;gap:11px;margin:12px 20px 0}
.wm-time .play{flex:0 0 auto;width:42px;height:42px;border:0;border-radius:50%;background:linear-gradient(135deg,#36D6F5,#2E8FFF);color:#04121b;font-size:15px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(46,143,255,.3)}
.wm-time .t{flex:0 0 auto;font-size:13px;font-weight:700;color:var(--cyan2);min-width:64px;text-align:right}
.wm-time input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:99px;background:rgba(255,255,255,.12)}
.wm-time input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--cyan2);box-shadow:0 0 10px rgba(43,198,244,.7);cursor:pointer}
.wm-time input[type=range]::-moz-range-thumb{width:18px;height:18px;border:0;border-radius:50%;background:var(--cyan2)}
.wm-rangs{display:flex;gap:8px;margin:10px 20px 0}
.wm-rangs button{flex:1;padding:8px;font-size:12px;font-weight:700;color:var(--tx2);background:var(--panel-a);border:1px solid var(--line);border-radius:10px;font-family:inherit}
.wm-rangs button.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-color:transparent}
.wxm .wm-chips{padding:0 20px;margin-top:12px}
.wm-readout{text-align:center;font-size:12.5px;color:var(--tx2);margin:11px 20px 0}
.wm-readout b{color:var(--cyan2)}
.wm-tide{margin:14px 20px 0;background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:12px 14px}
.wm-tide .hd{font-size:11.5px;color:var(--tx2);display:flex;align-items:center;gap:6px;margin-bottom:8px}
.wm-tide .hd b{margin-left:auto;color:var(--cyan2);font-size:13px}
.wm-tide .chart{position:relative;height:66px;cursor:pointer}
.wm-tide .chart svg{width:100%;height:100%;overflow:visible}
.wm-tide .chart polyline{fill:none;stroke:var(--cyan2);stroke-width:2;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 4px rgba(43,198,244,.5))}
.wm-tide .chart polygon.area{fill:rgba(43,198,244,.14);stroke:none}
.wm-tide .src{font-size:9.5px;font-weight:700;color:var(--green);border:1px solid rgba(51,210,119,.4);border-radius:99px;padding:1px 6px;margin-left:2px}
.wm-tide .mk{position:absolute;top:-3px;bottom:-3px;width:2px;background:rgba(255,255,255,.6);box-shadow:0 0 6px rgba(255,255,255,.5)}
.wm-tide .chart .tmk{position:absolute;width:7px;height:7px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2}
.wm-tide .chart .tmk.hi{background:#ff8a5c;box-shadow:0 0 7px rgba(255,138,92,.95)}
.wm-tide .chart .tmk.lo{background:#36D6F5;box-shadow:0 0 7px rgba(54,214,245,.95)}
/* 만조/간조 목록 */
.wm-tide .tide-ext{display:flex;flex-wrap:wrap;gap:5px 12px;margin-top:9px;font-size:10.5px;color:var(--tx2)}
.wm-tide .tide-ext span{display:inline-flex;align-items:baseline;gap:3px}
.wm-tide .tide-ext span.hi{color:#ffb089} .wm-tide .tide-ext span.lo{color:#7fd9f0}
.wm-tide .tide-ext b{font-size:12px;font-weight:800;color:var(--tx)} .wm-tide .tide-ext i{font-style:normal;font-size:8.5px;color:var(--tx3)}
.wm-tide .tide-hint{margin-top:9px;font-size:10px;color:var(--tx3);display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.wm-tide .tide-hint #wmFlowNow b{font-weight:800}
.wm-tide .tide-hint #wmFlowNow b.in{color:#5fd0ff} .wm-tide .tide-hint #wmFlowNow b.out{color:#ffb089} .wm-tide .tide-hint #wmFlowNow b.slack{color:var(--tx3)}
/* 물때 헤더 */
.wm-tide .mul-hd{display:flex;align-items:center;gap:11px;margin-bottom:11px}
.wm-tide .mul-badge{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:58px;padding:6px 8px;border-radius:11px;line-height:1.1;border:1px solid var(--line);background:rgba(255,255,255,.04)}
.wm-tide .mul-badge b{font-size:17px;font-weight:900;color:var(--tx)} .wm-tide .mul-badge span{font-size:10px;font-weight:700;margin-top:2px;color:var(--tx2)}
.wm-tide .mul-badge.sari{border-color:rgba(255,138,92,.55);background:rgba(255,138,92,.12)} .wm-tide .mul-badge.sari b,.wm-tide .mul-badge.sari span{color:#ff9a6a}
.wm-tide .mul-badge.jogeum{border-color:rgba(54,214,245,.5);background:rgba(54,214,245,.1)} .wm-tide .mul-badge.jogeum b,.wm-tide .mul-badge.jogeum span{color:#5fd0ff}
.wm-tide .mul-bar{flex:1;display:flex;flex-direction:column;gap:4px;font-size:10px;color:var(--tx3)}
.wm-tide .mul-bar label{font-weight:700}
.wm-tide .mul-bar i{display:block;height:7px;border-radius:99px;background:rgba(255,255,255,.1);overflow:hidden}
.wm-tide .mul-bar u{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#36D6F5,#ff8a5c)}
.wm-tide .mul-bar>b{position:static;align-self:flex-end;font-size:11px;font-weight:800;color:var(--cyan2);margin-top:-16px}
/* 물때표 7일 */
.wm-tide .mul-sub{margin-top:12px;font-size:10px;color:var(--tx3);font-weight:600}
.wm-tide .mul-tab{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-top:6px}
.wm-tide .mul-tab .mt{display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 2px;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid transparent}
.wm-tide .mul-tab .mt .d{font-size:8.5px;color:var(--tx3)} .wm-tide .mul-tab .mt b{font-size:12px;font-weight:800;color:var(--tx)} .wm-tide .mul-tab .mt .p{font-size:8px;color:var(--tx3)}
.wm-tide .mul-tab .mt.on{border-color:var(--cyan2);background:rgba(43,198,244,.14)} .wm-tide .mul-tab .mt.on .d{color:var(--cyan2)}
.wm-tide .mul-tab .mt.sari b{color:#ff9a6a} .wm-tide .mul-tab .mt.jogeum b{color:#5fd0ff}
.wm-tide .mul-tab .mt{cursor:pointer;transition:background .12s}
.wm-tide .mul-tab .mt:active{background:rgba(43,198,244,.2)}
.wm-tide .tide-loc{font-size:9.5px;font-weight:700;color:var(--cyan2);display:inline-flex;align-items:center;gap:2px;margin-left:4px}
.wm-loading-sm{margin:14px 20px 0;padding:20px;text-align:center;font-size:12px;color:var(--tx3);background:var(--panel-a);border:1px solid var(--line);border-radius:13px}
/* 차트 시간축(조위·수온 공용) */
.ch-axis{position:relative;height:13px;margin-top:3px}
.ch-axis span{position:absolute;top:0;font-size:8.5px;color:var(--tx3);white-space:nowrap}
/* 조위 차트(고정 cm Y축 + 확대/축소) */
.tide-chart-wrap{position:relative}
.ch-zoom{position:absolute;top:0;right:0;z-index:6;display:flex;gap:3px}
.ch-zoom button{width:23px;height:23px;border-radius:7px;border:1px solid var(--line);background:rgba(8,13,24,.72);color:var(--tx2);font-size:13px;font-weight:800;line-height:1;display:flex;align-items:center;justify-content:center;font-family:inherit;cursor:pointer}
.ch-zoom button:active{background:rgba(43,198,244,.2);color:var(--cyan2)}
.tide-plot{display:flex;gap:5px;margin-top:2px}
.tide-plot .y-axis{position:relative;flex:0 0 auto;width:28px;height:104px}
.tide-plot .y-axis span{position:absolute;right:0;transform:translateY(-50%);font-size:8px;color:var(--tx3);white-space:nowrap}
.tide-plot .plot-area{position:relative;flex:1;height:104px;touch-action:none;cursor:crosshair;overflow:hidden;border-radius:6px}
.tide-plot .plot-area svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.tide-plot .plot-area polyline{fill:none;stroke:var(--cyan2);stroke-width:2;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 4px rgba(43,198,244,.5))}
.tide-plot .plot-area polygon.area{fill:rgba(43,198,244,.13);stroke:none}
.tide-plot .plot-area .ygrid .gl{position:absolute;left:0;right:0;height:1px;background:rgba(255,255,255,.06)}
.tide-plot .plot-area .ygrid .gl.zero{background:rgba(120,200,255,.42);box-shadow:0 0 4px rgba(120,200,255,.3)}
.tide-plot .plot-area .tmk{position:absolute;width:7px;height:7px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2}
.tide-plot .plot-area .tmk.hi{background:#ff8a5c;box-shadow:0 0 7px rgba(255,138,92,.95)}
.tide-plot .plot-area .tmk.lo{background:#36D6F5;box-shadow:0 0 7px rgba(54,214,245,.95)}
.tide-plot .plot-area .mk{position:absolute;top:0;bottom:0;width:2px;background:rgba(255,255,255,.62);box-shadow:0 0 6px rgba(255,255,255,.5);pointer-events:none}
.tideax{margin-left:33px}
/* 수온 변화 */
.wm-temp-box{margin:14px 20px 0;background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:12px 14px}
.wm-temp-box .hd{font-size:11.5px;color:var(--tx2);display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.wm-temp-box .hd .rng{font-size:9.5px;font-weight:700;color:var(--tx)}
.wm-temp-box .hd b{margin-left:auto;color:#5fd0ff;font-size:14px}
.wm-temp-box .chart{position:relative;height:50px;cursor:pointer}
.wm-temp-box .chart svg{width:100%;height:100%;overflow:visible}
.wm-temp-box .chart polyline{fill:none;stroke:url(#wmTcg);stroke-width:2.4;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 4px rgba(43,198,160,.45))}
.wm-temp-box .chart polygon.area{fill:rgba(43,198,160,.12);stroke:none}
.wm-temp-box .chart .mk{position:absolute;top:-3px;bottom:-3px;width:2px;background:rgba(255,255,255,.6);box-shadow:0 0 6px rgba(255,255,255,.5)}
.temp-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;margin-top:9px}
.temp-strip .tc{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 2px;border-radius:9px;background:rgba(255,255,255,.04)}
.temp-strip .tc span{font-size:8.5px;color:var(--tx3)} .temp-strip .tc b{font-size:13px;font-weight:800;color:var(--tx)}
.wm-temp-box .note-sm{margin-top:9px;font-size:9.5px;color:var(--tx3);display:flex;align-items:center;gap:4px;line-height:1.45}
.wm-legend{display:flex;align-items:center;gap:8px;margin-top:11px;font-size:10.5px;color:var(--tx3)}
.wm-legend .bar{flex:1;height:7px;border-radius:99px}
.wm-readout{text-align:center;font-size:12px;color:var(--tx2);margin-top:9px;min-height:16px}
.wm-chips{display:flex;gap:7px;margin-top:11px}
.wm-chips button{flex:1;padding:9px 4px;font-size:12px;font-weight:700;color:var(--tx2);background:rgba(11,19,33,.6);border:1px solid var(--line);border-radius:11px;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:4px}
.wm-chips button.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-color:transparent}
/* 갯바위 공략집 바(날씨 지도 통합) */
.wm-gb-bar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;padding:11px 20px 0}
.wm-gb-bar .t{font-size:12px;font-weight:700;color:var(--tx2);display:flex;align-items:center;gap:5px;margin-right:auto}
.wm-gb-bar .t b{color:var(--gold,#f6c453);margin-left:2px}
.wm-gb-bar button{padding:7px 11px;font-size:11.5px;font-weight:700;color:var(--tx2);background:rgba(11,19,33,.6);border:1px solid var(--line);border-radius:99px;font-family:inherit}
.wm-gb-bar button.on{color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);border-color:transparent}
.wm-gb-bar button.add-on{color:#04121b;background:linear-gradient(90deg,#f6c453,#f29f3d);border-color:transparent;animation:wpulse 1.4s ease-out infinite}
.wm-gb-bar button.admin-on{color:#04121b;background:linear-gradient(90deg,#33d277,#1fae8f);border-color:transparent}
.wm-gb-hint{margin:8px 20px 0;font-size:11px;color:var(--gold,#f6c453);display:flex;align-items:center;gap:5px}
.wm-gb-pin{background:none;border:0}
.wm-gb-pin .pin{display:block;width:18px;height:18px;border-radius:50% 50% 50% 0;background:linear-gradient(150deg,#f6c453,#f29f3d);transform:rotate(-45deg);box-shadow:0 3px 7px rgba(0,0,0,.5);border:2px solid #fff;position:relative}
.wm-gb-pin .pin::after{content:'';position:absolute;inset:0;margin:auto;width:6px;height:6px;border-radius:50%;background:#04121b;transform:rotate(45deg)}
.wm-gb-pin .lbl{position:absolute;left:14px;top:-3px;white-space:nowrap;font-size:10.5px;font-weight:800;color:#fff;text-shadow:0 1px 3px #000,0 0 4px #000;pointer-events:none}
.wm-score{margin:12px 20px 0;display:flex;align-items:center;justify-content:space-between;background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:12px 16px}
.wm-score .gd{font-size:13px;font-weight:700;color:var(--tx2);display:flex;align-items:center;gap:5px}
.wm-score .v{font-size:22px;font-weight:800}.wm-score .v small{font-size:12px;font-weight:600;color:var(--tx2)}
.wm-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;padding:0 20px}
.wm-stat{background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:12px 11px;display:flex;flex-direction:column;gap:7px}
.wm-stat .i{color:var(--cyan2)}
.wm-stat .v{font-size:18px;font-weight:800;color:var(--tx)}.wm-stat .v small{font-size:11px;font-weight:600;color:var(--tx2);margin-left:2px}
.wm-stat .l{font-size:10.5px;color:var(--tx3)}

/* ===== AI 예약 비서 대화창 ===== */
.rai .chat{padding:14px 20px 210px}
.rai-bar{position:fixed;bottom:calc(59px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);width:100%;max-width:460px;z-index:45;background:linear-gradient(180deg,transparent,var(--bg) 26%);padding:10px 16px 10px}
.rai-quick{display:flex;gap:7px;overflow-x:auto;padding-bottom:9px;scrollbar-width:none}
.rai-quick::-webkit-scrollbar{display:none}
.rai-quick button{flex:0 0 auto;font-size:12px;color:var(--cyan2);background:rgba(43,198,244,.08);border:1px solid rgba(43,198,244,.25);border-radius:99px;padding:7px 12px;font-weight:600;white-space:nowrap;font-family:inherit}
.rai-input{display:flex;gap:8px;align-items:center}
.rai-input input{flex:1;background:rgba(20,33,52,.92);border:1px solid var(--line);border-radius:13px;padding:13px 15px;color:var(--tx);font-size:14px;font-family:inherit}
.rai-input input:focus{outline:none;border-color:rgba(43,198,244,.5)}
.rai-input button{flex:0 0 46px;height:46px;border:0;border-radius:13px;background:linear-gradient(90deg,#36D6F5,#2E8FFF);color:#04121b;display:flex;align-items:center;justify-content:center}
.typing{display:inline-flex;gap:4px;align-items:center;padding:2px 0}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--tx3);animation:tbounce 1.2s infinite}
.typing i:nth-child(2){animation-delay:.15s}.typing i:nth-child(3){animation-delay:.3s}
@keyframes tbounce{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.boatcard .rt{font-weight:700}.boatcard .ds b{color:var(--green)}
.rai-confirm,.rai-receipt{margin:6px 20px 0;padding:14px 16px;border-radius:14px;background:var(--panel-a);border:1px solid var(--line)}
.rai-confirm .nm{font-weight:800;font-size:15px}
.rai-confirm .ds{font-size:12px;color:var(--tx2);margin-top:4px;line-height:1.5}
.rai-confirm .amt{font-size:15px;color:var(--cyan2);font-weight:800;margin-top:9px}
.rai-confirm .btn,.rai-receipt .btn{margin:11px 0 0;width:100%;padding:13px;font-size:14px}
.rai-receipt{text-align:center;background:rgba(51,210,119,.08);border-color:rgba(51,210,119,.3)}
.rai-receipt .ck{width:44px;height:44px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;background:rgba(51,210,119,.14);color:var(--green)}
.rai-receipt .nm{font-weight:800;font-size:15px}.rai-receipt .ds{font-size:12px;color:var(--tx2);margin-top:4px}
.rai-receipt .mf{font-size:11.5px;color:#bff5d4;margin-top:8px}

/* ===== 예약 목록(선박 카드) ===== */
.boatlist{display:flex;flex-direction:column;gap:14px;padding:0 20px}
.rai-boats{display:flex;flex-direction:column;gap:12px;padding:6px 20px 2px}
.boat-lc{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel-a),var(--panel-b));cursor:pointer;transition:transform .15s}
.boat-lc:active{transform:scale(.985)}
.boat-lc .hd{position:relative;height:104px;background:linear-gradient(160deg,#1a2630,#0d141b);display:flex;align-items:center;justify-content:center;overflow:hidden}
.boat-lc .fishwm{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#2a4256;opacity:.5}
.boat-lc .fishwm svg{width:72%}
.boat-lc .vf{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;color:#bff5d4;background:rgba(51,210,119,.14);border:1px solid rgba(51,210,119,.35);padding:3px 8px;border-radius:99px;display:flex;align-items:center;gap:4px}
.boat-lc .rt{position:absolute;top:10px;right:10px;font-size:11px;font-weight:800;color:var(--gold);background:rgba(5,8,15,.5);padding:3px 8px;border-radius:99px}
.boat-lc .cb{position:absolute;bottom:10px;left:10px;font-size:10px;font-weight:700;color:#3a1d00;background:linear-gradient(90deg,#F7E4A8,#E0A94E);padding:3px 9px;border-radius:99px;display:flex;align-items:center;gap:4px}
.boat-lc .bd{padding:13px 15px 15px}
.boat-lc .nm{font-size:17px;font-weight:800;display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.boat-lc .nm .rg{font-size:11.5px;font-weight:500;color:var(--tx2);display:flex;align-items:center;gap:3px;white-space:nowrap}
.boat-lc .sp{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.boat-lc .sp span{font-size:11px;color:var(--cyan2);background:rgba(43,198,244,.08);border:1px solid rgba(43,198,244,.2);padding:3px 9px;border-radius:99px}
.boat-lc .av{margin-top:12px}
.boat-lc .av .bar{height:6px;border-radius:99px;background:rgba(255,255,255,.07);overflow:hidden}
.boat-lc .av .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#33D277,#2BC6F4)}
.boat-lc .av .bar.mid i{background:linear-gradient(90deg,#EDC877,#33D277)}
.boat-lc .av .bar.low i{background:linear-gradient(90deg,#FF5A53,#EDC877)}
.boat-lc .av span{display:block;font-size:11.5px;color:var(--tx2);margin-top:6px}
.boat-lc .av span b{color:var(--tx)}
.boat-lc .ft{display:flex;align-items:center;justify-content:space-between;margin-top:13px}
.boat-lc .pr{font-size:19px;font-weight:800;color:var(--cyan2)}.boat-lc .pr small{font-size:11px;font-weight:500;color:var(--tx2);margin-left:2px}
.boat-lc .bk{border:0;border-radius:11px;padding:11px 20px;font-size:13.5px;font-weight:800;color:#04121b;background:linear-gradient(90deg,#36D6F5,#2E8FFF);box-shadow:0 6px 16px rgba(46,143,255,.25);font-family:inherit}

/* ===== 예약 상세 ===== */
.sd-hero{position:relative;margin:8px 20px 0;height:160px;border-radius:18px;overflow:hidden;background:linear-gradient(160deg,#1a2833,#0c131a);border:1px solid var(--line);display:flex;align-items:flex-end}
.sd-hero .fishwm{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#2a4256;opacity:.45}
.sd-hero .fishwm svg{width:64%}
.sd-hero .vf{position:absolute;top:12px;left:12px;font-size:11px;font-weight:700;color:#bff5d4;background:rgba(51,210,119,.14);border:1px solid rgba(51,210,119,.35);padding:4px 10px;border-radius:99px;display:flex;align-items:center;gap:5px;z-index:1}
.sd-hero .meta{position:relative;padding:14px 16px;width:100%;background:linear-gradient(0deg,rgba(5,8,15,.85),transparent)}
.sd-hero .meta .nm{font-size:22px;font-weight:800}
.sd-hero .meta .sub{font-size:12.5px;color:var(--tx2);margin-top:3px;display:flex;align-items:center;gap:5px}
.sd-hero .meta .rt{color:var(--gold);font-weight:700;margin-left:4px}
.sd-badge{margin:12px 20px 0;font-size:12px;font-weight:700;color:#3a1d00;background:linear-gradient(90deg,#F7E4A8,#E0A94E);padding:8px 14px;border-radius:12px;display:flex;align-items:center;gap:6px}
.sd-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:14px 20px 0}
.sd-cell{background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:12px;display:flex;gap:10px;align-items:center}
.sd-cell .i{color:var(--cyan2);flex:0 0 auto}
.sd-cell .l{font-size:10.5px;color:var(--tx3)}.sd-cell .v{font-size:13.5px;font-weight:700;margin-top:2px}
.sd-sp{display:flex;flex-wrap:wrap;gap:7px;padding:0 20px}
.sd-sp span{font-size:12.5px;color:var(--cyan2);background:rgba(43,198,244,.08);border:1px solid rgba(43,198,244,.22);padding:6px 13px;border-radius:99px;font-weight:600}
.sd-av{margin:14px 20px 0;background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:13px 15px}
.sd-av .hd{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--tx2);margin-bottom:9px}
.sd-av .hd span{display:flex;align-items:center;gap:5px}.sd-av .hd b{font-size:16px;color:var(--tx)}.sd-av .hd b small{font-size:11px;color:var(--tx3);font-weight:500}
.sd-av .bar{height:8px;border-radius:99px;background:rgba(255,255,255,.07);overflow:hidden}
.sd-av .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#33D277,#2BC6F4)}
.sd-av .bar.mid i{background:linear-gradient(90deg,#EDC877,#33D277)}.sd-av .bar.low i{background:linear-gradient(90deg,#FF5A53,#EDC877)}
.stepper{display:flex;align-items:center;margin:0 20px;background:var(--panel-a);border:1px solid var(--line);border-radius:13px;overflow:hidden}
.stepper button{width:64px;height:52px;border:0;background:transparent;color:var(--cyan2);font-size:26px;font-weight:700;font-family:inherit}
.stepper button:disabled{color:var(--tx3);opacity:.5}
.stepper span{flex:1;text-align:center;font-size:18px;font-weight:800}.stepper span small{font-size:13px;font-weight:600;color:var(--tx2);margin-left:2px}
.sd-cta{margin:16px 20px 24px;background:var(--panel-a);border:1px solid var(--line);border-radius:16px;padding:14px 16px}
.sd-cta .amt{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:11px}
.sd-cta .amt span{font-size:13px;color:var(--tx2)}.sd-cta .amt b{font-size:22px;font-weight:800;color:var(--cyan2)}
.sd-cta .btn{margin:0;width:100%}

/* ===== SFL 리그 ===== */
.sfl-hero{position:relative;margin:8px 20px 0;border-radius:18px;padding:16px;display:flex;align-items:center;gap:13px;overflow:hidden;
  background:radial-gradient(120% 140% at 100% 0,rgba(237,200,119,.18),transparent 60%),linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid rgba(237,200,119,.28)}
.sfl-hero .emb{width:50px;height:50px;flex:0 0 auto;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#3a1d00;background:linear-gradient(135deg,#F7E4A8,#D2A24E);box-shadow:0 0 20px rgba(237,200,119,.4)}
.sfl-hero .t{font-size:16px;font-weight:800;letter-spacing:.3px}
.sfl-hero .s{font-size:11.5px;color:var(--tx2);margin-top:2px}
.sfl-hero .season{position:absolute;top:12px;right:14px;font-size:10px;font-weight:700;color:var(--gold);border:1px solid rgba(237,200,119,.4);padding:3px 8px;border-radius:99px}
.sfl-me{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin:12px 20px 0}
.sfl-me .cell{background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:12px 10px;text-align:center}
.sfl-me .lab{font-size:10.5px;color:var(--tx3);display:block}
.sfl-me .v{font-size:18px;font-weight:800;margin-top:5px;display:inline-flex;align-items:center;gap:4px}.sfl-me .v small{font-size:12px;color:var(--tx2)}
.sfl-me .v.gd{color:var(--gold);font-size:15px}
.sfl-div{display:flex;gap:8px;margin:14px 20px 0}
.sfl-div button{flex:1;background:var(--panel-a);border:1px solid var(--line);border-radius:13px;padding:11px 6px;font-family:inherit;display:flex;flex-direction:column;gap:2px;align-items:center}
.sfl-div button b{font-size:12.5px;color:var(--tx2)}.sfl-div button span{font-size:9.5px;color:var(--tx3)}
.sfl-div button.on{border-color:transparent;background:linear-gradient(180deg,rgba(43,198,244,.18),rgba(43,198,244,.06));box-shadow:0 0 0 1px rgba(43,198,244,.4)}
.sfl-div button.on b,.sfl-div button.on span{color:var(--cyan2)}
/* AI 계측 랭킹 — 상금 대상 안내 + 계측 장르/어종 선택 */
.prize-note{display:flex;align-items:center;gap:6px;margin:11px 20px 0;font-size:11.5px;color:var(--tx2);background:rgba(237,200,119,.08);border:1px solid rgba(237,200,119,.28);border-radius:11px;padding:8px 12px}
.prize-note svg{color:var(--gold,#edc877);flex:0 0 auto} .prize-note b{color:var(--gold,#edc877);font-weight:800;margin-right:2px}
.meas-sel{display:flex;align-items:center;gap:9px;margin:12px 20px 0}
.meas-sel .lb{flex:0 0 auto;font-size:10.5px;font-weight:700;color:var(--tx3);display:inline-flex;align-items:center;gap:3px;min-width:52px}
.meas-sel .chips{margin:0;padding:0;flex:1}
.podium{display:flex;align-items:flex-end;justify-content:center;gap:10px;padding:10px 20px 0}
.pod{flex:1;max-width:33%;border-radius:14px 14px 0 0;padding:12px 8px 14px;text-align:center;background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line);border-bottom:0}
.pod .medal{width:24px;height:24px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#04121b}
.pod .av{width:40px;height:40px;border-radius:50%;margin:0 auto 7px;display:flex;align-items:center;justify-content:center;background:rgba(43,198,244,.1);border:1px solid var(--line);color:var(--cyan2)}
.pod .nm{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pod .sp{font-size:10px;color:var(--tx3);margin-top:1px}
.pod .sc{font-size:14px;font-weight:800;color:var(--cyan2);margin-top:6px}
.pod.p1{transform:translateY(-12px);border-color:rgba(237,200,119,.5);box-shadow:0 0 24px rgba(237,200,119,.16)}
.pod.p1 .medal{background:linear-gradient(135deg,#F7E4A8,#D2A24E)}
.pod.p2 .medal{background:linear-gradient(135deg,#dfe7ee,#9fb0bf)}
.pod.p3 .medal{background:linear-gradient(135deg,#e6b489,#bd7f4f)}
.rk-list{margin:16px 20px 0;display:flex;flex-direction:column}
.rk-row{display:flex;align-items:center;gap:12px;padding:13px 4px;border-bottom:1px solid rgba(255,255,255,.05)}
.rk-row .n{flex:0 0 26px;text-align:center;font-size:14px;font-weight:800;color:var(--tx3)}
.rk-row .bd{flex:1;min-width:0}
.rk-row .bd b{font-size:14px;display:flex;align-items:center;gap:6px}
.rk-row .bd .lv{display:inline-flex;width:15px;height:15px;border-radius:50%;background:rgba(51,210,119,.18);color:var(--green);align-items:center;justify-content:center}
.rk-row .bd span{font-size:11.5px;color:var(--tx3);display:block;margin-top:2px}
.rk-row .sc{text-align:right;font-size:15px;font-weight:800;color:var(--cyan2)}.rk-row .sc small{display:block;font-size:9.5px;color:var(--tx3);font-weight:500}

/* AI 예약 비서 (대화형) */
.chat{padding:14px 20px 0;display:flex;flex-direction:column;gap:16px}
.cmsg{display:flex;gap:10px;max-width:92%}
.cmsg .av{width:34px;height:34px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#2b4a66,#16242f);border:1px solid var(--line);color:var(--cyan2);overflow:hidden}
.cmsg .av img{width:100%;height:100%;object-fit:cover}
.cmsg .bub{background:linear-gradient(180deg,var(--panel-a),var(--panel-b));border:1px solid var(--line);
  border-radius:4px 14px 14px 14px;padding:12px 14px;font-size:14px;line-height:1.55}
.cmsg .who{font-size:11px;color:var(--tx3);font-weight:700;margin-bottom:5px;letter-spacing:.3px}
.cmsg.me{align-self:flex-end;flex-direction:row-reverse}
.cmsg.me .bub{border-radius:14px 4px 14px 14px;background:rgba(43,198,244,.1);border-color:rgba(43,198,244,.28)}
.cmsg.me .av{background:rgba(43,198,244,.12)}
.analyzing-row{display:flex;align-items:center;gap:10px;color:var(--tx2);font-size:13px;padding:6px 0 0 44px}
.analyzing-row .spin{width:18px;height:18px;margin:0;border-width:2px}
.boatcards{display:flex;gap:12px;overflow-x:auto;padding:4px 20px 0;scrollbar-width:none}
.boatcards::-webkit-scrollbar{display:none}
.boatcard{flex:0 0 200px;border-radius:16px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel-a),var(--panel-b))}
.boatcard.rec{border-color:rgba(237,200,119,.5);box-shadow:0 0 20px rgba(237,200,119,.12)}
.boatcard .ph{height:96px;background:linear-gradient(160deg,#1c2730,#0f161d);display:flex;align-items:center;justify-content:center;color:#36506a;position:relative}
.boatcard .tag{position:absolute;top:8px;left:8px;font-size:9.5px;font-weight:800;letter-spacing:.5px;color:#3a1d00;background:linear-gradient(90deg,#F7E4A8,#E0A94E);padding:3px 8px;border-radius:99px}
.boatcard .bd{padding:12px}
.boatcard .nm{font-size:15px;font-weight:800}
.boatcard .ds{font-size:11.5px;color:var(--tx2);margin-top:4px;line-height:1.5;min-height:32px}
.boatcard .ds b{color:var(--cyan2)}
.boatcard .pick{margin-top:10px;width:100%;border:0;border-radius:10px;padding:10px;font-weight:800;font-size:13px;color:#3a1d00;background:linear-gradient(90deg,#F7E4A8,#E0A94E)}
.chat-steps{display:flex;gap:8px;padding:16px 20px 0;font-size:11.5px;color:var(--tx3)}
.chat-steps b{color:var(--cyan2)}
.confirm-ok{margin:0 20px;padding:16px;border-radius:14px;text-align:center;background:rgba(51,210,119,.08);border:1px solid rgba(51,210,119,.3)}
.confirm-ok .ck{width:48px;height:48px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;background:rgba(51,210,119,.14);color:var(--green)}

/* 탭바 */
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:460px;z-index:40;
  display:flex;background:rgba(7,11,19,.92);border-top:1px solid var(--line);backdrop-filter:blur(12px);
  padding:9px 4px calc(9px + env(safe-area-inset-bottom))}
.tabbar .t{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10.5px;color:var(--tx3);font-weight:600;background:none;border:0}
.tabbar .t.on{color:var(--cyan2)} .tabbar .t.on svg{filter:drop-shadow(0 0 6px rgba(43,198,244,.7))}
.tabbar .t svg{width:22px;height:22px}
.tabbar .t.fab{flex:0 0 auto}
.tabbar .fab .ring{width:50px;height:50px;border-radius:16px;background:linear-gradient(135deg,#36D6F5,#2E8FFF);
  display:flex;align-items:center;justify-content:center;color:#04121b;margin-top:-26px;border:4px solid var(--bg);
  box-shadow:0 8px 20px rgba(46,143,255,.45)}
