
:root{--ink:#0a0d14;--surface:#0f1420;--card:#141928;--card2:#1a2035;--border:rgba(255,255,255,0.07);--accent:#00d4aa;--accent2:#0088ff;--accent3:#a855f7;--gold:#f5c842;--text:#e8eaf0;--muted:#6b7494;--nav-h:72px;--radius:20px;--radius-sm:12px;}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;background:var(--ink);color:var(--text);font-family:'DM Sans',sans-serif;overflow-x:hidden;}
::-webkit-scrollbar{width:4px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
#app{min-height:100vh;padding-bottom:calc(var(--nav-h)+16px);position:relative;}
.bg-orbs{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.12;animation:drift 20s infinite alternate ease-in-out;}
.orb1{width:500px;height:500px;background:var(--accent2);top:-150px;right:-100px;animation-duration:18s;}
.orb2{width:400px;height:400px;background:var(--accent);bottom:-100px;left:-120px;animation-duration:22s;animation-delay:-6s;}
.orb3{width:300px;height:300px;background:var(--accent3);top:40%;left:50%;animation-duration:25s;animation-delay:-10s;}
@keyframes drift{from{transform:translate(0,0) scale(1);}to{transform:translate(40px,30px) scale(1.1);}}
.page{display:none;position:relative;z-index:1;animation:pageIn .4s ease;}
.page.active{display:block;}
@keyframes pageIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* HERO */
.hero{position:relative;overflow:hidden;padding:60px 24px 48px;background:linear-gradient(180deg,rgba(0,136,255,.06) 0%,transparent 100%);border-bottom:1px solid var(--border);}
.hero-eyebrow{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--accent);}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(32px,8vw,52px);line-height:1.1;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.6) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.hero h1 em{font-style:italic;-webkit-text-fill-color:var(--accent);}
.hero p{color:var(--muted);font-size:15px;line-height:1.7;max-width:400px;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;margin-top:24px;padding:8px 16px;border-radius:100px;border:1px solid var(--border);background:rgba(255,255,255,.03);font-size:12px;color:var(--muted);}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.4);}}

/* SECTION */
.section{padding:32px 20px 0;}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
.section-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;}
.section-link{font-size:12px;color:var(--accent);text-decoration:none;font-weight:500;letter-spacing:.5px;}

/* STAT STRIP */
.stat-strip{display:flex;gap:10px;padding:20px;overflow-x:auto;scrollbar-width:none;}
.stat-strip::-webkit-scrollbar{display:none;}
.stat-card{flex:0 0 140px;background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);padding:16px;position:relative;overflow:hidden;transition:transform .2s,border-color .2s;}
.stat-card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.14);}
.stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--c,var(--accent));border-radius:0 0 var(--radius-sm) var(--radius-sm);}
.stat-label{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;}
.stat-value{font-family:'Space Mono',monospace;font-size:22px;font-weight:700;}
.stat-change{font-size:11px;margin-top:4px;}
.up{color:var(--accent);}.down{color:#ff5c6a;}

/* CARD GRID */
.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.card-grid.triple{grid-template-columns:repeat(3,1fr);}

/* ARTICLE CARD */
.article-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform .25s,box-shadow .25s;}
.article-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4);}
.article-card.featured{grid-column:1/-1;}
.card-img-placeholder{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:48px;background:linear-gradient(135deg,var(--card2) 0%,var(--card) 100%);position:relative;overflow:hidden;}
.card-img-placeholder::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--ga,rgba(0,212,170,.1)) 0%,transparent 60%);}
.card-body{padding:16px;}
.card-tag{display:inline-block;font-size:9px;letter-spacing:2px;text-transform:uppercase;font-family:'Space Mono',monospace;color:var(--ct,var(--accent));border:1px solid var(--ct,var(--accent));padding:3px 8px;border-radius:4px;margin-bottom:10px;opacity:.85;}
.card-title{font-family:'Playfair Display',serif;font-size:16px;line-height:1.35;margin-bottom:8px;font-weight:700;}
.article-card.featured .card-title{font-size:20px;}
.card-meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:8px;}
.card-meta::before{content:'';display:inline-block;width:16px;height:1px;background:var(--border);}

/* TICKER */
.ticker-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:12px 0;background:rgba(0,0,0,.2);}
.ticker-inner{display:flex;gap:32px;animation:ticker 20s linear infinite;white-space:nowrap;}
@keyframes ticker{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.ticker-item{display:flex;align-items:center;gap:8px;font-family:'Space Mono',monospace;font-size:12px;}
.ticker-sym{color:var(--text);font-weight:700;}.ticker-price{color:var(--muted);}

/* ROUTE CARD */
.route-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:20px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;}
.route-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent2),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.route-card:hover::before{transform:scaleX(1);}
.route-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.14);}
.route-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;}
.route-icon{font-size:28px;}.route-price{font-family:'Space Mono',monospace;font-size:18px;font-weight:700;color:var(--accent);}
.route-price span{font-size:10px;color:var(--muted);font-family:'DM Sans',sans-serif;}
.route-name{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;margin-bottom:4px;}
.route-ports{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;}
.route-ports .arrow{color:var(--accent);}
.route-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px;}
.route-tag{font-size:10px;padding:4px 10px;border-radius:100px;background:rgba(255,255,255,.05);color:var(--muted);}

/* DEFI */
.defi-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:20px;margin-bottom:12px;transition:all .2s;}
.defi-card:hover{border-color:rgba(0,212,170,.3);}
.defi-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.defi-logo{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--card2);}
.defi-name{font-weight:600;font-size:16px;}.defi-cat{font-size:11px;color:var(--muted);}
.defi-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.defi-stat{text-align:center;}.defi-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.defi-stat-val{font-family:'Space Mono',monospace;font-size:14px;font-weight:700;margin-top:4px;}
.progress-bar{height:3px;background:var(--card2);border-radius:2px;margin-top:14px;overflow:hidden;}
.progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent2),var(--accent));}

/* CHAIN */
.chain-visual{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:24px;margin-bottom:12px;overflow:hidden;}
.chain-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;margin-bottom:20px;}
.blocks-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:8px;}
.blocks-scroll::-webkit-scrollbar{display:none;}
.block{flex:0 0 110px;background:var(--card2);border-radius:10px;border:1px solid var(--border);padding:12px;position:relative;cursor:pointer;transition:all .2s;}
.block:hover{border-color:var(--accent);transform:translateY(-2px);}
.block.latest{border-color:var(--accent);box-shadow:0 0 20px rgba(0,212,170,.15);}
.block::after{content:'→';position:absolute;right:-14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:12px;}
.block:last-child::after{display:none;}
.block-num{font-family:'Space Mono',monospace;font-size:10px;color:var(--accent);margin-bottom:6px;}
.block-hash{font-family:'Space Mono',monospace;font-size:8px;color:var(--muted);word-break:break-all;line-height:1.4;}
.block-txs{font-size:10px;color:var(--text);margin-top:8px;font-weight:600;}

/* NFT */
.nft-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:all .25s;}
.nft-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.5);}
.nft-img{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:52px;background:linear-gradient(135deg,var(--card2),var(--card));}
.nft-body{padding:12px;}.nft-name{font-weight:600;font-size:13px;margin-bottom:4px;}
.nft-price{font-family:'Space Mono',monospace;font-size:12px;color:var(--accent);}

/* PAY CARD */
.pay-card{border-radius:20px;padding:24px;margin-bottom:16px;position:relative;overflow:hidden;background:linear-gradient(135deg,#1a2a4a 0%,#0a1628 100%);border:1px solid rgba(0,136,255,.2);}
.pay-chip{font-size:28px;margin-bottom:24px;position:relative;}
.pay-number{font-family:'Space Mono',monospace;letter-spacing:4px;font-size:16px;color:rgba(255,255,255,.8);margin-bottom:20px;position:relative;}
.pay-footer{display:flex;justify-content:space-between;align-items:flex-end;position:relative;}
.pay-label{font-size:9px;color:rgba(255,255,255,.4);letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;}
.pay-value{font-size:14px;font-weight:600;}.pay-network{font-size:24px;}

/* TX */
.tx-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);}
.tx-item:last-child{border-bottom:none;}
.tx-icon{width:40px;height:40px;border-radius:12px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.tx-info{flex:1;}.tx-name{font-size:14px;font-weight:500;margin-bottom:3px;}.tx-date{font-size:11px;color:var(--muted);}
.tx-amount{font-family:'Space Mono',monospace;font-size:14px;font-weight:700;}

/* PROFILE */
.profile-header{background:linear-gradient(180deg,rgba(0,136,255,.08) 0%,transparent 100%);padding:40px 24px 24px;text-align:center;border-bottom:1px solid var(--border);}
.avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),var(--accent));display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 16px;border:3px solid rgba(255,255,255,.1);}
.profile-name{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;margin-bottom:4px;}
.profile-handle{color:var(--muted);font-size:13px;}
.profile-stats{display:flex;justify-content:center;gap:32px;margin-top:20px;}
.pstat{text-align:center;}.pstat-val{font-family:'Space Mono',monospace;font-size:20px;font-weight:700;}
.pstat-label{font-size:11px;color:var(--muted);margin-top:4px;}
.settings-list{padding:0 20px;}
.setting-item{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity .2s;}
.setting-item:hover{opacity:.7;}
.setting-icon{width:40px;height:40px;border-radius:12px;background:var(--card);display:flex;align-items:center;justify-content:center;font-size:18px;}
.setting-text{flex:1;}.setting-name{font-size:14px;font-weight:500;}.setting-desc{font-size:12px;color:var(--muted);margin-top:2px;}
.setting-arrow{color:var(--muted);font-size:14px;}

/* SEARCH */
.search-wrap{padding:16px 20px 0;position:relative;}
.search-icon{position:absolute;left:36px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:16px;pointer-events:none;}
.search-input{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px 12px 40px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;}
.search-input:focus{border-color:rgba(0,212,170,.4);}

/* FINTECH ACTIONS */
.fintech-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:20px 20px 0;}
.fintech-action-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;border-radius:var(--radius);cursor:pointer;border:1.5px solid var(--border);transition:all .25s;position:relative;overflow:hidden;background:var(--card);}
.fintech-action-btn:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.18);}
.fa-icon{font-size:30px;}.fa-label{font-weight:700;font-size:14px;}.fa-desc{font-size:11px;color:var(--muted);text-align:center;line-height:1.4;}

/* MY STAKES */
.my-stake-item{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);padding:16px;margin-bottom:10px;}
.my-stake-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.my-stake-name{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;}
.my-stake-status{font-size:10px;padding:3px 8px;border-radius:100px;background:rgba(0,212,170,.15);color:var(--accent);font-family:'Space Mono',monospace;}
.my-stake-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px;}
.my-stake-row span:first-child{color:var(--muted);}
.my-stake-row span:last-child{font-weight:600;}
.unstake-btn{margin-top:12px;width:100%;padding:10px;border-radius:10px;background:rgba(255,92,106,.1);border:1px solid rgba(255,92,106,.2);color:#ff5c6a;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;}

/* BADGE */
.badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--accent);font-size:9px;font-weight:700;color:var(--ink);position:absolute;top:4px;right:calc(50% - 18px);}

/* TOAST */
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);background:var(--card2);border:1px solid var(--border);border-radius:100px;padding:10px 20px;font-size:13px;z-index:500;transition:transform .35s cubic-bezier(.32,.72,0,1);white-space:nowrap;}
.toast.show{transform:translateX(-50%) translateY(0);}

/* BOTTOM NAV */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;height:var(--nav-h);background:rgba(10,13,20,.9);backdrop-filter:blur(24px) saturate(180%);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0);}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 2px;cursor:pointer;transition:all .25s;border-radius:12px;background:none;border:none;color:var(--muted);position:relative;}
.nav-item.active{color:var(--text);}
.nav-icon{font-size:18px;transition:transform .25s;}.nav-item.active .nav-icon{transform:scale(1.1);}
.nav-label{font-size:8px;letter-spacing:.3px;font-weight:500;text-transform:uppercase;}
.nav-indicator{position:absolute;top:6px;width:24px;height:3px;border-radius:2px;background:var(--accent);opacity:0;transition:opacity .25s;}
.nav-item.active .nav-indicator{opacity:1;}
.ham-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;cursor:pointer;transition:all .25s;border-radius:14px;background:none;border:none;color:var(--muted);position:relative;}
.ham-icon{display:flex;flex-direction:column;gap:4px;width:20px;}
.ham-line{height:2px;border-radius:1px;background:currentColor;transition:all .3s ease;transform-origin:center;}
.ham-line.l1{width:20px;}.ham-line.l2{width:14px;}.ham-line.l3{width:17px;}
.ham-btn.open .ham-line.l1{transform:translateY(6px) rotate(45deg);width:20px;}
.ham-btn.open .ham-line.l2{opacity:0;transform:scaleX(0);}
.ham-btn.open .ham-line.l3{transform:translateY(-6px) rotate(-45deg);width:20px;}
.ham-btn.open{color:var(--text);}
.ham-label{font-size:9px;letter-spacing:.5px;font-weight:500;text-transform:uppercase;}

/* DRAWER */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:90;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px);}
.drawer-overlay.open{opacity:1;pointer-events:all;}
.drawer{position:fixed;bottom:var(--nav-h);left:0;right:0;z-index:91;background:var(--surface);border-top-left-radius:28px;border-top-right-radius:28px;border:1px solid var(--border);border-bottom:none;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);padding:24px 20px 20px;}
.drawer.open{transform:translateY(0);}
.drawer-pill{width:36px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 24px;}
.drawer-title{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:20px;}
.drawer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.drawer-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 8px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);cursor:pointer;transition:all .2s;}
.drawer-item:hover{border-color:var(--accent);background:rgba(0,212,170,.05);}
.drawer-item-icon{font-size:24px;}.drawer-item-label{font-size:10px;color:var(--muted);text-align:center;line-height:1.3;}

/* ITINERARY */
.itinerary{display:flex;flex-direction:column;}
.itin-day{display:flex;}
.itin-timeline{display:flex;flex-direction:column;align-items:center;width:36px;flex-shrink:0;}
.itin-dot{width:12px;height:12px;border-radius:50%;background:var(--card2);border:2px solid var(--border);flex-shrink:0;margin-top:5px;}
.itin-day.highlight .itin-dot{background:var(--accent2);border-color:var(--accent2);box-shadow:0 0 10px rgba(0,136,255,.4);}
.itin-line{flex:1;width:2px;background:var(--border);margin-top:4px;}
.itin-day:last-child .itin-line{display:none;}
.itin-content{flex:1;padding:0 0 22px 12px;}
.itin-day-num{font-family:'Space Mono',monospace;font-size:10px;color:var(--muted);margin-bottom:3px;}
.itin-port{font-weight:600;font-size:14px;margin-bottom:3px;}
.itin-desc{font-size:12px;color:var(--muted);line-height:1.5;}
.itin-activity{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px;}
.itin-tag{font-size:10px;padding:3px 9px;border-radius:100px;background:var(--card);border:1px solid var(--border);color:var(--muted);}
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px;}
.incl-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);background:var(--card);border-radius:10px;padding:10px 12px;border:1px solid var(--border);}
.incl-item.yes{color:var(--text);}
.incl-check{font-size:13px;flex-shrink:0;}

/* CABIN */
.cabin-cards{display:flex;flex-direction:column;gap:10px;}
.cabin-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:18px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;}
.cabin-card.selected{border-color:var(--accent2);background:rgba(0,136,255,.05);}
.cabin-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--accent2);transform:scaleY(0);transform-origin:top;transition:transform .3s;}
.cabin-card.selected::before{transform:scaleY(1);}
.cabin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.cabin-icon{font-size:26px;}
.cabin-price{font-family:'Space Mono',monospace;font-size:17px;font-weight:700;color:var(--accent2);text-align:right;}
.cabin-price-note{font-size:10px;color:var(--muted);margin-top:2px;}
.cabin-name{font-weight:700;font-size:15px;margin-bottom:4px;}
.cabin-desc{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:10px;}
.cabin-features{display:flex;flex-wrap:wrap;gap:6px;}
.cabin-feat{font-size:10px;padding:4px 10px;border-radius:100px;background:rgba(0,136,255,.08);color:var(--accent2);border:1px solid rgba(0,136,255,.2);}
.cabin-radio{position:absolute;top:18px;right:18px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);transition:all .25s;display:flex;align-items:center;justify-content:center;}
.cabin-card.selected .cabin-radio{border-color:var(--accent2);background:var(--accent2);color:white;font-size:11px;font-weight:700;}
.cabin-card.selected .cabin-radio::after{content:'✓';}

/* CALENDAR */
.date-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.date-field{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:all .2s;}
.date-field.active{border-color:var(--accent2);background:rgba(0,136,255,.05);}
.date-field-label{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;font-family:'Space Mono',monospace;}
.date-field-value{font-weight:600;font-size:14px;}.date-field-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.mini-cal{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:16px;margin-bottom:16px;}
.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.cal-month{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;}
.cal-nav{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px 8px;transition:color .2s;}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:6px;}
.cal-wd{font-size:10px;color:var(--muted);padding:4px 0;font-family:'Space Mono',monospace;}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;border-radius:8px;cursor:pointer;transition:all .2s;}
.cal-day:hover:not(.empty):not(.past){background:var(--card2);}
.cal-day.past{color:var(--muted);opacity:.38;cursor:default;}
.cal-day.selected{background:var(--accent2);color:white;font-weight:700;}
.cal-day.in-range{background:rgba(0,136,255,.12);}
.cal-day.range-end{background:var(--accent);color:var(--ink);font-weight:700;}
.cal-day.empty{cursor:default;}.cal-day.today{border:1px solid var(--accent2);color:var(--accent2);font-weight:600;}

/* PAX */
.passenger-row{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:10px;}
.pax-type{font-weight:600;font-size:14px;}.pax-desc{font-size:11px;color:var(--muted);margin-top:2px;}
.pax-ctrl{display:flex;align-items:center;gap:12px;}
.pax-btn{width:32px;height:32px;border-radius:10px;background:var(--card2);border:1px solid var(--border);font-size:18px;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1;}
.pax-btn:hover{border-color:var(--accent2);color:var(--accent2);}
.pax-count{font-family:'Space Mono',monospace;font-size:17px;font-weight:700;min-width:22px;text-align:center;}
.pax-form{margin-bottom:16px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;}
.pax-form-title{font-size:13px;color:var(--accent2);font-weight:600;padding:14px 16px;background:rgba(0,136,255,.05);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.pax-form-fields{padding:14px 16px;display:flex;flex-direction:column;gap:10px;}
.pax-field{background:var(--card2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;width:100%;-webkit-appearance:none;}
.pax-field:focus{border-color:rgba(0,136,255,.4);}
.pax-field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.extras-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.extra-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:all .2s;position:relative;}
.extra-card.selected{border-color:var(--accent);background:rgba(0,212,170,.05);}
.extra-icon{font-size:22px;margin-bottom:8px;}.extra-name{font-size:12px;font-weight:600;margin-bottom:4px;}
.extra-price{font-family:'Space Mono',monospace;font-size:11px;color:var(--accent);}
.extra-check{position:absolute;top:10px;right:10px;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;}
.extra-card.selected .extra-check{background:var(--accent);border-color:var(--accent);color:var(--ink);}
.extra-card.selected .extra-check::after{content:'✓';}

/* SUMMARY */
.summary-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;margin-bottom:16px;}
.summary-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.summary-route-icon{font-size:30px;}.summary-route-name{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;}
.summary-route-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.summary-lines{padding:0 16px;}
.summary-line{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--border);font-size:13px;}
.summary-line:last-child{border-bottom:none;}
.summary-line-label{color:var(--muted);}.summary-line-val{font-weight:500;}
.summary-total{display:flex;justify-content:space-between;align-items:center;padding:16px;background:rgba(0,136,255,.05);border-top:1px solid rgba(0,136,255,.15);}
.summary-total-label{font-weight:600;font-size:15px;}
.summary-total-val{font-family:'Space Mono',monospace;font-size:19px;font-weight:700;color:var(--accent2);}
.pay-methods{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
.pay-method{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;}
.pay-method.selected{border-color:var(--accent2);background:rgba(0,136,255,.05);}
.pay-method-icon{font-size:24px;flex-shrink:0;}.pay-method-name{font-weight:600;font-size:14px;}.pay-method-desc{font-size:11px;color:var(--muted);margin-top:2px;}
.pay-method-radio{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);margin-left:auto;flex-shrink:0;transition:all .2s;position:relative;}
.pay-method.selected .pay-method-radio{border-color:var(--accent2);}
.pay-method.selected .pay-method-radio::after{content:'';position:absolute;width:9px;height:9px;border-radius:50%;background:var(--accent2);top:50%;left:50%;transform:translate(-50%,-50%);}
.promo-row{display:flex;gap:10px;margin-bottom:16px;}
.promo-input{flex:1;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;-webkit-appearance:none;}
.promo-apply{background:var(--card2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;color:var(--accent);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;}

/* BOOKING SCREEN */
#booking-screen{position:fixed;inset:0;z-index:200;background:var(--ink);display:none;flex-direction:column;overflow:hidden;}
#booking-screen.open{display:flex;}
.bk-topbar{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:rgba(10,13,20,.95);backdrop-filter:blur(20px);flex-shrink:0;position:relative;z-index:2;}
.bk-back{width:38px;height:38px;border-radius:12px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--text);}
.bk-topbar-info{flex:1;min-width:0;}
.bk-topbar-title{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bk-topbar-sub{font-size:11px;color:var(--muted);margin-top:1px;}
.bk-topbar-price{font-family:'Space Mono',monospace;font-size:14px;font-weight:700;color:var(--accent);flex-shrink:0;}
.bk-stepbar{display:flex;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;}
.bk-step{flex:1;padding:11px 4px;text-align:center;cursor:pointer;font-size:9px;font-family:'Space Mono',monospace;letter-spacing:.5px;color:var(--muted);border-bottom:2px solid transparent;transition:all .25s;text-transform:uppercase;}
.bk-step.active{color:var(--accent2);border-bottom-color:var(--accent2);}
.bk-step.done{color:var(--accent);border-bottom-color:var(--accent);}
.bk-step-num{display:block;font-size:15px;margin-bottom:2px;}
.bk-body{flex:1;overflow-y:auto;padding-bottom:100px;}
.bk-panel{display:none;animation:pageIn .3s ease;}.bk-panel.active{display:block;}
.bk-hero{position:relative;overflow:hidden;height:200px;display:flex;align-items:flex-end;}
.bk-hero-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:110px;background:linear-gradient(135deg,#0a1628 0%,#1a2a4a 100%);}
.bk-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,13,20,1) 0%,rgba(10,13,20,.3) 60%,transparent 100%);}
.bk-hero-info{position:relative;z-index:1;padding:20px;width:100%;}
.bk-hero-name{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin-bottom:6px;}
.bk-hero-ports{font-size:12px;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.bk-hero-ports .arr{color:var(--accent2);}
.bk-highlights{display:flex;gap:8px;padding:16px 20px;overflow-x:auto;scrollbar-width:none;}
.bk-highlights::-webkit-scrollbar{display:none;}
.bk-hl{flex:0 0 auto;background:var(--card);border-radius:12px;border:1px solid var(--border);padding:12px 16px;text-align:center;min-width:76px;}
.bk-hl-icon{font-size:20px;margin-bottom:5px;}.bk-hl-val{font-family:'Space Mono',monospace;font-size:13px;font-weight:700;}
.bk-hl-label{font-size:9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:2px;}
.bk-section{padding:20px 20px 0;}
.bk-section-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.bk-section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.bk-bottom{position:absolute;bottom:0;left:0;right:0;padding:14px 20px;background:rgba(10,13,20,.96);backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;gap:12px;align-items:center;}
.bk-bottom-price{font-family:'Space Mono',monospace;font-size:19px;font-weight:700;color:var(--accent2);}
.bk-bottom-note{font-size:10px;color:var(--muted);margin-top:2px;}
.bk-next-btn{padding:14px 22px;border-radius:var(--radius-sm);border:none;background:linear-gradient(135deg,var(--accent2),#00aaff);color:white;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;white-space:nowrap;flex-shrink:0;}
.bk-next-btn:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(0,136,255,.3);}
.bk-success{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:85vh;padding:32px;text-align:center;}
.bk-success-ticket{background:var(--card);border-radius:24px;border:1px solid var(--border);padding:28px 22px;max-width:310px;width:100%;margin-bottom:24px;position:relative;overflow:hidden;}
.bk-success-ticket::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent2),var(--accent));}
.bk-ticket-icon{font-size:60px;margin-bottom:14px;display:block;animation:popIn .5s cubic-bezier(.32,.72,0,1) .1s both;}
@keyframes popIn{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}
.bk-ticket-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;margin-bottom:4px;}
.bk-ticket-no{font-family:'Space Mono',monospace;font-size:11px;color:var(--accent);margin-bottom:18px;letter-spacing:2px;}
.bk-ticket-divider{border:none;border-top:1px dashed var(--border);margin:14px 0;}
.bk-ticket-row{display:flex;justify-content:space-between;margin-bottom:9px;}
.bk-ticket-label{font-size:11px;color:var(--muted);}.bk-ticket-val{font-size:12px;font-weight:600;}
.bk-qr{width:70px;height:70px;margin:14px auto 0;background:white;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:46px;}
.bk-success-btns{display:flex;flex-direction:column;gap:10px;width:100%;max-width:310px;}

/* ════ MODAL ════ */
.modal-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:none;align-items:flex-end;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal-sheet{width:100%;max-width:520px;background:var(--surface);border-top-left-radius:28px;border-top-right-radius:28px;border:1px solid var(--border);border-bottom:none;transform:translateY(100%);transition:transform .38s cubic-bezier(.32,.72,0,1);max-height:92vh;display:flex;flex-direction:column;overflow:hidden;}
.modal-overlay.open .modal-sheet{transform:translateY(0);}
.modal-pill{width:36px;height:4px;border-radius:2px;background:var(--border);margin:16px auto 0;flex-shrink:0;}
.modal-header{padding:16px 24px 12px;border-bottom:1px solid var(--border);flex-shrink:0;}
.modal-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;margin-bottom:4px;}
.modal-sub{font-size:12px;color:var(--muted);}
.modal-body{flex:1;overflow-y:auto;padding:20px 24px;}
.modal-body::-webkit-scrollbar{width:3px;}
.modal-body::-webkit-scrollbar-thumb{background:var(--border);}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface);}
.modal-tabs{display:flex;margin-bottom:20px;background:var(--card);border-radius:var(--radius-sm);padding:4px;gap:4px;}
.modal-tab{flex:1;padding:10px;text-align:center;border-radius:9px;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);transition:all .2s;}
.modal-tab.active{background:var(--card2);color:var(--text);}
.amount-wrap{position:relative;margin-bottom:16px;}
.amount-currency{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-family:'Space Mono',monospace;font-size:18px;color:var(--muted);pointer-events:none;}
.amount-input{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:16px 16px 16px 44px;font-family:'Space Mono',monospace;font-size:24px;font-weight:700;color:var(--text);outline:none;transition:border-color .2s;-webkit-appearance:none;}
.amount-input:focus{border-color:rgba(0,212,170,.5);box-shadow:0 0 0 3px rgba(0,212,170,.07);}
.amount-presets{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;}
.amount-preset{flex:1;min-width:60px;padding:9px 8px;border-radius:10px;text-align:center;background:var(--card);border:1px solid var(--border);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;color:var(--text);}
.amount-preset:hover{border-color:var(--accent);color:var(--accent);}
.m-field{margin-bottom:14px;}
.m-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-family:'Space Mono',monospace;color:var(--muted);margin-bottom:7px;display:block;}
.m-input{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:13px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;-webkit-appearance:none;}
.m-input:focus{border-color:rgba(0,212,170,.4);}
.m-select{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:13px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;-webkit-appearance:none;}
.m-select option{background:var(--card);}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--border);font-size:13px;}
.info-row:last-child{border-bottom:none;}
.info-row-label{color:var(--muted);}.info-row-val{font-weight:600;}
.info-box{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);padding:4px 14px;margin-bottom:16px;}
.balance-big{text-align:center;padding:24px 0 20px;}
.balance-big-label{font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;font-family:'Space Mono',monospace;margin-bottom:8px;}
.balance-big-val{font-family:'Space Mono',monospace;font-size:36px;font-weight:700;}
.balance-big-sub{font-size:13px;color:var(--muted);margin-top:6px;}
.pool-card{background:var(--card);border-radius:var(--radius);border:1.5px solid var(--border);padding:18px;margin-bottom:12px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;}
.pool-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent3),var(--accent2));transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.pool-card:hover::before,.pool-card.selected::before{transform:scaleX(1);}
.pool-card.selected{border-color:rgba(168,85,247,.4);background:rgba(168,85,247,.05);}
.pool-card:hover{transform:translateY(-2px);}
.pool-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.pool-logo{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--card2);}
.pool-name{font-weight:700;font-size:15px;}.pool-token{font-size:11px;color:var(--muted);margin-top:2px;font-family:'Space Mono',monospace;}
.pool-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.pool-stat{background:var(--card2);border-radius:10px;padding:10px;text-align:center;}
.pool-stat-val{font-family:'Space Mono',monospace;font-size:14px;font-weight:700;}
.pool-stat-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:3px;}
.pool-card-radio{position:absolute;top:18px;right:18px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .25s;}
.pool-card.selected .pool-card-radio{border-color:var(--accent3);background:var(--accent3);color:white;font-size:11px;font-weight:700;}
.pool-card.selected .pool-card-radio::after{content:'✓';}
.stake-summary{background:linear-gradient(135deg,rgba(168,85,247,.1),rgba(0,136,255,.08));border-radius:var(--radius);border:1px solid rgba(168,85,247,.2);padding:20px;margin-bottom:16px;}
.stake-summary-title{font-size:11px;color:var(--accent3);letter-spacing:2px;text-transform:uppercase;font-family:'Space Mono',monospace;margin-bottom:12px;}
.stake-earn{display:flex;justify-content:space-between;align-items:center;}
.stake-earn-label{font-size:13px;color:var(--muted);}
.stake-earn-val{font-family:'Space Mono',monospace;font-size:18px;font-weight:700;color:var(--accent3);}
.unstake-btn{margin-top:12px;width:100%;padding:10px;border-radius:10px;background:rgba(255,92,106,.1);border:1px solid rgba(255,92,106,.2);color:#ff5c6a;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;}
.confirm-badge{display:flex;align-items:center;gap:10px;background:rgba(0,212,170,.08);border:1px solid rgba(0,212,170,.2);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:14px;font-size:13px;color:var(--muted);line-height:1.5;}
.confirm-badge-icon{font-size:20px;flex-shrink:0;}
.modal-submit{width:100%;padding:16px;border-radius:var(--radius-sm);border:none;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;}
.modal-submit.green{background:linear-gradient(135deg,#00aaff,var(--accent));color:var(--ink);}
.modal-submit.green:hover{box-shadow:0 8px 28px rgba(0,212,170,.3);transform:translateY(-1px);}
.modal-submit.purple{background:linear-gradient(135deg,var(--accent3),#7c3aed);color:white;}
.modal-submit.purple:hover{box-shadow:0 8px 28px rgba(168,85,247,.3);transform:translateY(-1px);}
.modal-submit.red{background:linear-gradient(135deg,#ff5c6a,#e02d3c);color:white;}
.progress-ring-wrap{display:flex;flex-direction:column;align-items:center;padding:16px 0 8px;}
.progress-ring-wrap svg{transform:rotate(-90deg);}
.ring-bg{fill:none;stroke:var(--card2);stroke-width:8;}
.ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .6s ease;}
.ring-label{text-align:center;margin-top:12px;}
.ring-val{font-family:'Space Mono',monospace;font-size:22px;font-weight:700;color:var(--accent3);}
.ring-sub{font-size:11px;color:var(--muted);margin-top:4px;}

/* ════ AUTH ════ */
#auth-screen{position:fixed;inset:0;z-index:400;background:var(--ink);display:flex;flex-direction:column;overflow-y:auto;}
#auth-screen.hidden{display:none;}
.auth-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.auth-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.18;animation:drift 18s infinite alternate ease-in-out;}
.auth-orb1{width:420px;height:420px;background:var(--accent2);top:-180px;right:-120px;}
.auth-orb2{width:340px;height:340px;background:var(--accent);bottom:-120px;left:-100px;animation-duration:22s;animation-delay:-8s;}
.auth-orb3{width:200px;height:200px;background:var(--accent3);top:45%;left:30%;animation-duration:28s;animation-delay:-14s;}
.auth-steps{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px 24px 0;position:relative;z-index:1;}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:'Space Mono',monospace;border:1.5px solid var(--border);color:var(--muted);background:var(--card);transition:all .4s ease;}
.step-dot.active{border-color:var(--accent);color:var(--accent);background:rgba(0,212,170,.1);}
.step-dot.done{border-color:var(--accent);background:var(--accent);color:var(--ink);}
.step-line{width:32px;height:1.5px;background:var(--border);border-radius:1px;transition:background .4s ease;}
.step-line.done{background:var(--accent);}
.auth-header{padding:28px 28px 0;position:relative;z-index:1;}
.auth-logo{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.55) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:6px;}
.auth-logo em{font-style:italic;-webkit-text-fill-color:var(--accent);}
.auth-sub{font-size:12px;color:var(--muted);letter-spacing:2px;font-family:'Space Mono',monospace;}
.auth-panels{position:relative;z-index:1;flex:1;overflow:hidden;}
.auth-panel{padding:28px 24px;display:none;animation:slideIn .35s cubic-bezier(.32,.72,0,1);}
.auth-panel.active{display:block;}
@keyframes slideIn{from{opacity:0;transform:translateX(24px);}to{opacity:1;transform:translateX(0);}}
.panel-title{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;line-height:1.2;margin-bottom:6px;}
.panel-desc{font-size:13px;color:var(--muted);margin-bottom:28px;line-height:1.6;}
.field-group{display:flex;flex-direction:column;gap:14px;margin-bottom:24px;}
.field-wrap{position:relative;}
.field-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-family:'Space Mono',monospace;color:var(--muted);margin-bottom:8px;display:block;transition:color .2s;}
.field-wrap:focus-within .field-label{color:var(--accent);}
.field-input{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px 14px 48px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:15px;outline:none;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;}
.field-input:focus{border-color:rgba(0,212,170,.5);box-shadow:0 0 0 3px rgba(0,212,170,.07);}
.field-input.error{border-color:rgba(255,92,106,.6);}
.field-icon{position:absolute;left:16px;bottom:14px;font-size:17px;pointer-events:none;}
.field-eye{position:absolute;right:14px;bottom:12px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;padding:4px;}
.field-error{font-size:11px;color:#ff5c6a;margin-top:6px;display:none;}
.field-error.show{display:block;}
.pw-strength{margin-top:10px;}
.pw-bars{display:flex;gap:4px;margin-bottom:5px;}
.pw-bar{flex:1;height:3px;border-radius:2px;background:var(--card2);transition:background .3s ease;}
.pw-bar.weak{background:#ff5c6a;}.pw-bar.fair{background:var(--gold);}.pw-bar.strong{background:var(--accent);}
.pw-label{font-size:10px;color:var(--muted);font-family:'Space Mono',monospace;}
.plan-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.plan-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:18px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;}
.plan-card.selected{border-color:var(--accent);background:rgba(0,212,170,.05);}
.plan-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent2),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.plan-card.selected::before{transform:scaleX(1);}
.plan-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.plan-name{font-weight:700;font-size:16px;}
.plan-badge{font-size:9px;padding:4px 10px;border-radius:100px;background:rgba(0,212,170,.15);color:var(--accent);font-family:'Space Mono',monospace;letter-spacing:1px;}
.plan-badge.gold{background:rgba(245,200,66,.15);color:var(--gold);}
.plan-badge.purple{background:rgba(168,85,247,.15);color:var(--accent3);}
.plan-price{font-family:'Space Mono',monospace;font-size:22px;font-weight:700;color:var(--accent);margin-bottom:10px;}
.plan-price span{font-size:12px;color:var(--muted);font-family:'DM Sans',sans-serif;}
.plan-features{display:flex;flex-direction:column;gap:5px;}
.plan-feat{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px;}
.plan-feat::before{content:'✓';color:var(--accent);font-size:11px;font-weight:700;flex-shrink:0;}
.plan-radio{position:absolute;top:18px;right:18px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .25s;}
.plan-card.selected .plan-radio{border-color:var(--accent);}
.plan-card.selected .plan-radio::after{content:'';width:10px;height:10px;border-radius:50%;background:var(--accent);}
.interest-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;}
.interest-chip{padding:9px 16px;border-radius:100px;font-size:13px;border:1.5px solid var(--border);background:var(--card);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;user-select:none;}
.interest-chip.selected{border-color:var(--accent);background:rgba(0,212,170,.1);color:var(--accent);}
.terms-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:14px;}
.check-row{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 0;}
.check-row+.check-row{border-top:1px solid var(--border);}
.custom-check{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;background:var(--card2);}
.check-row.checked .custom-check{background:var(--accent);border-color:var(--accent);}
.check-row.checked .custom-check::after{content:'✓';font-size:12px;font-weight:700;color:var(--ink);}
.check-text{font-size:13px;flex:1;line-height:1.4;}
.check-text .required{color:var(--accent);font-size:10px;margin-left:4px;font-family:'Space Mono',monospace;}
.check-arrow{color:var(--muted);font-size:14px;}
.auth-btn{width:100%;padding:16px;border-radius:var(--radius-sm);border:none;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;}
.auth-btn-primary{background:linear-gradient(135deg,var(--accent2) 0%,var(--accent) 100%);color:var(--ink);}
.auth-btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 30px rgba(0,212,170,.25);}
.auth-btn-ghost{background:transparent;border:1.5px solid var(--border);color:var(--muted);margin-top:10px;}
.auth-btn-ghost:hover{border-color:rgba(255,255,255,.2);color:var(--text);}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.auth-divider span{font-size:11px;color:var(--muted);white-space:nowrap;}
.social-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.social-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--radius-sm);background:var(--card);border:1.5px solid var(--border);cursor:pointer;transition:all .2s;font-size:13px;font-weight:500;color:var(--text);}
.social-btn:hover{border-color:rgba(255,255,255,.18);}
.success-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;padding:32px;text-align:center;position:relative;z-index:1;}
.success-icon{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),var(--accent));display:flex;align-items:center;justify-content:center;font-size:44px;margin-bottom:28px;animation:popIn .5s cubic-bezier(.32,.72,0,1) .1s both;box-shadow:0 20px 60px rgba(0,212,170,.3);}
.success-title{font-family:'Playfair Display',serif;font-size:30px;font-weight:700;margin-bottom:12px;}
.success-desc{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:32px;max-width:280px;}
.confetti-row{display:flex;gap:8px;justify-content:center;margin-bottom:32px;font-size:24px;animation:float 2s ease-in-out infinite alternate;}
@keyframes float{from{transform:translateY(0);}to{transform:translateY(-8px);}}
.auth-back{background:none;border:none;color:var(--muted);cursor:pointer;padding:8px;display:flex;align-items:center;gap:8px;font-family:'DM Sans',sans-serif;font-size:13px;margin-bottom:8px;transition:color .2s;}
.auth-back:hover{color:var(--text);}
.auth-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 24px 0;position:relative;z-index:1;}
.auth-login-link{font-size:13px;color:var(--muted);}
.auth-login-link a{color:var(--accent);text-decoration:none;font-weight:600;}
.code-inputs{display:flex;gap:10px;justify-content:center;margin-bottom:24px;}
.code-input{width:52px;height:60px;text-align:center;font-size:24px;font-weight:700;font-family:'Space Mono',monospace;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;transition:all .2s;-webkit-appearance:none;}
.code-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,212,170,.08);}
.code-input.filled{border-color:rgba(0,212,170,.4);}
.resend-row{text-align:center;font-size:13px;color:var(--muted);margin-bottom:24px;}
.resend-btn{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:600;}
.wallet-options{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.wallet-btn{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;}
.wallet-btn:hover{border-color:rgba(168,85,247,.4);}
.wallet-icon{font-size:28px;}.wallet-name{font-weight:600;font-size:15px;}.wallet-desc{font-size:12px;color:var(--muted);margin-top:2px;}

/* ════ PRIVACY SETTINGS SCREEN ════ */
#privacy-screen{position:fixed;inset:0;z-index:250;background:var(--ink);display:none;flex-direction:column;overflow:hidden;}
#privacy-screen.open{display:flex;}
.prv-topbar{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--border);background:rgba(10,13,20,.95);backdrop-filter:blur(20px);flex-shrink:0;}
.prv-back{width:38px;height:38px;border-radius:12px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--text);}
.prv-back:hover{background:var(--card2);}
.prv-topbar-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;}
.prv-topbar-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.prv-body{flex:1;overflow-y:auto;padding-bottom:32px;}
.prv-body::-webkit-scrollbar{width:3px;}
.prv-body::-webkit-scrollbar-thumb{background:var(--border);}
.prv-hero{padding:28px 24px 24px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(168,85,247,.06) 0%,transparent 100%);}
.prv-hero-icon{font-size:52px;margin-bottom:14px;display:block;}
.prv-hero-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;margin-bottom:8px;}
.prv-hero-desc{font-size:13px;color:var(--muted);line-height:1.7;}
.prv-section{padding:24px 20px 0;}
.prv-section-label{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--accent3);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.prv-section-label::after{content:'';flex:1;height:1px;background:rgba(168,85,247,.2);}
.prv-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;margin-bottom:12px;}
/* TOGGLE */
.prv-row{display:flex;align-items:center;gap:14px;padding:16px;border-bottom:1px solid var(--border);transition:background .2s;}
.prv-row:last-child{border-bottom:none;}
.prv-row:hover{background:rgba(255,255,255,.02);}
.prv-row-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.prv-row-info{flex:1;}
.prv-row-title{font-size:14px;font-weight:500;margin-bottom:3px;}
.prv-row-desc{font-size:11px;color:var(--muted);line-height:1.4;}
.toggle{width:46px;height:26px;border-radius:13px;background:var(--card2);border:1px solid var(--border);position:relative;cursor:pointer;transition:all .3s;flex-shrink:0;}
.toggle.on{background:var(--accent);border-color:var(--accent);}
.toggle::after{content:'';position:absolute;width:20px;height:20px;border-radius:50%;background:white;top:2px;left:2px;transition:transform .3s;box-shadow:0 1px 4px rgba(0,0,0,.3);}
.toggle.on::after{transform:translateX(20px);}
/* PROFILE EDIT */
.prv-avatar-wrap{display:flex;flex-direction:column;align-items:center;padding:24px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:12px;}
.prv-avatar{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),var(--accent));display:flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:14px;border:3px solid rgba(255,255,255,.1);position:relative;cursor:pointer;}
.prv-avatar-edit{position:absolute;bottom:0;right:0;width:28px;height:28px;border-radius:50%;background:var(--accent2);display:flex;align-items:center;justify-content:center;font-size:13px;border:2px solid var(--surface);}
.prv-avatar-name{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;margin-bottom:4px;}
.prv-avatar-sub{font-size:12px;color:var(--muted);}
.prv-edit-btn{margin-top:14px;padding:10px 24px;border-radius:100px;background:rgba(0,136,255,.1);border:1px solid rgba(0,136,255,.3);color:var(--accent2);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;}
.prv-edit-btn:hover{background:rgba(0,136,255,.2);}
/* FIELD */
.prv-field-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s;}
.prv-field-row:last-child{border-bottom:none;}
.prv-field-row:hover{background:rgba(255,255,255,.02);}
.prv-field-label{font-size:11px;color:var(--muted);margin-bottom:3px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;}
.prv-field-value{font-size:14px;font-weight:500;}
.prv-field-arrow{color:var(--muted);font-size:16px;margin-left:auto;flex-shrink:0;}
/* DATA USAGE BAR */
.data-usage-bar{background:var(--card2);border-radius:4px;height:6px;overflow:hidden;margin-top:8px;}
.data-usage-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent2),var(--accent));}
/* DANGER ZONE */
.danger-btn{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card);border-radius:var(--radius);border:1px solid rgba(255,92,106,.2);cursor:pointer;transition:all .2s;margin-bottom:10px;width:100%;}
.danger-btn:hover{border-color:rgba(255,92,106,.4);background:rgba(255,92,106,.05);}
.danger-icon{width:40px;height:40px;border-radius:12px;background:rgba(255,92,106,.1);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.danger-text{flex:1;text-align:left;}.danger-title{font-size:14px;font-weight:600;color:#ff5c6a;}
.danger-desc{font-size:11px;color:var(--muted);margin-top:2px;}
/* SECURITY LEVEL */
.security-meter{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:20px;margin-bottom:12px;}
.security-label{font-size:12px;color:var(--muted);margin-bottom:6px;}
.security-level{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.security-score{font-family:'Space Mono',monospace;font-size:22px;font-weight:700;color:var(--gold);}
.security-grade{font-size:11px;padding:4px 10px;border-radius:100px;background:rgba(245,200,66,.15);color:var(--gold);font-family:'Space Mono',monospace;}
.security-bars{display:flex;gap:4px;}
.security-bar{flex:1;height:5px;border-radius:3px;background:var(--card2);}
.security-bar.filled{background:var(--gold);}
.security-bar.filled.low{background:#ff5c6a;}.security-bar.filled.mid{background:var(--gold);}.security-bar.filled.hi{background:var(--accent);}
/* CONNECTED DEVICES */
.device-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);}
.device-item:last-child{border-bottom:none;}
.device-icon{font-size:22px;width:40px;height:40px;border-radius:12px;background:var(--card2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.device-info{flex:1;}.device-name{font-size:13px;font-weight:600;margin-bottom:2px;}
.device-detail{font-size:11px;color:var(--muted);}
.device-status{font-size:10px;padding:3px 8px;border-radius:100px;}
.device-status.active{background:rgba(0,212,170,.15);color:var(--accent);}
.device-status.inactive{background:rgba(255,255,255,.05);color:var(--muted);}
.revoke-btn{background:none;border:1px solid rgba(255,92,106,.3);color:#ff5c6a;font-size:11px;padding:5px 10px;border-radius:8px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;flex-shrink:0;}
.revoke-btn:hover{background:rgba(255,92,106,.1);}
/* INLINE EDIT MODAL */
.edit-modal-overlay{position:fixed;inset:0;z-index:350;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:24px;}
.edit-modal-overlay.open{display:flex;}
.edit-modal{background:var(--surface);border-radius:24px;border:1px solid var(--border);padding:28px 24px;width:100%;max-width:420px;animation:popIn .3s ease;}
.edit-modal-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;margin-bottom:4px;}
.edit-modal-sub{font-size:12px;color:var(--muted);margin-bottom:20px;}
.edit-modal-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px;}
.edit-cancel{padding:13px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);color:var(--muted);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;}
.edit-cancel:hover{border-color:rgba(255,255,255,.2);color:var(--text);}
.edit-save{padding:13px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent2),var(--accent));color:var(--ink);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all .2s;}
.edit-save:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,212,170,.3);}

.color-accent{color:var(--accent);}.color-blue{color:var(--accent2);}.color-purple{color:var(--accent3);}.color-gold{color:var(--gold);}
.gap-list{display:flex;flex-direction:column;gap:0;}

/* ════ INTRO SCREEN ════ */
#intro-screen{position:fixed;inset:0;z-index:600;background:#020509;display:flex;flex-direction:column;overflow:hidden;}
#intro-screen.hidden{display:none;}
.intro-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;}

/* STAR CANVAS */
.intro-star-canvas{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}

/* AMBIENT ORBS */
.intro-orb{position:absolute;border-radius:50%;filter:blur(90px);}
.intro-orb1{width:420px;height:420px;background:#0055bb;top:-180px;right:-130px;opacity:.22;animation:drift 22s infinite alternate ease-in-out;}
.intro-orb2{width:340px;height:340px;background:#00aa88;bottom:-140px;left:-100px;opacity:.18;animation:drift 26s infinite alternate ease-in-out;animation-delay:-10s;}
.intro-orb3{width:200px;height:200px;background:#8844ee;top:45%;left:30%;opacity:.14;animation:drift 30s infinite alternate ease-in-out;animation-delay:-18s;}

/* SPLASH */
.intro-splash{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;flex:1;padding:0 0 20px;overflow-y:auto;}
.intro-splash::-webkit-scrollbar{display:none;}

/* GLOBE WRAP */
.globe-wrap{position:relative;width:100%;max-width:100%;height:400px;margin:0 auto -30px;flex-shrink:0;}
.globe-svg{width:100%;height:100%;display:block;}

/* SHIP FLOAT */
@keyframes shipFloat{0%,100%{transform:translateY(0) rotate(-1.5deg);}50%{transform:translateY(-10px) rotate(1.5deg);}}
@keyframes enginePulse{0%,100%{opacity:.5;}50%{opacity:1;}}
@keyframes scanLine{0%{transform:translateY(-60px);opacity:0;}30%{opacity:.4;}70%{opacity:.4;}100%{transform:translateY(60px);opacity:0;}}
@keyframes orbitSpin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}

.ship-group{animation:shipFloat 4s ease-in-out infinite;}
.engine-glow{animation:enginePulse 1.8s ease-in-out infinite;}
.scan-line{animation:scanLine 3s ease-in-out infinite;}
.orbit-ring{transform-box:fill-box;transform-origin:50% 50%;animation:orbitSpin 12s linear infinite;}
.live-dot{animation:blink 2s ease-in-out infinite;}

/* BRAND */
.intro-logo-wrap{text-align:center;margin-bottom:10px;position:relative;z-index:10;}
.intro-brand-text{font-family:'Playfair Display',serif;font-size:38px;font-weight:700;letter-spacing:5px;background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.7) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;}
.intro-brand-em{-webkit-text-fill-color:#00d4aa !important;}
.intro-tagline-text{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:3.5px;color:#2a5a7a;text-transform:uppercase;margin-top:6px;}

/* FEATURE PILLS */
.intro-pills{display:flex;gap:6px;justify-content:center;margin-bottom:14px;flex-wrap:wrap;position:relative;z-index:10;}
.intro-pill{padding:7px 14px;border-radius:100px;font-size:11px;font-family:'Space Mono',monospace;letter-spacing:.5px;border:1px solid;display:flex;align-items:center;gap:5px;}
.intro-pill-blue{background:rgba(0,136,255,.1);border-color:rgba(0,136,255,.35);color:#4db8ff;}
.intro-pill-teal{background:rgba(0,212,170,.1);border-color:rgba(0,212,170,.35);color:#00d4aa;}
.intro-pill-purple{background:rgba(168,85,247,.1);border-color:rgba(168,85,247,.35);color:#c084fc;}

/* SEPARATOR */
.intro-sep{width:160px;height:1px;background:linear-gradient(90deg,transparent,#1a3a5c,transparent);margin:0 auto 14px;position:relative;z-index:10;}

/* BUTTONS */
.intro-btns{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto;position:relative;z-index:10;}
.intro-btn-main{padding:18px;border-radius:16px;border:none;background:linear-gradient(135deg,#0066dd,#00aaff);color:#ffffff;font-family:'DM Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;letter-spacing:.3px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;}
.intro-btn-main:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(0,136,255,.35);}
.intro-btn-main::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);}
.intro-btn-login{padding:16px;border-radius:16px;border:1.5px solid #1a3a5c;background:rgba(255,255,255,.03);color:#4488aa;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;}
.intro-btn-login:hover{border-color:#2a5a7a;background:rgba(255,255,255,.06);color:#77aabb;}
.intro-guest-link{text-align:center;font-size:12px;color:#2a4a6a;cursor:pointer;margin-top:12px;text-decoration:underline;text-underline-offset:3px;position:relative;z-index:10;}
.intro-terms-text{font-size:10px;color:#1e3a52;text-align:center;line-height:1.7;margin-top:14px;max-width:280px;position:relative;z-index:10;}
.intro-terms-text a{color:#2a6a8a;text-decoration:none;}

/* HUD ELEMENTS */
.hud-coord{font-family:'Space Mono',monospace;font-size:9px;color:#1a3a5c;position:absolute;}

/* ONBOARDING */
.onboard-wrap{position:relative;z-index:1;display:flex;flex-direction:column;flex:1;background:#020509;}
.onboard-slides{flex:1;overflow:hidden;position:relative;}
.onboard-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;text-align:center;opacity:0;transform:translateX(60px);transition:all .5s cubic-bezier(.32,.72,0,1);pointer-events:none;}
.onboard-slide.active{opacity:1;transform:translateX(0);pointer-events:all;}
.onboard-slide.prev{opacity:0;transform:translateX(-60px);}
.onboard-emoji{font-size:80px;margin-bottom:24px;filter:drop-shadow(0 0 30px rgba(0,136,255,.4));}
.onboard-title{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;line-height:1.2;margin-bottom:14px;color:#e8eaf0;}
.onboard-title em{font-style:italic;color:#00d4aa;}
.onboard-desc{font-size:14px;color:#6b7494;line-height:1.75;max-width:280px;}
.onboard-dots{display:flex;gap:8px;justify-content:center;padding:20px 0;}
.onboard-dot{width:8px;height:8px;border-radius:4px;background:#1a2a3a;transition:all .3s;}
.onboard-dot.active{background:#00d4aa;width:24px;}
.onboard-nav{display:flex;gap:12px;padding:0 24px 48px;}
.onboard-skip{flex:1;padding:16px;border-radius:14px;border:1.5px solid #1a2a3a;background:transparent;color:#6b7494;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;}
.onboard-next{flex:2;padding:16px;border-radius:14px;border:none;background:linear-gradient(135deg,#0066dd,#00aaff);color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;}
.onboard-next:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(0,136,255,.3);}

/* LOGIN SCREEN */
#login-screen{position:fixed;inset:0;z-index:500;background:var(--ink);display:none;flex-direction:column;overflow-y:auto;}
#login-screen.open{display:flex;}
.login-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.login-orb1{width:380px;height:380px;background:var(--accent2);top:-150px;right:-100px;position:absolute;border-radius:50%;filter:blur(90px);opacity:.15;animation:drift 20s infinite alternate;}
.login-orb2{width:300px;height:300px;background:var(--accent);bottom:-100px;left:-80px;position:absolute;border-radius:50%;filter:blur(90px);opacity:.15;animation:drift 24s infinite alternate;animation-delay:-10s;}
.login-wrap{position:relative;z-index:1;display:flex;flex-direction:column;flex:1;padding:0 24px 40px;}
.login-header{padding:20px 0 0;display:flex;align-items:center;justify-content:space-between;}
.login-close{background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:8px;transition:color .2s;}
.login-close:hover{color:var(--text);}
.login-logo{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;background:linear-gradient(135deg,#fff,rgba(255,255,255,.6));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.login-logo em{font-style:italic;-webkit-text-fill-color:var(--accent);}
.login-title-wrap{padding:36px 0 28px;text-align:left;}
.login-title{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;line-height:1.15;margin-bottom:8px;}
.login-sub{font-size:14px;color:var(--muted);line-height:1.6;}
.login-tabs{display:flex;background:var(--card);border-radius:14px;padding:4px;gap:4px;margin-bottom:28px;}
.login-tab{flex:1;padding:11px;text-align:center;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;color:var(--muted);transition:all .25s;}
.login-tab.active{background:var(--card2);color:var(--text);}
.login-form{display:flex;flex-direction:column;gap:14px;}
.lf-wrap{position:relative;}
.lf-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-family:'Space Mono',monospace;color:var(--muted);margin-bottom:7px;display:block;transition:color .2s;}
.lf-wrap:focus-within .lf-label{color:var(--accent);}
.lf-icon{position:absolute;left:16px;bottom:14px;font-size:17px;pointer-events:none;}
.lf-input{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px 14px 48px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:15px;outline:none;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;}
.lf-input:focus{border-color:rgba(0,212,170,.5);box-shadow:0 0 0 3px rgba(0,212,170,.07);}
.lf-eye{position:absolute;right:14px;bottom:12px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;padding:4px;}
.lf-error{font-size:11px;color:#ff5c6a;margin-top:5px;display:none;}
.lf-error.show{display:block;}
.login-forgot{text-align:right;font-size:12px;color:var(--accent);cursor:pointer;text-decoration:none;margin-top:-6px;}
.login-submit{padding:17px;border-radius:14px;border:none;background:linear-gradient(135deg,var(--accent2),var(--accent));color:var(--ink);font-family:'DM Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;margin-top:8px;}
.login-submit:hover{transform:translateY(-1px);box-shadow:0 10px 32px rgba(0,212,170,.3);}
.login-divider{display:flex;align-items:center;gap:12px;margin:24px 0;}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.login-divider span{font-size:11px;color:var(--muted);white-space:nowrap;}
.login-social{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.login-social-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:12px;background:var(--card);border:1.5px solid var(--border);cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:var(--text);}
.login-social-btn:hover{border-color:rgba(255,255,255,.18);background:var(--card2);}
.login-switch{text-align:center;font-size:13px;color:var(--muted);margin-top:24px;}
.login-switch a{color:var(--accent);text-decoration:none;font-weight:600;cursor:pointer;}
.login-biometric{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 0;cursor:pointer;opacity:.7;transition:opacity .2s;}
.login-biometric:hover{opacity:1;}
.login-biometric-icon{font-size:48px;animation:pulse 2s infinite;}
.login-biometric-label{font-size:12px;color:var(--muted);}

