﻿/* ═══════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#0d0c09;--ink-l:#1a1812;--ink-m:#4a4840;--ink-s:#78766e;
  --paper:#f8f6f1;--paper-w:#efece3;--paper-d:#ddd8ce;
  --gold:#bf9a4e;--gold-l:#d4b66a;--gold-d:#a07d38;--gold-a:rgba(191,154,78,.12);--gold-a2:rgba(191,154,78,.22);
  --red:#b84036;--jade:#4e7d5e;--jade-l:#6ea478;
  --r:8px;--t:.45s cubic-bezier(.25,.46,.45,.94);
}
html{scroll-behavior:smooth;font-size:16px}
body{font:16px/1.8 'Noto Sans SC',sans-serif;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}
h1,h2,h3,h4{font:700 1em/1.3 'Noto Serif SC',serif;letter-spacing:.04em}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gold-d);border-radius:3px;opacity:.5}
::-webkit-scrollbar-thumb:hover{background:var(--gold)}
::selection{background:var(--gold);color:var(--paper)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ═══════════════════════════════════════
   LOADER
   ═══════════════════════════════════════ */
.loader{position:fixed;inset:0;z-index:9999;background:var(--ink);display:flex;align-items:center;justify-content:center;transition:opacity 1s ease,visibility 1s ease}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center;position:relative}

/* Seal — larger with glow ring */
.loader-seal{width:100px;height:100px;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Noto Serif SC',serif;font-size:42px;color:var(--gold);margin:0 auto 36px;position:relative;animation:sealPulse 2.5s ease-in-out infinite}
.loader-seal::before{content:'';position:absolute;inset:-12px;border:1px solid rgba(191,154,78,.15);border-radius:50%;animation:ringExpand 2.5s ease-in-out infinite}
.loader-seal::after{content:'';position:absolute;inset:-24px;border:1px solid rgba(191,154,78,.08);border-radius:50%;animation:ringExpand 2.5s ease-in-out .3s infinite}

/* Bar — wider, taller, with shimmer */
.loader-bar{width:280px;height:3px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;position:relative;box-shadow:0 0 20px rgba(191,154,78,.06)}
.loader-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-l),var(--gold));animation:loadBar 2.2s cubic-bezier(.4,0,.2,1) forwards;position:relative;border-radius:2px;box-shadow:0 0 12px rgba(191,154,78,.3)}
.loader-bar span::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s ease-in-out infinite}

/* Percentage counter */
.loader-pct{font-family:'Noto Sans SC',sans-serif;font-size:13px;color:rgba(255,255,255,.3);letter-spacing:.3em;margin-top:18px;font-weight:300}
.loader-pct span{color:var(--gold);font-weight:500}

/* Tagline */
.loader-tag{font-size:11px;color:rgba(255,255,255,.18);letter-spacing:.25em;margin-top:10px;text-transform:uppercase}

@keyframes sealPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.96)}}
@keyframes ringExpand{0%{opacity:0;transform:scale(.8)}50%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.15)}}
@keyframes loadBar{to{width:100%}}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ═══════════════════════════════════════
   NAV
   ═══════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 4%;transition:var(--t)}
.nav::before{content:'';position:absolute;inset:0;background:rgba(248,246,241,.78);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);opacity:0;transition:opacity .5s}
.nav.scrolled::before{opacity:1}
.nav.scrolled{box-shadow:0 1px 0 rgba(0,0,0,.05),0 4px 20px rgba(0,0,0,.03)}
.nav-inner{position:relative;max-width:1300px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:72px}
.nav-logo{display:flex;align-items:center;gap:10px;z-index:1}
.nav-logo .logo-svg{flex-shrink:0;transition:transform .4s}
.nav-logo:hover .logo-svg{transform:rotate(-5deg) scale(1.05)}
.nav-logo span{font-family:'Noto Serif SC',serif;font-size:18px;font-weight:700;letter-spacing:.06em}
.nav-links{display:flex;gap:4px;z-index:1}
.nav-links a{font-size:13px;color:var(--ink-m);padding:8px 14px;border-radius:var(--r);transition:var(--t);letter-spacing:.04em;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:2px;left:14px;right:14px;height:2px;background:var(--gold);border-radius:1px;transform:scaleX(0);transition:transform .35s cubic-bezier(.25,.46,.45,.94)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:12px;z-index:1}
.nav-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-s)}
.nav-status .dot{width:6px;height:6px;background:var(--jade);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.nav-cta{background:var(--ink)!important;color:var(--paper)!important;padding:9px 22px!important;border-radius:var(--r)!important;font-size:12px!important;letter-spacing:.1em!important;cursor:pointer;border:none;font-weight:500;transition:var(--t);display:inline-flex;align-items:center;gap:6px;box-shadow:0 2px 8px rgba(13,12,9,.12)}
.nav-cta:hover{background:var(--ink-l)!important;transform:translateY(-2px);box-shadow:0 6px 20px rgba(13,12,9,.2)}
.nav-vip{background:linear-gradient(135deg,var(--gold-a2),var(--gold-a));border:1px solid rgba(191,154,78,.28);color:var(--gold-d);padding:8px 16px;border-radius:var(--r);font-size:12px;letter-spacing:.06em;cursor:pointer;font-family:'Noto Sans SC',sans-serif;font-weight:500;transition:var(--t);display:inline-flex;align-items:center;gap:6px}
.nav-vip:hover{background:linear-gradient(135deg,rgba(191,154,78,.22),rgba(191,154,78,.1));border-color:var(--gold);color:var(--gold);box-shadow:0 0 20px rgba(191,154,78,.15);transform:translateY(-1px)}
.nav-vip i{font-size:11px}
.nav-login{background:transparent;border:1px solid var(--paper-d);color:var(--ink-m);padding:8px 18px;border-radius:var(--r);font-size:12px;letter-spacing:.08em;cursor:pointer;font-family:'Noto Sans SC',sans-serif;font-weight:500;transition:var(--t);display:inline-flex;align-items:center;gap:6px}
.nav-login:hover{border-color:var(--gold);color:var(--gold-d);background:var(--gold-a);transform:translateY(-1px)}
.nav-login.logged{border-color:var(--jade);color:var(--jade);gap:8px;background:rgba(78,125,94,.06)}
.nav-login.logged .av-sm{width:22px;height:22px;background:var(--gold-a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--gold);font-weight:700}
.nav-toggle{display:none;background:none;border:none;font-size:20px;color:var(--ink);cursor:pointer;z-index:1}

/* ═══════════════════════════════════════
   HERO — SPLIT LAYOUT
   ═══════════════════════════════════════ */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:100px 6% 80px;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--gold-a);border:1px solid rgba(191,154,78,.25);padding:7px 18px 7px 12px;border-radius:100px;font-size:12px;color:var(--gold);margin-bottom:36px;width:fit-content;opacity:0;animation:fadeUp .8s .4s forwards;letter-spacing:.06em;backdrop-filter:blur(8px)}
.hero-badge .dot{width:6px;height:6px;background:var(--gold);border-radius:50%;box-shadow:0 0 8px var(--gold)}
.hero h1{font-size:clamp(38px,5vw,64px);line-height:1.12;margin-bottom:24px;opacity:0;animation:fadeUp .8s .6s forwards}
.hero h1 em{font-style:normal;color:var(--gold);position:relative}
.hero h1 em::after{content:'';position:absolute;bottom:3px;left:-4px;right:-4px;height:9px;background:var(--gold);opacity:.14;z-index:-1;border-radius:2px}
.hero-desc{font-size:15px;color:var(--ink-m);max-width:460px;margin-bottom:40px;line-height:2.1;opacity:0;animation:fadeUp .8s .8s forwards}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fadeUp .8s 1s forwards}
.btn{padding:14px 32px;font-size:13px;border:none;cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;font-weight:500;letter-spacing:.1em;display:inline-flex;align-items:center;gap:8px;border-radius:var(--r)}
.btn-dark{background:var(--ink);color:var(--paper);box-shadow:0 2px 12px rgba(13,12,9,.15)}
.btn-dark:hover{background:var(--ink-l);transform:translateY(-2px);box-shadow:0 8px 28px rgba(13,12,9,.22)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--paper-d)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-a)}
.hero-stats{display:flex;gap:48px;margin-top:56px;padding-top:36px;border-top:1px solid var(--paper-d);opacity:0;animation:fadeUp .8s 1.2s forwards}
.hero-stat .num{font-family:'Noto Serif SC',serif;font-size:36px;font-weight:900;color:var(--ink)}
.hero-stat .label{font-size:12px;color:var(--ink-s);margin-top:4px;letter-spacing:.08em}

/* Hero right — visual */
.hero-right{position:relative;overflow:hidden}
.hero-visual{position:absolute;inset:0;background:linear-gradient(170deg,#0f0e08 0%,#1e1810 30%,#14181a 65%,#0d0f12 100%)}
.hero-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 65% 35%,rgba(191,154,78,.18) 0%,transparent 55%),radial-gradient(ellipse at 30% 70%,rgba(78,125,94,.08) 0%,transparent 50%)}
.hero-visual-pattern{position:absolute;inset:0;opacity:.12;background-image:radial-gradient(circle at 25% 25%,var(--gold) 1px,transparent 1px),radial-gradient(circle at 75% 75%,var(--gold) .5px,transparent .5px);background-size:55px 55px,36px 36px;animation:drift 80s linear infinite}
/* Golden dust motes */
.hero-visual::after{content:'';position:absolute;inset:0;background:radial-gradient(1px 1px at 20% 30%,rgba(212,182,106,.6) 0%,transparent 100%),radial-gradient(1px 1px at 50% 50%,rgba(212,182,106,.4) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 75% 20%,rgba(212,182,106,.5) 0%,transparent 100%),radial-gradient(1px 1px at 35% 65%,rgba(212,182,106,.35) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 60% 80%,rgba(212,182,106,.45) 0%,transparent 100%),radial-gradient(1px 1px at 85% 55%,rgba(212,182,106,.3) 0%,transparent 100%),radial-gradient(1px 1px at 10% 75%,rgba(212,182,106,.4) 0%,transparent 100%),radial-gradient(2px 2px at 45% 15%,rgba(212,182,106,.55) 0%,transparent 100%);animation:twinkle 4s ease-in-out infinite alternate}
@keyframes twinkle{0%{opacity:.6}50%{opacity:1}100%{opacity:.5}}
@keyframes drift{from{transform:translate(0,0)}to{transform:translate(-30px,-30px)}}
.hero-quote{position:absolute;bottom:15%;left:10%;right:10%;z-index:2;color:rgba(255,255,255,.55);font-family:'Noto Serif SC',serif;font-size:clamp(15px,2vw,22px);line-height:2.2;opacity:0;animation:fadeUp 1s 1.4s forwards;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.hero-quote cite{display:block;font-size:13px;color:var(--gold-l);margin-top:14px;font-style:normal;letter-spacing:.18em}
.hero-float{position:absolute;z-index:2;background:rgba(26,24,18,.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:14px 18px;color:rgba(255,255,255,.85);font-size:12px;display:flex;align-items:center;gap:10px;animation:float 6s ease-in-out infinite;box-shadow:0 4px 24px rgba(0,0,0,.2)}
.hero-float.one{top:20%;right:7%;animation-delay:0s}
.hero-float.two{top:58%;right:13%;animation-delay:2s}
.hero-float .icon{width:34px;height:34px;background:rgba(191,154,78,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-l);font-size:14px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Hero quote bubbles — float in/out like reviews */
.hero-quotes{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.hero-q-bubble{position:absolute;max-width:220px;background:rgba(26,24,18,.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(191,154,78,.1);border-radius:var(--r);padding:14px 16px;color:rgba(255,255,255,.5);font-family:'Noto Serif SC',serif;font-size:12px;line-height:1.9;opacity:0;pointer-events:none;will-change:transform,opacity;box-shadow:0 4px 20px rgba(0,0,0,.15)}
.hero-q-bubble .q-mark{position:absolute;top:-8px;left:16px;font-size:28px;color:var(--gold-l);opacity:.25;line-height:1}
.hero-q-bubble .q-src{display:block;font-size:10px;color:var(--gold-l);opacity:.5;margin-top:8px;font-family:'Noto Sans SC',sans-serif;letter-spacing:.1em;font-style:normal}
@keyframes heroQIn{
  0%{opacity:0;transform:translateY(24px) scale(.94)}
  15%{opacity:.7;transform:translateY(0) scale(1)}
  75%{opacity:.7;transform:translateY(0) scale(1)}
  100%{opacity:0;transform:translateY(-16px) scale(.96)}
}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.3);font-size:11px;letter-spacing:.2em;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════
   LIVE TICKER
   ═══════════════════════════════════════ */
.ticker{background:var(--ink);padding:14px 0;overflow:hidden;position:relative;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.ticker-track{display:flex;gap:60px;animation:scroll 30s linear infinite;width:max-content}
.ticker-item{display:flex;align-items:center;gap:10px;white-space:nowrap;font-size:13px;color:rgba(255,255,255,.45)}
.ticker-item .dot{width:5px;height:5px;background:var(--jade);border-radius:50%;box-shadow:0 0 6px rgba(78,125,94,.5)}
.ticker-item strong{color:rgba(255,255,255,.75);font-weight:500}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════
   SECTION UTILITY
   ═══════════════════════════════════════ */
.sec{padding:100px 6%;position:relative;scroll-margin-top:72px}
.sec-inner{max-width:1200px;margin:0 auto}
.sec-head{margin-bottom:60px}
.sec-head.center{text-align:center}
.sec-head .tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-d);border:1px solid rgba(191,154,78,.3);padding:5px 16px;border-radius:100px;margin-bottom:20px}
.sec-head h2{font-size:clamp(28px,3.8vw,44px);color:var(--ink);margin-bottom:14px;line-height:1.25}
.sec-head p{color:var(--ink-m);font-size:15px;max-width:560px;line-height:1.9}
.sec-head.center p{margin:0 auto}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ═══════════════════════════════════════
   FEATURES — BENTO GRID
   ═══════════════════════════════════════ */
.feat-sec{background:var(--paper)}
.bento{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:auto auto;gap:16px}
.feat-card{background:#fff;border:1px solid var(--paper-d);border-radius:var(--r);padding:36px 32px;transition:transform .45s cubic-bezier(.25,.46,.45,.94),box-shadow .45s cubic-bezier(.25,.46,.45,.94),border-color .3s;cursor:pointer;position:relative;overflow:hidden}
.feat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-d),var(--gold-l));transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.25,.46,.45,.94)}
.feat-card::after{content:'';position:absolute;inset:0;border-radius:var(--r);opacity:0;box-shadow:0 20px 50px rgba(13,12,9,.08);transition:opacity .45s;pointer-events:none}
.feat-card:hover::before{transform:scaleX(1)}
.feat-card:hover::after{opacity:1}
.feat-card:hover{transform:translateY(-6px);border-color:transparent}
.feat-card.big{grid-column:span 7;padding:44px 40px}
.feat-card.small{grid-column:span 5}
.feat-card.wide{grid-column:span 6}
.feat-ic{width:52px;height:52px;background:var(--gold-a);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:20px;margin-bottom:24px;transition:var(--t)}
.feat-card:hover .feat-ic{background:var(--gold);color:var(--paper);transform:scale(1.08);box-shadow:0 6px 20px rgba(191,154,78,.3)}
.feat-card h4{font-size:19px;margin-bottom:12px;letter-spacing:.05em}
.feat-card>p{color:var(--ink-m);font-size:14px;line-height:1.85;margin-bottom:20px}
.feat-metrics{display:flex;gap:28px;padding-top:18px;border-top:1px solid var(--paper-w)}
.feat-metrics .m{text-align:center}
.feat-metrics .mv{font-family:'Noto Serif SC',serif;font-size:26px;font-weight:700;color:var(--ink)}
.feat-metrics .ml{font-size:11px;color:var(--ink-s);letter-spacing:.05em;margin-top:2px}
.feat-btn{display:inline-flex;align-items:center;gap:6px;margin-top:18px;padding:9px 20px;font-size:12px;color:var(--gold-d);border:1.5px solid var(--gold);background:transparent;border-radius:var(--r);cursor:pointer;transition:var(--t);letter-spacing:.08em;font-family:'Noto Sans SC',sans-serif}
.feat-btn:hover{background:var(--gold);color:var(--paper);box-shadow:0 4px 16px rgba(191,154,78,.25);transform:translateY(-1px)}

/* Big card — horizontal layout */
.feat-card.big .feat-inner{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.feat-card.big .feat-visual{height:100%;min-height:200px;background:linear-gradient(135deg,#1a1a1a,#2a2018);border-radius:var(--r);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.feat-card.big .feat-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(191,154,78,.1),transparent 70%)}
.feat-card.big .feat-visual i{font-size:52px;color:var(--gold);opacity:.7;position:relative;z-index:1}

/* ═══════════════════════════════════════
   THEMES — HORIZONTAL SCROLL
   ═══════════════════════════════════════ */
.themes-sec{background:var(--ink);overflow:hidden}
.themes-sec .sec-head h2{color:#fff}
.themes-sec .sec-head p{color:rgba(255,255,255,.45)}
.themes-sec .sec-head .tag{border-color:rgba(191,154,78,.3)}
.themes-wrap{display:flex;gap:20px;overflow-x:auto;padding:0 6% 40px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.themes-wrap::-webkit-scrollbar{display:none}
.theme-card{min-width:340px;max-width:380px;flex-shrink:0;scroll-snap-align:start;background:var(--ink-l);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);overflow:hidden;transition:transform .45s cubic-bezier(.25,.46,.45,.94),border-color .3s,box-shadow .4s}
.theme-card:hover{border-color:rgba(191,154,78,.3);transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.theme-visual{height:200px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.theme-visual i{font-size:48px;color:var(--gold-l);opacity:.6;z-index:1;transition:transform .5s}
.theme-card:hover .theme-visual i{transform:scale(1.1);opacity:.8}
.theme-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--ink-l) 0%,transparent 60%)}
.theme-1 .theme-visual{background:linear-gradient(135deg,#2a1f1a,#1a2a1f)}
.theme-2 .theme-visual{background:linear-gradient(135deg,#1a1a2a,#2a1a1a)}
.theme-3 .theme-visual{background:linear-gradient(135deg,#1a2a2a,#1a1a2a)}
.theme-body{padding:26px}
.theme-body h4{color:#fff;font-size:18px;margin-bottom:8px}
.theme-tag{display:inline-block;background:var(--gold-a2);color:var(--gold-l);padding:3px 12px;border-radius:100px;font-size:11px;letter-spacing:.1em;margin-bottom:14px}
.theme-body>p{color:rgba(255,255,255,.4);font-size:13px;line-height:1.85;margin-bottom:20px}
.theme-btns{display:flex;gap:8px}
.theme-btn{flex:1;padding:10px 14px;font-size:12px;border-radius:var(--r);cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;text-align:center;letter-spacing:.06em}
.theme-btn.out{background:transparent;border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.55)}
.theme-btn.out:hover{border-color:var(--gold);color:var(--gold)}
.theme-btn.fill{background:linear-gradient(135deg,var(--gold-d),var(--gold));border:1px solid transparent;color:var(--paper);font-weight:600}
.theme-btn.fill:hover{background:linear-gradient(135deg,var(--gold),var(--gold-l));transform:translateY(-1px);box-shadow:0 4px 16px rgba(191,154,78,.3)}

/* ═══════════════════════════════════════
   AR SECTION — SPLIT
   ═══════════════════════════════════════ */
.ar-sec{background:var(--paper-w)}
.ar-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.ar-text p{color:var(--ink-m);font-size:15px;line-height:2;margin-bottom:24px}
.ar-features{display:flex;flex-direction:column;gap:16px}
.ar-feat{display:flex;gap:14px;align-items:flex-start}
.ar-feat .dot{width:36px;height:36px;background:var(--gold-a);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:14px;flex-shrink:0}
.ar-feat h5{font-size:14px;color:var(--ink);margin-bottom:2px;font-family:'Noto Sans SC',sans-serif;font-weight:600}
.ar-feat p{font-size:13px;color:var(--ink-s)}
.ar-visual{text-align:center}
.ar-frame{background:#fff;border:1px solid var(--paper-d);border-radius:var(--r);padding:40px}
.ar-qr{width:160px;height:160px;margin:0 auto 20px;background:var(--ink);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-direction:column;gap:8px}
.ar-qr i{font-size:36px}
.ar-qr span{font-size:12px;color:rgba(255,255,255,.5)}
.ar-frame>p{font-size:12px;color:var(--ink-s);margin-top:6px}
.ar-ctrls{display:flex;gap:10px;justify-content:center;margin-top:20px}

/* ═══════════════════════════════════════
   ECO — IMMERSIVE
   ═══════════════════════════════════════ */
.eco-sec{background:linear-gradient(180deg,#0a0a08 0%,#12110e 50%,#151412 100%);color:#fff;position:relative}
.eco-sec::before{content:'';position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.6' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
.eco-sec .sec-head h2{color:#fff}
.eco-sec .sec-head p{color:rgba(255,255,255,.38)}
.eco-sec .sec-head .tag{border-color:rgba(191,154,78,.3)}
.eco-top{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:44px}
.eco-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:var(--r);padding:30px 22px;text-align:center;transition:transform .4s cubic-bezier(.25,.46,.45,.94),border-color .3s,background .3s;cursor:pointer}
.eco-card:hover{border-color:rgba(191,154,78,.25);background:rgba(255,255,255,.06);transform:translateY(-3px)}
.eco-card i{font-size:26px;color:var(--gold-l)}
.eco-card .val{font-family:'Noto Serif SC',serif;font-size:38px;font-weight:700;color:#fff;margin:12px 0 4px}
.eco-card .lbl{font-size:13px;color:rgba(255,255,255,.35)}
.eco-card .sts{display:inline-block;margin-top:10px;padding:3px 12px;background:rgba(78,125,94,.15);color:var(--jade-l);border-radius:100px;font-size:11px;letter-spacing:.08em}
.eco-chart-wrap{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-top:16px}
.eco-chart{width:100%;height:360px;min-height:300px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:8px;position:relative}
.eco-sidebar{display:flex;flex-direction:column;gap:12px}
.eco-trend{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:18px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.eco-trend-title{font-size:12px;color:rgba(255,255,255,.35);letter-spacing:.08em;margin-bottom:6px}
.eco-trend-val{font-family:'Noto Serif SC',serif;font-size:28px;font-weight:700;color:#fff}
.eco-trend-change{font-size:12px;margin-top:4px;display:flex;align-items:center;gap:4px}
.eco-trend-change.up{color:var(--jade-l)}
.eco-trend-change.down{color:var(--red)}
.eco-trend-bar{height:3px;background:rgba(255,255,255,.06);border-radius:2px;margin-top:10px;overflow:hidden}
.eco-trend-bar span{display:block;height:100%;border-radius:2px;transition:width 1.5s cubic-bezier(.16,1,.3,1)}
@media(max-width:900px){.eco-chart-wrap{grid-template-columns:1fr}.eco-sidebar{flex-direction:row;flex-wrap:wrap}.eco-trend{min-width:140px}}

/* ═══════════════════════════════════════
   REVIEWS — RANDOM FLOATING BUBBLES
   ═══════════════════════════════════════ */
.rev-sec{background:var(--paper);overflow:hidden}
.rev-pool{position:relative;height:480px;margin-top:20px}
.rev-pool::before,.rev-pool::after{content:'';position:absolute;left:0;right:0;height:80px;z-index:2;pointer-events:none}
.rev-pool::before{top:0;background:linear-gradient(to bottom,var(--paper),transparent)}
.rev-pool::after{bottom:0;background:linear-gradient(to top,var(--paper),transparent)}
.rev-bubble{position:absolute;width:300px;background:#fff;border:1px solid var(--paper-d);border-radius:var(--r);padding:22px 20px;opacity:0;pointer-events:none;will-change:transform,opacity;box-shadow:0 6px 28px rgba(13,12,9,.05);transition:box-shadow .3s}
.rev-bubble:hover{box-shadow:0 8px 36px rgba(13,12,9,.1)}
.rev-bubble .stars{color:var(--gold);font-size:11px;margin-bottom:10px;letter-spacing:2px}
.rev-bubble blockquote{font-size:12px;color:var(--ink-m);line-height:1.9;margin-bottom:14px;font-style:italic}
.rev-bubble .author{display:flex;align-items:center;gap:10px}
.rev-bubble .av{width:30px;height:30px;background:var(--gold-a2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-d);font-size:12px;font-weight:600}
.rev-bubble .nm{font-size:12px;color:var(--ink);font-weight:500}
.rev-bubble .dt{font-size:9px;color:var(--ink-s)}
@keyframes bubbleIn{
  0%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(.8) rotate(var(--tr))}
  12%{opacity:1;transform:translate(var(--tx),var(--ty)) scale(1) rotate(0deg)}
  78%{opacity:1;transform:translate(var(--tx),var(--ty)) scale(1) rotate(0deg)}
  100%{opacity:0;transform:translate(var(--tx),calc(var(--ty) - 50px)) scale(.9) rotate(calc(var(--tr) * -.5))}
}
.rev-stats{display:flex;justify-content:center;gap:56px;margin-top:52px;padding-top:36px;border-top:1px solid var(--paper-d)}
.rev-stat{text-align:center}
.rev-stat .num{font-family:'Noto Serif SC',serif;font-size:30px;font-weight:700;color:var(--ink)}
.rev-stat .lbl{font-size:12px;color:var(--ink-s);margin-top:4px;letter-spacing:.05em}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.foot{background:linear-gradient(180deg,#080706 0%,#0d0c09 100%);color:rgba(255,255,255,.45);padding:80px 6% 32px;position:relative}
.foot::before{content:'';position:absolute;top:0;left:6%;right:6%;height:1px;background:linear-gradient(90deg,transparent,rgba(191,154,78,.15),transparent)}
.foot-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px}
.foot-brand .logo-svg{margin-bottom:16px}
.foot-brand h4{color:#fff;font-size:20px;margin-bottom:16px}
.foot-brand p{font-size:13px;line-height:2;margin-bottom:8px}
.foot-col h4{font-size:12px;color:var(--gold-l);letter-spacing:.15em;margin-bottom:20px;font-family:'Noto Sans SC',sans-serif;font-weight:500}
.foot-col a,.foot-col p{display:block;font-size:13px;margin-bottom:10px;transition:var(--t);color:rgba(255,255,255,.4)}
.foot-col a:hover{color:var(--gold-l);transform:translateX(4px)}
.foot-col i{width:16px;margin-right:6px;text-align:center}
.foot-bottom{max-width:1200px;margin:44px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.05);text-align:center;font-size:12px;color:rgba(255,255,255,.2)}

/* ═══════════════════════════════════════
   FAB
   ═══════════════════════════════════════ */
.fab{position:fixed;bottom:28px;right:28px;z-index:999;width:54px;height:54px;background:linear-gradient(135deg,var(--gold-d),var(--gold));color:var(--paper);border:none;border-radius:50%;font-size:20px;cursor:pointer;box-shadow:0 4px 24px rgba(191,154,78,.4);transition:var(--t);display:flex;align-items:center;justify-content:center}
.fab:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(191,154,78,.55)}

/* ═══════════════════════════════════════
   MODALS — DARK IMMERSIVE
   ═══════════════════════════════════════ */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;padding:20px}
.modal-ov.active{opacity:1;visibility:visible}
.modal{background:var(--ink-l);border:1px solid rgba(255,255,255,.06);border-radius:10px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;transform:translateY(28px);transition:transform .5s cubic-bezier(.16,1,.3,1);position:relative;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}
.modal::-webkit-scrollbar{width:4px}
.modal::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}
.modal-ov.active .modal{transform:translateY(0)}
.modal-hd{padding:30px 36px 0;display:flex;align-items:center;justify-content:space-between}
.modal-hd h3{font-size:22px;color:#fff;letter-spacing:.06em}
.modal-x{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);font-size:16px;color:rgba(255,255,255,.35);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t)}
.modal-x:hover{background:rgba(196,70,58,.2);color:var(--red);border-color:rgba(196,70,58,.3)}
.modal-bd{padding:28px 36px 36px}
.modal-bd>p{color:rgba(255,255,255,.4);font-size:13px;margin-bottom:22px;line-height:1.7}
.modal-div{height:1px;background:rgba(255,255,255,.04);margin:0 36px}

/* Controls */
.cg{margin:18px 0}
.cl{display:flex;justify-content:space-between;font-size:13px;color:rgba(255,255,255,.65);margin-bottom:8px;font-weight:400}
.cl span:last-child{color:var(--gold-l);font-weight:600;font-family:'Noto Serif SC',serif;font-size:14px}
.sl{width:100%;height:3px;border-radius:2px;background:rgba(255,255,255,.06);outline:none;-webkit-appearance:none;transition:background .3s}
.sl:hover{background:rgba(255,255,255,.1)}
.sl::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--gold-d),var(--gold));cursor:pointer;box-shadow:0 0 14px rgba(191,154,78,.4);transition:transform .2s}
.sl::-webkit-slider-thumb:hover{transform:scale(1.25)}
.sl::-webkit-slider-thumb:active{transform:scale(1.15)}
.bg{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.bp{padding:9px 20px;font-size:12px;border:1px solid rgba(255,255,255,.08);background:transparent;color:rgba(255,255,255,.45);border-radius:var(--r);cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;letter-spacing:.04em}
.bp:hover{border-color:var(--gold);color:var(--gold-l);background:rgba(191,154,78,.06);transform:translateY(-1px)}
.bp.on{background:linear-gradient(135deg,var(--gold-d),var(--gold));border-color:transparent;color:var(--paper);font-weight:600}
.btn-gen{width:100%;padding:15px;background:linear-gradient(135deg,var(--gold-d),var(--gold),var(--gold-l));color:var(--paper);border:none;border-radius:var(--r);font-size:14px;font-weight:600;letter-spacing:.12em;cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;margin-top:28px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 20px rgba(191,154,78,.25)}
.btn-gen:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(191,154,78,.4)}
.btn-gen:active{transform:translateY(0)}
.res-box{margin-top:22px;padding:24px;background:rgba(255,255,255,.03);border:1px solid rgba(191,154,78,.15);border-radius:var(--r);display:none;position:relative;overflow:hidden}
.res-box::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold-d),var(--gold-l))}
.res-box h4{font-size:18px;margin-bottom:16px;color:#fff;font-family:'Noto Serif SC',serif}
.res-box p{font-size:13px;color:rgba(255,255,255,.5);line-height:2}
.res-box p strong{color:rgba(255,255,255,.8)}
.res-box .tip{margin-top:12px;color:var(--gold-l);font-size:12px}

/* ═══════════════════════════════════════
   BOOKING MANAGEMENT
   ═══════════════════════════════════════ */
.my-bookings-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}
.booking-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px;transition:var(--t)}
.booking-card:hover{border-color:var(--gold-a2)}
.booking-icon{width:44px;height:44px;background:var(--gold-a);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gold);flex-shrink:0}
.booking-info{flex:1;min-width:0}
.booking-info h4{font-size:14px;color:#fff;margin-bottom:4px}
.booking-info p{font-size:12px;color:rgba(255,255,255,.35);line-height:1.6}
.booking-info .booking-code{color:var(--gold-l);font-weight:600;font-size:11px;letter-spacing:.04em}
.booking-del{width:36px;height:36px;background:rgba(196,70,58,.08);border:1px solid rgba(196,70,58,.15);color:var(--red);border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:var(--t);flex-shrink:0}
.booking-del:hover{background:rgba(196,70,58,.2);border-color:var(--red)}
.booking-empty{text-align:center;padding:40px 20px;color:rgba(255,255,255,.25)}
.booking-empty i{font-size:40px;margin-bottom:12px;opacity:.3}
.booking-empty p{font-size:13px}

/* ═══════════════════════════════════════
   E-COMMERCE OPTIMIZATION
   ═══════════════════════════════════════ */
.prod-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:8px;overflow:hidden;transition:var(--t);cursor:pointer}
.prod-card:hover{border-color:var(--gold-a2);transform:translateY(-2px)}
.prod-card-img{height:160px;background:linear-gradient(135deg,rgba(191,154,78,.08),rgba(78,125,94,.08));display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--gold);position:relative}
.prod-card-img .prod-origin{position:absolute;top:10px;right:10px;padding:3px 10px;background:rgba(78,125,94,.9);color:#fff;font-size:10px;border-radius:100px;letter-spacing:.06em}
.prod-card-body{padding:16px}
.prod-card-body h4{font-size:15px;color:#fff;margin-bottom:4px}
.prod-card-body .prod-desc{font-size:12px;color:rgba(255,255,255,.35);margin-bottom:10px;line-height:1.6}
.prod-card-bottom{display:flex;align-items:center;justify-content:space-between}
.prod-card-bottom .pr{font-size:18px;color:var(--gold);font-weight:700;font-family:'Noto Serif SC',serif}
.prod-card-bottom .pr small{font-size:11px;color:rgba(255,255,255,.3);font-weight:400;font-family:'Noto Sans SC',sans-serif}
.prod-card-bottom .prod-buy{padding:8px 16px;background:linear-gradient(135deg,var(--gold-d),var(--gold-l));color:var(--paper);border:none;border-radius:var(--r);font-size:11px;font-weight:600;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:var(--t)}
.prod-card-bottom .prod-buy:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(191,154,78,.3)}

/* Trace timeline */
.trace-timeline{position:relative;padding-left:24px;margin:16px 0}
.trace-timeline::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;background:rgba(191,154,78,.15)}
.trace-step{position:relative;margin-bottom:16px;padding-left:16px}
.trace-step:last-child{margin-bottom:0}
.trace-step::before{content:'';position:absolute;left:-20px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--gold);border:2px solid var(--ink-l);z-index:1}
.trace-step.done::before{background:var(--jade)}
.trace-step h5{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:2px;font-family:'Noto Sans SC',sans-serif;font-weight:500}
.trace-step p{font-size:11px;color:rgba(255,255,255,.35)}
.trace-step .trace-time{font-size:10px;color:var(--gold-l);opacity:.6}

/* Cart badge */
.cart-badge{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--red);color:#fff;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'Noto Sans SC',sans-serif}

/* Product detail overlay */
.prod-detail-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(12px);z-index:2100;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;padding:20px}
.prod-detail-ov.active{opacity:1;visibility:visible}
.prod-detail{background:var(--ink-l);border:1px solid rgba(255,255,255,.08);border-radius:12px;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;transform:translateY(24px);transition:transform .5s cubic-bezier(.16,1,.3,1)}
.prod-detail-ov.active .prod-detail{transform:translateY(0)}
.prod-detail-hd{padding:20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between}
.prod-detail-hd h3{font-size:18px;color:#fff}
.prod-detail-close{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);cursor:pointer;font-size:14px;transition:var(--t)}
.prod-detail-close:hover{background:rgba(255,255,255,.12);color:#fff}
.prod-detail-body{padding:20px}
.prod-detail-img{height:200px;background:linear-gradient(135deg,rgba(191,154,78,.1),rgba(78,125,94,.1));display:flex;align-items:center;justify-content:center;font-size:64px;color:var(--gold);border-radius:8px;margin-bottom:20px}
.prod-detail-body h4{font-size:16px;color:#fff;margin-bottom:8px}
.prod-detail-body .prod-detail-desc{font-size:13px;color:rgba(255,255,255,.4);line-height:1.8;margin-bottom:16px}
.prod-detail-price{font-size:24px;color:var(--gold);font-weight:700;font-family:'Noto Serif SC',serif;margin-bottom:16px}
.prod-detail-price small{font-size:13px;color:rgba(255,255,255,.3);font-weight:400;font-family:'Noto Sans SC',sans-serif}
.prod-detail-actions{display:flex;gap:10px;margin-top:20px}

/* ═══════════════════════════════════════
   SHOPPING CART
   ═══════════════════════════════════════ */
.cart-fab{position:fixed;bottom:28px;left:28px;z-index:997;width:48px;height:48px;background:var(--ink);color:var(--gold-l);border:1px solid rgba(191,154,78,.3);border-radius:50%;font-size:18px;cursor:pointer;box-shadow:0 4px 24px rgba(0,0,0,.25);transition:var(--t);display:none;align-items:center;justify-content:center}
.cart-fab:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(0,0,0,.35);border-color:var(--gold)}
.cart-fab .cart-count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;background:var(--red);color:#fff;border-radius:100px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'Noto Sans SC',sans-serif;padding:0 5px}
.cart-panel{position:fixed;bottom:88px;left:28px;z-index:997;width:340px;max-height:420px;background:var(--ink-l);border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.4);display:none;flex-direction:column;overflow:hidden;transform:translateY(10px);opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1)}
.cart-panel.open{display:flex;transform:translateY(0);opacity:1}
.cart-panel-hd{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.cart-panel-hd h4{font-size:14px;color:#fff;display:flex;align-items:center;gap:8px}
.cart-panel-hd h4 .cart-total-count{font-size:11px;color:var(--gold-l);font-weight:400}
.cart-clear{font-size:11px;color:rgba(255,255,255,.25);cursor:pointer;background:none;border:none;font-family:'Noto Sans SC',sans-serif;transition:var(--t)}
.cart-clear:hover{color:var(--red)}
.cart-list{flex:1;overflow-y:auto;padding:8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}
.cart-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r);transition:var(--t)}
.cart-item:hover{background:rgba(255,255,255,.02)}
.cart-item-icon{width:40px;height:40px;background:var(--gold-a);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--gold);flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-info h5{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:2px;font-family:'Noto Sans SC',sans-serif;font-weight:500}
.cart-item-info .cart-item-price{font-size:12px;color:var(--gold-l);font-weight:600}
.cart-item-qty{display:flex;align-items:center;gap:6px;flex-shrink:0}
.cart-item-qty button{width:22px;height:22px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);border-radius:50%;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.cart-item-qty button:hover{background:var(--gold-a2);border-color:var(--gold);color:var(--gold)}
.cart-item-qty span{font-size:13px;color:#fff;min-width:16px;text-align:center;font-weight:500}
.cart-item-del{width:22px;height:22px;background:none;border:none;color:rgba(255,255,255,.15);cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t);flex-shrink:0}
.cart-item-del:hover{color:var(--red);background:rgba(196,70,58,.1)}
.cart-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.cart-footer .cart-total{font-size:13px;color:rgba(255,255,255,.5)}
.cart-footer .cart-total strong{font-size:18px;color:var(--gold);font-family:'Noto Serif SC',serif;font-weight:700}
.cart-footer .cart-checkout{padding:10px 20px;background:linear-gradient(135deg,var(--gold-d),var(--gold-l));color:var(--paper);border:none;border-radius:var(--r);font-size:12px;font-weight:600;letter-spacing:.08em;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:var(--t)}
.cart-footer .cart-checkout:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(191,154,78,.3)}
.cart-empty{text-align:center;padding:30px 16px;color:rgba(255,255,255,.2)}
.cart-empty i{font-size:32px;margin-bottom:10px;opacity:.3}
.cart-empty p{font-size:12px}
.cart-toast{position:fixed;bottom:88px;left:50%;transform:translateX(-50%) translateY(10px);background:rgba(26,26,26,.95);border:1px solid rgba(78,125,94,.3);border-radius:8px;padding:10px 20px;color:#fff;font-size:13px;z-index:3000;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.cart-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.cart-toast i{color:var(--jade-l)}

/* ═══════════════════════════════════════
   ROUTE MAP MODAL
   ═══════════════════════════════════════ */
.route-fab{position:fixed;bottom:88px;right:28px;z-index:997;width:48px;height:48px;background:linear-gradient(135deg,var(--jade),var(--jade-l));color:#fff;border:none;border-radius:50%;font-size:18px;cursor:pointer;box-shadow:0 4px 20px rgba(78,125,94,.35);transition:var(--t);display:none;align-items:center;justify-content:center}
.route-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(78,125,94,.5)}
.route-fab .badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:var(--gold);color:var(--paper);border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'Noto Sans SC',sans-serif}
.route-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:2600;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;padding:20px}
.route-ov.active{opacity:1;visibility:visible}
.route-modal{background:var(--ink-l);border:1px solid rgba(255,255,255,.08);border-radius:12px;width:100%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;transform:translateY(24px);transition:transform .5s cubic-bezier(.16,1,.3,1);box-shadow:0 12px 40px rgba(0,0,0,.5);overflow:hidden}
.route-ov.active .route-modal{transform:translateY(0)}
.route-hd{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:linear-gradient(135deg,rgba(78,125,94,.08),transparent)}
.route-hd-left{display:flex;align-items:center;gap:14px}
.route-hd-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--jade),var(--jade-l));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;flex-shrink:0}
.route-hd-text h3{font-size:18px;color:#fff;margin-bottom:2px;letter-spacing:.04em}
.route-hd-text p{font-size:12px;color:rgba(255,255,255,.35)}
.route-close{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:16px;color:rgba(255,255,255,.4);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t)}
.route-close:hover{background:rgba(255,255,255,.12);color:#fff}
.route-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}
.route-map-wrap{flex:1;min-height:360px;position:relative;background:rgba(255,255,255,.02)}
.route-map{width:100%;height:100%;min-height:360px}
.route-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:rgba(255,255,255,.3);text-align:center}
.route-empty i{font-size:48px;margin-bottom:16px;opacity:.3}
.route-empty h4{font-size:16px;color:rgba(255,255,255,.5);margin-bottom:8px}
.route-empty p{font-size:13px;line-height:1.8}
.route-empty .route-go-btn{margin-top:20px;padding:10px 24px;background:var(--gold);color:var(--paper);border:none;border-radius:var(--r);font-size:12px;font-weight:600;letter-spacing:.1em;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:var(--t)}
.route-empty .route-go-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(191,154,78,.3)}
.route-info{padding:20px 24px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;background:rgba(255,255,255,.01)}
.route-info-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.route-info-head h4{font-size:15px;color:#fff}
.route-info-head .route-badge{padding:3px 10px;background:rgba(78,125,94,.15);color:var(--jade-l);border-radius:100px;font-size:11px;letter-spacing:.06em}
.route-themes{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.route-theme-tag{display:flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:100px;font-size:12px;color:rgba(255,255,255,.5);cursor:pointer;transition:var(--t)}
.route-theme-tag.active{background:var(--gold-a2);border-color:var(--gold);color:var(--gold-l)}
.route-theme-tag i{font-size:12px}
.route-stops{display:flex;flex-wrap:wrap;gap:0;align-items:center}
.route-stop{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.6)}
.route-stop .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.route-stop .dot.t1{background:var(--gold)}
.route-stop .dot.t2{background:#12b7f5}
.route-stop .dot.t3{background:var(--jade)}
.route-stop .dot.base{background:rgba(255,255,255,.3)}
.route-arrow{color:rgba(255,255,255,.15);margin:0 6px;font-size:10px}
.route-edit-bar{display:flex;gap:8px;margin-bottom:12px}
.route-edit-btn{padding:6px 14px;font-size:11px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);border-radius:100px;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:var(--t);display:inline-flex;align-items:center;gap:5px}
.route-edit-btn:hover{background:rgba(191,154,78,.1);border-color:var(--gold);color:var(--gold-l)}
.route-edit-btn.save{background:rgba(78,125,94,.15);border-color:rgba(78,125,94,.3);color:var(--jade-l)}
.route-edit-btn.save:hover{background:rgba(78,125,94,.25)}
.route-add-panel{margin-bottom:12px;padding:12px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:var(--r)}
.add-poi-list{display:flex;flex-wrap:wrap;gap:6px}
.add-poi-item{padding:5px 12px;font-size:11px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.5);border-radius:100px;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:var(--t);display:inline-flex;align-items:center;gap:5px}
.add-poi-item:hover{background:var(--gold-a2);border-color:var(--gold);color:var(--gold-l)}
.add-poi-item .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.add-poi-item .dot.t1{background:var(--gold)}
.add-poi-item .dot.t2{background:#12b7f5}
.add-poi-item .dot.t3{background:var(--jade)}
.add-poi-item .dot.base{background:rgba(255,255,255,.3)}
.add-poi-empty{font-size:12px;color:rgba(255,255,255,.2);text-align:center;padding:8px}
.route-stop.editable{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:4px 8px;display:inline-flex;align-items:center;gap:4px}
.route-stop.editable .stop-name{font-size:11px}
.stop-del,.stop-up,.stop-down{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:rgba(255,255,255,.25);cursor:pointer;font-size:9px;border-radius:50%;transition:var(--t)}
.stop-del:hover{color:var(--red);background:rgba(196,70,58,.1)}
.stop-up:hover,.stop-down:hover{color:var(--gold);background:var(--gold-a)}

/* Section label inside modals */
.modal-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-l);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.modal-label::after{content:'';flex:1;height:1px;background:rgba(191,154,78,.1)}

/* Calendar */
.cal-g{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin:14px 0}
.cal-h{text-align:center;font-size:11px;color:var(--gold);font-weight:600;padding:6px 0;letter-spacing:.1em}
.cal-d{text-align:center;padding:10px 0;font-size:12px;border-radius:4px;background:rgba(255,255,255,.04);cursor:pointer;transition:var(--t);color:rgba(255,255,255,.6)}
.cal-d:hover{background:rgba(191,154,78,.1);color:var(--gold)}
.cal-d.sel{background:var(--gold);color:var(--ink);font-weight:600}
.cal-d.off{opacity:.15;cursor:not-allowed}
.cal-d.we{color:var(--red)}

/* Booking result */
.book-res{margin-top:22px;padding:24px;background:rgba(255,255,255,.03);border:1px solid rgba(78,125,94,.15);border-radius:var(--r);display:none;position:relative;overflow:hidden}
.book-res::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--jade),var(--jade-l))}
.book-res h4{margin-bottom:12px;font-size:18px;color:#fff;font-family:'Noto Serif SC',serif}
.book-res p{font-size:13px;color:rgba(255,255,255,.5);line-height:2}
.book-res strong{color:rgba(255,255,255,.8)}

/* Product */
.prod-g{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.prod-it{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:24px 16px;text-align:center;transition:var(--t)}
.prod-it:hover{border-color:rgba(191,154,78,.2);background:rgba(255,255,255,.06)}
.prod-it i{font-size:32px;color:var(--gold);margin-bottom:10px}
.prod-it h4{font-size:15px;margin-bottom:4px;color:#fff}
.prod-it p{font-size:12px;color:rgba(255,255,255,.35)}
.prod-it .pr{color:var(--gold);font-weight:600;margin-top:8px;font-size:15px;font-family:'Noto Serif SC',serif}
.trace{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:20px;margin-bottom:24px}
.trace h4{font-size:14px;margin-bottom:14px;color:#fff;display:flex;align-items:center;gap:6px}
.trace h4 i{color:var(--gold)}
.tr-row{display:flex;justify-content:space-between;padding:8px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,.04)}
.tr-row:last-child{border:none}
.tr-row span:first-child{color:rgba(255,255,255,.35)}
.tr-row span:last-child{color:rgba(255,255,255,.75);font-weight:500}
.tr-row .ok{color:var(--jade-l)}
.btn-r{display:flex;gap:10px}
.btn-c,.btn-b{flex:1;padding:12px;border:none;border-radius:var(--r);font-size:12px;cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;letter-spacing:.08em;display:flex;align-items:center;justify-content:center;gap:6px;font-weight:500}
.btn-c{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.1)}
.btn-c:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)}
.btn-b{background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--ink);border:1px solid transparent}
.btn-b:hover{box-shadow:0 4px 16px rgba(191,154,78,.3)}

/* Login modal */
.login-modal .modal{max-width:440px}
.login-tabs{display:flex;gap:0;margin:0 32px 24px;background:rgba(255,255,255,.04);border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.login-tab{flex:1;padding:12px;text-align:center;font-size:13px;color:rgba(255,255,255,.4);cursor:pointer;transition:var(--t);letter-spacing:.08em;font-family:'Noto Sans SC',sans-serif;border:none;background:transparent}
.login-tab.on{color:var(--gold);background:rgba(191,154,78,.1);font-weight:500}
.login-tab:hover:not(.on){color:rgba(255,255,255,.7)}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:12px;color:rgba(255,255,255,.5);margin-bottom:8px;letter-spacing:.06em}
.login-input{width:100%;padding:13px 16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);color:#fff;font-size:14px;font-family:'Noto Sans SC',sans-serif;transition:border-color .3s,box-shadow .3s;outline:none}
.login-input::placeholder{color:rgba(255,255,255,.2)}
.login-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(191,154,78,.08)}
.login-input-wrap{position:relative}
.login-input-wrap .toggle-pw{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,.25);cursor:pointer;font-size:14px;transition:color .3s}
.login-input-wrap .toggle-pw:hover{color:var(--gold)}
.login-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.login-row label{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.4);cursor:pointer}
.login-row label input{accent-color:var(--gold)}
.login-row a{font-size:12px;color:var(--gold);opacity:.7;transition:opacity .3s}
.login-row a:hover{opacity:1}
.login-submit{width:100%;padding:15px;background:linear-gradient(135deg,var(--gold-d),var(--gold),var(--gold-l));color:var(--paper);border:none;border-radius:var(--r);font-size:14px;font-weight:600;letter-spacing:.12em;cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(191,154,78,.2)}
.login-submit:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(191,154,78,.35)}
.login-submit:active{transform:translateY(0)}
.login-submit.loading{pointer-events:none;color:transparent}
.login-submit.loading::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold),var(--gold-l));display:flex;align-items:center;justify-content:center}
.login-submit .spinner{display:none;position:absolute;left:50%;top:50%;width:18px;height:18px;margin:-9px 0 0 -9px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--ink);border-radius:50%;animation:spin .6s linear infinite}
.login-submit.loading .spinner{display:block}
@keyframes spin{to{transform:rotate(360deg)}}
.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.06)}
.login-divider span{font-size:11px;color:rgba(255,255,255,.25);letter-spacing:.15em}
.login-social{display:flex;gap:10px}
.login-social-btn{flex:1;padding:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);cursor:pointer;transition:var(--t);display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;color:rgba(255,255,255,.5);font-family:'Noto Sans SC',sans-serif}
.login-social-btn:hover{border-color:rgba(191,154,78,.3);background:rgba(191,154,78,.06);color:rgba(255,255,255,.8)}
.login-social-btn i{font-size:16px}
.login-social-btn.wx{color:#07c160}
.login-social-btn.wx:hover{border-color:rgba(7,193,96,.3);background:rgba(7,193,96,.06)}
.login-footer{margin-top:20px;text-align:center;font-size:12px;color:rgba(255,255,255,.25)}
.login-footer a{color:var(--gold);opacity:.7}
.login-footer a:hover{opacity:1}

/* Login success feedback */
.login-success{position:absolute;inset:0;background:rgba(26,26,26,.97);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s;border-radius:8px;z-index:10}
.login-success.show{opacity:1;pointer-events:auto}
.login-success .check{width:56px;height:56px;border-radius:50%;background:rgba(78,125,94,.15);border:2px solid var(--jade);display:flex;align-items:center;justify-content:center;margin-bottom:16px;animation:popIn .5s cubic-bezier(.16,1,.3,1)}
.login-success .check i{color:var(--jade-l);font-size:24px}
.login-success p{color:rgba(255,255,255,.6);font-size:14px}
.login-success p strong{color:#fff}
@keyframes popIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}

/* User dropdown */
.user-menu{position:absolute;top:100%;right:0;margin-top:8px;background:var(--ink-l);border:1px solid rgba(255,255,255,.08);border-radius:8px;min-width:200px;box-shadow:0 12px 40px rgba(0,0,0,.3);opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .3s cubic-bezier(.16,1,.3,1);z-index:100;overflow:hidden}
.user-menu.open{opacity:1;visibility:visible;transform:translateY(0)}
.user-menu-hd{padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px}
.user-menu-hd .av{width:36px;height:36px;background:linear-gradient(135deg,var(--gold),var(--gold-l));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif SC',serif;font-size:15px;font-weight:700;color:var(--ink)}
.user-menu-hd .info .name{font-size:14px;color:#fff;font-weight:500}
.user-menu-hd .info .email{font-size:11px;color:rgba(255,255,255,.35);margin-top:2px}
.user-menu-items{padding:6px}
.user-menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;color:rgba(255,255,255,.55);cursor:pointer;transition:var(--t);border-radius:var(--r);border:none;background:transparent;width:100%;font-family:'Noto Sans SC',sans-serif;text-align:left}
.user-menu-item:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.9)}
.user-menu-item i{width:16px;text-align:center;font-size:13px;opacity:.6}
.user-menu-item.danger{color:var(--red)}
.user-menu-item.danger:hover{background:rgba(196,70,58,.08)}
.user-menu-item.danger i{opacity:1}
.user-menu-div{height:1px;background:rgba(255,255,255,.06);margin:4px 14px}
.nav-right{position:relative}

/* ═══════════════════════════════════════
   VIP MEMBERSHIP MODAL
   ═══════════════════════════════════════ */
.vip-modal{padding:0!important}
.vip-modal .modal{max-width:820px;max-height:92vh;display:flex;flex-direction:column}
.vip-modal .vip-hero{flex-shrink:0}
.vip-modal .vip-tabs{flex-shrink:0}
.vip-modal .vip-body{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}
.vip-modal .vip-footer{flex-shrink:0}

/* VIP hero header */
.vip-hero{background:linear-gradient(160deg,#100e08 0%,#1e1810 50%,#14181a 100%);padding:44px 44px 36px;position:relative;overflow:hidden}
.vip-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(191,154,78,.12) 0%,transparent 60%)}
.vip-hero::after{content:'';position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle at 25% 25%,var(--gold) 1px,transparent 1px),radial-gradient(circle at 75% 75%,var(--gold) .5px,transparent .5px);background-size:40px 40px,28px 28px}
.vip-hero-inner{position:relative;z-index:1;display:flex;align-items:center;gap:24px}
.vip-hero-icon{width:68px;height:68px;background:linear-gradient(135deg,var(--gold-d),var(--gold-l));border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--paper);flex-shrink:0;box-shadow:0 6px 24px rgba(191,154,78,.35)}
.vip-hero-text h3{font-size:24px;color:#fff;margin-bottom:6px;letter-spacing:.06em}
.vip-hero-text p{font-size:13px;color:rgba(255,255,255,.4);line-height:1.8}
.vip-close{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:16px;color:rgba(255,255,255,.4);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t);z-index:2}
.vip-close:hover{background:rgba(255,255,255,.12);color:#fff}

/* Tab switch */
.vip-tabs{display:flex;background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.04)}
.vip-tab{flex:1;padding:15px;text-align:center;font-size:13px;color:rgba(255,255,255,.3);cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;border:none;background:transparent;letter-spacing:.06em;position:relative}
.vip-tab.on{color:var(--gold-l);background:rgba(191,154,78,.06)}
.vip-tab.on::after{content:'';position:absolute;bottom:0;left:20%;right:20%;height:2px;background:linear-gradient(90deg,var(--gold-d),var(--gold-l));border-radius:1px}
.vip-tab:hover:not(.on){color:rgba(255,255,255,.55)}

/* Pricing cards */
.vip-body{padding:32px 32px 36px}
.vip-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:36px}
.vip-plan{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:30px 22px;text-align:center;transition:transform .4s,box-shadow .4s,border-color .3s;cursor:pointer;position:relative;overflow:hidden}
.vip-plan:hover{border-color:rgba(191,154,78,.25);transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.25)}
.vip-plan.popular{border-color:rgba(191,154,78,.35);background:rgba(191,154,78,.05)}
.vip-plan.popular::before{content:'推荐';position:absolute;top:13px;right:-28px;background:linear-gradient(135deg,var(--gold-d),var(--gold));color:var(--paper);font-size:10px;padding:3px 32px;transform:rotate(45deg);font-weight:600;letter-spacing:.08em}
.vip-plan-icon{width:50px;height:50px;margin:0 auto 18px;background:rgba(191,154,78,.1);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--gold-l)}
.vip-plan.popular .vip-plan-icon{background:linear-gradient(135deg,rgba(191,154,78,.18),rgba(191,154,78,.06))}
.vip-plan h4{font-size:16px;color:#fff;margin-bottom:4px;letter-spacing:.04em}
.vip-plan .sub{font-size:11px;color:rgba(255,255,255,.25);margin-bottom:18px}
.vip-plan .price{margin-bottom:22px}
.vip-plan .price .sym{font-size:16px;color:var(--gold-l);vertical-align:top;line-height:2.2}
.vip-plan .price .num{font-family:'Noto Serif SC',serif;font-size:42px;font-weight:900;color:#fff;line-height:1}
.vip-plan .price .unit{font-size:12px;color:rgba(255,255,255,.25);margin-left:2px}
.vip-plan .price .orig{font-size:12px;color:rgba(255,255,255,.18);text-decoration:line-through;margin-top:4px;display:block}
.vip-plan-btn{width:100%;padding:12px;border-radius:var(--r);font-size:13px;cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;letter-spacing:.1em;font-weight:500}
.vip-plan-btn.out{background:transparent;border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.45)}
.vip-plan-btn.out:hover{border-color:var(--gold);color:var(--gold-l);transform:translateY(-1px)}
.vip-plan-btn.fill{background:linear-gradient(135deg,var(--gold-d),var(--gold),var(--gold-l));border:1px solid transparent;color:var(--paper);box-shadow:0 4px 18px rgba(191,154,78,.25)}
.vip-plan-btn.fill:hover{box-shadow:0 8px 28px rgba(191,154,78,.4);transform:translateY(-2px)}

/* Benefits section */
.vip-section-title{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-l);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.vip-section-title::after{content:'';flex:1;height:1px;background:rgba(191,154,78,.08)}
.vip-benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:28px}
.vip-benefit{display:flex;align-items:flex-start;gap:12px;padding:14px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);border-radius:var(--r);transition:var(--t)}
.vip-benefit:hover{border-color:rgba(191,154,78,.12);background:rgba(191,154,78,.02)}
.vip-benefit .ic{width:32px;height:32px;background:rgba(191,154,78,.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:13px;flex-shrink:0}
.vip-benefit h5{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:2px;font-family:'Noto Sans SC',sans-serif;font-weight:500}
.vip-benefit p{font-size:11px;color:rgba(255,255,255,.3);line-height:1.6}

/* Comparison table */
.vip-compare{width:100%;border-collapse:collapse;margin-bottom:8px}
.vip-compare th{font-size:11px;color:rgba(255,255,255,.25);font-weight:400;padding:10px 8px;text-align:center;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.04)}
.vip-compare th:first-child{text-align:left}
.vip-compare td{font-size:12px;color:rgba(255,255,255,.5);padding:10px 8px;text-align:center;border-bottom:1px solid rgba(255,255,255,.02)}
.vip-compare td:first-child{text-align:left;color:rgba(255,255,255,.35)}
.vip-compare tr:hover td{background:rgba(255,255,255,.02)}
.vip-compare .chk{color:var(--jade-l);font-size:13px}
.vip-compare .x{color:rgba(255,255,255,.1);font-size:11px}
.vip-compare .vip-col{background:rgba(191,154,78,.04)}

/* Footer */
.vip-footer{text-align:center;padding:0 32px 28px}
.vip-footer p{font-size:11px;color:rgba(255,255,255,.18);line-height:1.8}
.vip-footer a{color:var(--gold-l);opacity:.4}
.vip-footer a:hover{opacity:.8}

/* Success overlay */
/* ═══════════════════════════════════════
   GROWTH SYSTEM
   ═══════════════════════════════════════ */

/* Growth card — hero banner */
.growth-card{background:linear-gradient(135deg,#100e08 0%,#1e1810 50%,#14181a 100%);border-radius:10px;padding:28px 24px;position:relative;overflow:hidden;margin-bottom:24px}
.growth-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(191,154,78,.1) 0%,transparent 60%)}
.growth-card::after{content:'';position:absolute;inset:0;opacity:.05;background-image:radial-gradient(circle at 25% 25%,var(--gold) 1px,transparent 1px),radial-gradient(circle at 75% 75%,var(--gold) .5px,transparent .5px);background-size:40px 40px,28px 28px}
.growth-card-inner{position:relative;z-index:1}
.growth-top{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.growth-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-l));display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--ink);flex-shrink:0;position:relative}
.growth-avatar .lv-badge{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:50%;background:var(--ink-l);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--gold);font-weight:700}
.growth-user-info{flex:1}
.growth-user-name{font-size:16px;color:#fff;font-weight:600;margin-bottom:2px}
.growth-user-level{font-size:12px;color:var(--gold);letter-spacing:.08em;display:flex;align-items:center;gap:6px}
.growth-user-level i{font-size:10px}
.growth-pts{font-size:11px;color:rgba(255,255,255,.35);margin-top:2px}
.growth-pts span{color:var(--gold);font-weight:600;font-family:'Noto Serif SC',serif;font-size:13px}
.growth-checkin-btn{padding:8px 20px;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--ink);border:none;border-radius:var(--r);font-size:12px;font-weight:600;letter-spacing:.08em;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:var(--t);display:inline-flex;align-items:center;gap:6px}
.growth-checkin-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(191,154,78,.3)}
.growth-checkin-btn.done{background:rgba(78,125,94,.2);color:var(--jade-l);border:1px solid rgba(78,125,94,.3);box-shadow:none;pointer-events:none}

/* Progress bar */
.growth-progress{margin-top:4px}
.growth-progress-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden;position:relative}
.growth-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--gold-l));transition:width 1s cubic-bezier(.16,1,.3,1);position:relative}
.growth-progress-fill::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s ease-in-out infinite}
.growth-progress-labels{display:flex;justify-content:space-between;margin-top:6px;font-size:10px;color:rgba(255,255,255,.25)}
.growth-progress-labels .cur{color:var(--gold)}

/* Level milestones */
.growth-milestones{display:flex;justify-content:space-between;align-items:flex-start;margin-top:12px;position:relative}
.growth-milestones::before{content:'';position:absolute;top:10px;left:10px;right:10px;height:2px;background:rgba(255,255,255,.06)}
.growth-ms{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:1;flex:1}
.growth-ms-dot{width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.06);border:2px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:8px;color:rgba(255,255,255,.3);transition:var(--t)}
.growth-ms.active .growth-ms-dot{background:var(--gold);border-color:var(--gold);color:var(--paper);box-shadow:0 0 12px rgba(191,154,78,.4)}
.growth-ms.done .growth-ms-dot{background:rgba(78,125,94,.2);border-color:var(--jade);color:var(--jade-l)}
.growth-ms-name{font-size:9px;color:rgba(255,255,255,.25);text-align:center;white-space:nowrap}
.growth-ms.active .growth-ms-name{color:var(--gold);font-weight:600}
.growth-ms.done .growth-ms-name{color:var(--jade-l)}

/* Tasks section */
.growth-tasks{margin-bottom:24px}
.growth-task-list{display:flex;flex-direction:column;gap:8px}
.growth-task{display:flex;align-items:center;gap:12px;padding:14px 16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:var(--r);transition:var(--t);cursor:pointer}
.growth-task:hover{border-color:rgba(191,154,78,.15);background:rgba(191,154,78,.02)}
.growth-task.done{opacity:.5;pointer-events:none}
.growth-task-icon{width:36px;height:36px;border-radius:8px;background:rgba(191,154,78,.08);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:14px;flex-shrink:0}
.growth-task.done .growth-task-icon{background:rgba(78,125,94,.1);color:var(--jade-l)}
.growth-task-info{flex:1}
.growth-task-name{font-size:13px;color:rgba(255,255,255,.8);font-weight:500;margin-bottom:2px}
.growth-task-desc{font-size:11px;color:rgba(255,255,255,.3)}
.growth-task-pts{font-size:12px;color:var(--gold);font-weight:600;white-space:nowrap;font-family:'Noto Serif SC',serif}
.growth-task.done .growth-task-pts{color:var(--jade-l);font-size:11px}
.growth-task-check{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;flex-shrink:0;transition:var(--t)}
.growth-task.done .growth-task-check{background:var(--jade);border-color:var(--jade);color:#fff}

/* Level benefits grid */
.growth-levels{display:flex;flex-direction:column;gap:12px}
.growth-level{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:8px;overflow:hidden;transition:var(--t)}
.growth-level.current{border-color:rgba(191,154,78,.3);background:rgba(191,154,78,.03)}
.growth-level-hd{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer;transition:var(--t)}
.growth-level-hd:hover{background:rgba(255,255,255,.02)}
.growth-level-icon{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.04);border:2px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:var(--t)}
.growth-level.current .growth-level-icon{background:linear-gradient(135deg,var(--gold-d),var(--gold-l));border-color:var(--gold);color:var(--paper);box-shadow:0 0 16px rgba(191,154,78,.3)}
.growth-level.done .growth-level-icon{background:rgba(78,125,94,.1);border-color:var(--jade);color:var(--jade-l)}
.growth-level-meta{flex:1}
.growth-level-name{font-size:14px;color:rgba(255,255,255,.8);font-weight:600;margin-bottom:2px;display:flex;align-items:center;gap:8px}
.growth-level-name .tag{font-size:9px;padding:2px 8px;border-radius:100px;background:var(--gold-a);color:var(--gold);font-weight:500;letter-spacing:.06em}
.growth-level-req{font-size:11px;color:rgba(255,255,255,.25)}
.growth-level-req span{color:var(--gold)}
.growth-level-arrow{font-size:12px;color:rgba(255,255,255,.15);transition:var(--t)}
.growth-level.open .growth-level-arrow{transform:rotate(180deg)}
.growth-level-bd{padding:0 18px 18px;display:none}
.growth-level.open .growth-level-bd{display:block}
.growth-level-perks{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.growth-perk{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(255,255,255,.02);border-radius:var(--r);font-size:11px;color:rgba(255,255,255,.5)}
.growth-perk i{color:var(--gold);font-size:11px;width:14px;text-align:center}
.growth-perk.locked{opacity:.35}
.growth-perk.locked i{color:rgba(255,255,255,.2)}

/* History */
.growth-history{margin-top:24px}
.growth-history-list{display:flex;flex-direction:column;gap:6px}
.growth-hist-item{display:flex;align-items:center;gap:12px;padding:10px 14px;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03)}
.growth-hist-item:last-child{border:none}
.growth-hist-icon{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--gold);flex-shrink:0}
.growth-hist-icon.out{color:var(--red);background:rgba(196,70,58,.06)}
.growth-hist-info{flex:1;color:rgba(255,255,255,.5)}
.growth-hist-pts{font-family:'Noto Serif SC',serif;font-weight:600;white-space:nowrap}
.growth-hist-pts.plus{color:var(--jade-l)}
.growth-hist-pts.minus{color:var(--red)}
.growth-hist-time{font-size:10px;color:rgba(255,255,255,.15);white-space:nowrap}

/* ═══════════════════════════════════════
   MAIN PAGE CUSTOMER SERVICE
   ═══════════════════════════════════════ */
.main-cs-btn{position:fixed;bottom:90px;right:28px;z-index:998;width:48px;height:48px;background:var(--ink);color:var(--gold-l);border:1px solid rgba(191,154,78,.3);border-radius:50%;font-size:18px;cursor:pointer;box-shadow:0 4px 24px rgba(0,0,0,.25);transition:var(--t);display:flex;align-items:center;justify-content:center}
.main-cs-btn:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(0,0,0,.35);background:var(--ink-l);border-color:var(--gold)}
.main-cs-dot{position:absolute;top:8px;right:8px;width:10px;height:10px;background:var(--jade);border:2px solid var(--paper);border-radius:50%;animation:blink 2s infinite}

.main-cs-panel{position:fixed;bottom:0;right:28px;z-index:1001;background:var(--paper);border:1px solid var(--paper-d);border-bottom:none;border-radius:12px 12px 0 0;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);width:380px;max-height:520px;display:flex;flex-direction:column;box-shadow:0 -8px 40px rgba(0,0,0,.12)}
.main-cs-panel.open{transform:translateY(0)}

.main-cs-hd{padding:16px 18px;border-bottom:1px solid var(--paper-d);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:#fff;border-radius:12px 12px 0 0;position:relative;overflow:visible}
.main-cs-hd-left{display:flex;align-items:center;gap:12px}
.main-cs-avatar{width:38px;height:38px;background:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--gold);flex-shrink:0}
.main-cs-info .name{font-size:14px;color:var(--ink);font-weight:600}
.main-cs-info .status{font-size:11px;color:var(--jade);display:flex;align-items:center;gap:5px;margin-top:2px}
.main-cs-info .status .dot{width:6px;height:6px;background:var(--jade);border-radius:50%;animation:blink 2s infinite}
.main-cs-close{background:var(--paper);border:1px solid var(--paper-d);font-size:18px;color:var(--ink-m);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t);position:relative;z-index:10;pointer-events:auto}
.main-cs-close:hover{background:var(--red);color:#fff;border-color:var(--red)}

.main-cs-body{flex:1;overflow-y:auto;padding:16px 18px;scrollbar-width:thin;scrollbar-color:var(--paper-d) transparent;background:var(--paper)}
.main-cs-body::-webkit-scrollbar{width:3px}
.main-cs-body::-webkit-scrollbar-thumb{background:var(--paper-d);border-radius:2px}
.main-cs-body .cs-msg.agent .cs-msg-bubble{background:#fff;border:1px solid var(--paper-d);color:var(--ink-m)}
.main-cs-body .cs-msg.user .cs-msg-bubble{background:var(--ink);color:var(--paper)}
.main-cs-body .cs-msg-time{color:var(--ink-s)}
.main-cs-body .cs-quick-btn{background:var(--gold-a);border-color:rgba(191,154,78,.2);color:var(--gold)}
.main-cs-body .cs-quick-btn:hover{background:rgba(191,154,78,.2);border-color:var(--gold)}
.main-cs-body .cs-contact{background:#fff;border-color:var(--paper-d)}
.main-cs-body .cs-contact:hover{border-color:var(--gold);background:var(--gold-a)}
.main-cs-body .cs-contact-info .label{color:var(--ink-s)}
.main-cs-body .cs-contact-info .value{color:var(--ink)}

.main-cs-input{padding:12px 16px;border-top:1px solid var(--paper-d);display:flex;gap:10px;align-items:center;flex-shrink:0;background:#fff;border-radius:0 0 12px 12px}
.main-cs-input input{flex:1;background:var(--paper);border:1px solid var(--paper-d);border-radius:100px;padding:10px 16px;color:var(--ink);font-size:13px;font-family:'Noto Sans SC',sans-serif;outline:none;transition:border-color .3s}
.main-cs-input input::placeholder{color:var(--ink-s)}
.main-cs-input input:focus{border-color:var(--gold)}
.main-cs-send{width:38px;height:38px;background:var(--ink);color:var(--paper);border:none;border-radius:50%;font-size:14px;cursor:pointer;transition:var(--t);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.main-cs-send:hover{background:var(--ink-l);transform:scale(1.05)}

/* ═══════════════════════════════════════
   VIP CUSTOMER SERVICE
   ═══════════════════════════════════════ */

/* Floating CS button in VIP modal */
.vip-cs-fab{position:fixed;bottom:28px;right:28px;z-index:2500;width:48px;height:48px;background:linear-gradient(135deg,var(--gold-d),var(--gold-l));color:var(--paper);border:none;border-radius:50%;font-size:18px;cursor:pointer;box-shadow:0 4px 20px rgba(191,154,78,.35);transition:var(--t);display:none;align-items:center;justify-content:center}
.vip-cs-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(191,154,78,.5)}
.vip-cs-fab .pulse{position:absolute;inset:-4px;border:2px solid var(--gold);border-radius:50%;animation:csPulse 2s ease-in-out infinite}
@keyframes csPulse{0%,100%{opacity:0;transform:scale(1)}50%{opacity:.4;transform:scale(1.2)}}

/* CS Panel — modal overlay */
.vip-cs-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:2600;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;padding:20px}
.vip-cs-overlay.active{opacity:1;visibility:visible}
.vip-cs-panel{background:var(--ink-l);border:1px solid rgba(191,154,78,.15);border-radius:12px;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;transform:translateY(24px);transition:transform .5s cubic-bezier(.16,1,.3,1);box-shadow:0 12px 40px rgba(0,0,0,.5)}
.vip-cs-overlay.active .vip-cs-panel{transform:translateY(0)}
.vip-cs-hd{padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:relative;overflow:visible}
.vip-cs-hd-left{display:flex;align-items:center;gap:12px}
.vip-cs-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--gold),var(--gold-l));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--ink);flex-shrink:0}
.vip-cs-info .name{font-size:14px;color:#fff;font-weight:600}
.vip-cs-info .status{font-size:11px;color:var(--jade-l);display:flex;align-items:center;gap:5px;margin-top:2px}
.vip-cs-info .status .dot{width:6px;height:6px;background:var(--jade);border-radius:50%;animation:blink 2s infinite}
.vip-cs-close{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:18px;color:rgba(255,255,255,.6);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t);position:relative;z-index:10;pointer-events:auto}
.vip-cs-close:hover{background:var(--red);color:#fff;border-color:var(--red)}

/* CS Body — scrollable chat area */
.vip-cs-body{flex:1;overflow-y:auto;padding:16px 20px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}
.vip-cs-body::-webkit-scrollbar{width:3px}
.vip-cs-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}

/* Chat bubbles */
.cs-msg{display:flex;gap:10px;margin-bottom:16px;align-items:flex-start}
.cs-msg.agent .cs-msg-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--gold),var(--gold-l));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--ink);flex-shrink:0}
.cs-msg.user{flex-direction:row-reverse}
.cs-msg.user .cs-msg-avatar{width:32px;height:32px;background:rgba(255,255,255,.06);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(255,255,255,.5);flex-shrink:0}
.cs-msg-bubble{max-width:75%;padding:12px 16px;border-radius:12px;font-size:13px;line-height:1.7;position:relative}
.cs-msg.agent .cs-msg-bubble{background:rgba(255,255,255,.05);color:rgba(255,255,255,.8);border-bottom-left-radius:4px}
.cs-msg.user .cs-msg-bubble{background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--ink);border-bottom-right-radius:4px}
.cs-msg-time{font-size:10px;color:rgba(255,255,255,.15);margin-top:4px}
.cs-msg.user .cs-msg-time{text-align:right}

/* Typing indicator */
.cs-typing{display:flex;gap:4px;padding:4px 0}
.cs-typing span{width:6px;height:6px;background:rgba(255,255,255,.2);border-radius:50%;animation:typingDot 1.4s infinite}
.cs-typing span:nth-child(2){animation-delay:.2s}
.cs-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,60%,100%{transform:translateY(0);opacity:.3}30%{transform:translateY(-6px);opacity:.8}}

/* Quick actions */
.cs-quick{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.cs-quick-btn{padding:7px 14px;font-size:11px;background:rgba(191,154,78,.08);border:1px solid rgba(191,154,78,.15);color:var(--gold);border-radius:100px;cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;letter-spacing:.04em}
.cs-quick-btn:hover{background:rgba(191,154,78,.15);border-color:var(--gold)}

/* Contact cards */
.cs-contacts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.cs-contact{display:flex;align-items:center;gap:10px;padding:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:var(--r);cursor:pointer;transition:var(--t)}
.cs-contact:hover{border-color:rgba(191,154,78,.2);background:rgba(191,154,78,.03)}
.cs-contact i{font-size:18px;width:24px;text-align:center}
.cs-contact.wx i{color:#07c160}
.cs-contact.phone i{color:var(--gold)}
.cs-contact.qq i{color:#12b7f5}
.cs-contact.email i{color:var(--jade-l)}
.cs-contact-info .label{font-size:11px;color:rgba(255,255,255,.3)}
.cs-contact-info .value{font-size:12px;color:rgba(255,255,255,.7);margin-top:1px}

/* CS Input */
.vip-cs-input{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:10px;align-items:center;flex-shrink:0}
.vip-cs-input input{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:100px;padding:10px 16px;color:#fff;font-size:13px;font-family:'Noto Sans SC',sans-serif;outline:none;transition:border-color .3s}
.vip-cs-input input::placeholder{color:rgba(255,255,255,.2)}
.vip-cs-input input:focus{border-color:var(--gold)}
.vip-cs-send{width:38px;height:38px;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--ink);border:none;border-radius:50%;font-size:14px;cursor:pointer;transition:var(--t);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vip-cs-send:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(191,154,78,.3)}

/* Toast notification */
.growth-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);background:rgba(26,26,26,.95);border:1px solid rgba(191,154,78,.2);border-radius:8px;padding:14px 24px;color:#fff;font-size:13px;z-index:3000;opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:10px;box-shadow:0 8px 32px rgba(0,0,0,.3);backdrop-filter:blur(12px)}
.growth-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.growth-toast i{color:var(--gold);font-size:16px}
.growth-toast .pts{color:var(--gold);font-weight:700;font-family:'Noto Serif SC',serif}

/* Payment QR overlay */
.vip-pay{position:absolute;inset:0;background:rgba(17,15,11,.97);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s;z-index:10;border-radius:8px;padding:32px}
.vip-pay.show{opacity:1;pointer-events:auto}
.vip-pay-title{font-size:18px;color:#fff;margin-bottom:6px;font-family:'Noto Serif SC',serif;letter-spacing:.06em}
.vip-pay-sub{font-size:13px;color:rgba(255,255,255,.4);margin-bottom:24px}
.vip-pay-qr{width:200px;height:200px;background:#fff;border-radius:8px;padding:12px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 24px rgba(191,154,78,.15)}
.vip-pay-qr img{width:100%;height:100%;object-fit:contain}
.vip-pay-qr-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#333}
.vip-pay-qr-placeholder i{font-size:48px;margin-bottom:8px;color:var(--gold)}
.vip-pay-qr-placeholder span{font-size:12px;color:#888}
.vip-pay-amount{font-size:14px;color:var(--gold);margin-bottom:6px;font-weight:600}
.vip-pay-amount .sym{font-size:16px}
.vip-pay-amount .num{font-family:'Noto Serif SC',serif;font-size:32px;font-weight:900}
.vip-pay-hint{font-size:11px;color:rgba(255,255,255,.25);margin-top:16px;line-height:1.8;text-align:center}
.vip-pay-tabs{display:flex;gap:0;margin-bottom:20px;background:rgba(255,255,255,.04);border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.vip-pay-tab{flex:1;padding:10px 18px;text-align:center;font-size:12px;color:rgba(255,255,255,.4);cursor:pointer;transition:var(--t);font-family:'Noto Sans SC',sans-serif;border:none;background:transparent;letter-spacing:.06em}
.vip-pay-tab.on{color:var(--gold);background:rgba(191,154,78,.1);font-weight:500}
.vip-pay-tab:hover:not(.on){color:rgba(255,255,255,.7)}
.vip-pay-back{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:14px;color:rgba(255,255,255,.4);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--t)}
.vip-pay-back:hover{background:rgba(255,255,255,.12);color:#fff}
.vip-pay-timer{font-size:12px;color:rgba(255,255,255,.3);margin-top:10px}
.vip-pay-timer span{color:var(--gold);font-weight:600}

.vip-success{position:absolute;inset:0;background:rgba(17,15,11,.95);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s;z-index:10;border-radius:8px}
.vip-success.show{opacity:1;pointer-events:auto}
.vip-success .crown{font-size:48px;margin-bottom:16px;animation:popIn .6s cubic-bezier(.16,1,.3,1)}
.vip-success h4{font-size:20px;color:#fff;margin-bottom:8px;font-family:'Noto Serif SC',serif;letter-spacing:.06em}
.vip-success p{font-size:13px;color:rgba(255,255,255,.4)}

/* Image modal */
.img-ov{display:none;position:fixed;z-index:2000;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px)}
.img-box{background:var(--ink-l);border:1px solid rgba(255,255,255,.08);margin:10% auto;padding:24px;width:80%;max-width:380px;border-radius:8px;position:relative;text-align:center;animation:zi .4s cubic-bezier(.16,1,.3,1)}
.img-x{position:absolute;top:-12px;right:-12px;background:var(--ink-l);border:1px solid rgba(255,255,255,.1);width:32px;height:32px;border-radius:50%;line-height:30px;cursor:pointer;font-size:16px;color:rgba(255,255,255,.5);transition:var(--t)}
.img-x:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.img-box p{color:rgba(255,255,255,.4);font-size:13px;margin-top:10px}
@keyframes zi{from{transform:scale(.92) translateY(12px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}

/* ═══════════════════════════════════════
   RESPONSIVE — TABLET (≤900px)
   ═══════════════════════════════════════ */
@media(max-width:900px){
  /* NAV */
  .nav-inner{height:60px}
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:rgba(248,246,241,.95);padding:14px;border-bottom:1px solid var(--paper-d);box-shadow:0 8px 30px rgba(0,0,0,.08);backdrop-filter:blur(20px)}
  .nav-links.open a{padding:13px 18px;font-size:14px;border-radius:var(--r)}
  .nav-links.open a:hover{background:var(--gold-a)}
  .nav-right .nav-status{display:none}
  .nav-login{padding:7px 14px;font-size:11px}
  .nav-cta{padding:7px 16px!important;font-size:11px!important}

  /* HERO */
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-right{display:none}
  .hero-left{padding:90px 5% 56px}
  .hero h1{font-size:clamp(28px,7vw,42px)}
  .hero-desc{font-size:14px;max-width:100%}
  .hero-stats{gap:28px;margin-top:40px;padding-top:28px}
  .hero-stat .num{font-size:28px}
  .hero-actions{gap:10px}
  .btn{padding:12px 26px;font-size:12px}

  /* FEATURES */
  .bento{grid-template-columns:1fr;gap:14px}
  .feat-card.big,.feat-card.small,.feat-card.wide{grid-column:span 1}
  .feat-card.big .feat-inner{grid-template-columns:1fr}
  .feat-card.big{padding:28px 24px}
  .feat-card{padding:26px 22px}
  .feat-ic{width:44px;height:44px;font-size:17px;border-radius:12px}

  /* THEMES — horizontal scroll stays, but cards smaller */
  .theme-card{min-width:280px;max-width:320px}

  /* AR */
  .ar-grid{grid-template-columns:1fr;gap:32px}
  .ar-frame{padding:28px}

  /* ECO */
  .eco-top{grid-template-columns:1fr 1fr}
  .eco-chart-wrap{grid-template-columns:1fr}
  .eco-sidebar{flex-direction:row;flex-wrap:wrap}
  .eco-trend{min-width:140px}

  /* REVIEWS — fixed-height scrollable pool on tablet */
  .rev-pool{height:480px;overflow-y:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .rev-pool::-webkit-scrollbar{display:none}
  .rev-pool::before,.rev-pool::after{display:none}
  .rev-bubble{position:relative!important;width:100%!important;opacity:1!important;transform:none!important;animation:none!important;margin-bottom:14px;pointer-events:auto!important}

  /* FOOTER */
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}

  /* MODALS */
  .modal-ov{padding:16px}
  .modal-hd{padding:22px 26px 0}
  .modal-bd{padding:22px 26px 26px}
  .modal-div{margin:0 26px}
  .vip-hero{padding:28px 24px 24px}
  .vip-body{padding:24px 20px 28px}
  .vip-plans{grid-template-columns:1fr;gap:12px}
  .vip-plan{padding:24px 20px}
  .vip-benefits{grid-template-columns:1fr}
  .vip-compare{font-size:11px}
  .vip-compare th,.vip-compare td{padding:8px 4px}
  .vip-footer{padding:0 20px 24px}
  .login-tabs{margin:0 26px 20px}
  .login-social{flex-direction:column}

  /* Sections */
  .sec{padding:70px 5%}
  .sec-head{margin-bottom:40px}
  .sec-head h2{font-size:clamp(22px,5vw,32px)}
  .sec-head p{font-size:14px}
}

/* ═══════════════════════════════════════
   RESPONSIVE — MOBILE (≤600px)
   ═══════════════════════════════════════ */
@media(max-width:600px){
  /* NAV — compact */
  .nav{padding:0 3%}
  .nav-inner{height:56px}
  .nav-logo span{font-size:15px}
  .nav-logo .logo-svg{width:30px;height:30px}
  .nav-inner{gap:6px}
  .nav-right{gap:6px}
  .nav-cta{display:none!important}
  .nav-vip{padding:6px 10px;font-size:10px;border-color:rgba(191,154,78,.25)}
  .nav-vip i{font-size:9px}
  .nav-login{padding:6px 10px;font-size:10px}
  .nav-links.open{top:56px}

  /* HERO — full-width, stacked */
  .hero{min-height:auto}
  .hero-left{padding:80px 4% 44px}
  .hero-badge{font-size:11px;padding:6px 14px 6px 10px;margin-bottom:24px}
  .hero h1{font-size:clamp(24px,8vw,36px);margin-bottom:16px}
  .hero-desc{font-size:13px;line-height:2;margin-bottom:28px}
  .hero-actions{flex-direction:column;gap:8px}
  .btn{width:100%;justify-content:center;padding:13px 20px;font-size:12px}
  .hero-stats{flex-direction:column;gap:18px;margin-top:32px;padding-top:24px}
  .hero-stat .num{font-size:26px}
  .hero-stat .label{font-size:11px}

  /* LOADER */
  .loader-seal{width:72px;height:72px;font-size:30px;margin-bottom:24px}
  .loader-bar{width:200px}
  .loader-pct{font-size:12px;letter-spacing:.2em;margin-top:14px}
  .loader-tag{font-size:10px;margin-top:8px}

  /* TICKER */
  .ticker{padding:10px 0}
  .ticker-item{font-size:12px}

  /* FEATURES — single column, compact */
  .sec{padding:56px 4%}
  .sec-head{margin-bottom:32px}
  .sec-head h2{font-size:clamp(20px,6vw,28px)}
  .sec-head p{font-size:13px;line-height:1.7}
  .feat-card{padding:22px 18px}
  .feat-card h4{font-size:16px}
  .feat-card>p{font-size:13px}
  .feat-ic{width:42px;height:42px;font-size:16px;margin-bottom:16px;border-radius:12px}
  .feat-metrics{gap:18px}
  .feat-metrics .mv{font-size:22px}
  .feat-btn{padding:8px 16px;font-size:11px}
  .feat-card.big .feat-visual{min-height:160px}

  /* THEMES — cards full width */
  .theme-card{min-width:85vw;max-width:85vw}
  .themes-wrap{gap:14px;padding:0 4% 32px}
  .theme-visual{height:160px}
  .theme-body{padding:20px}
  .theme-body h4{font-size:16px}
  .theme-body>p{font-size:12px}
  .theme-btns{flex-direction:column;gap:6px}
  .theme-btn{padding:10px 14px;font-size:12px}

  /* AR — stacked */
  .ar-grid{gap:24px}
  .ar-text p{font-size:14px}
  .ar-frame{padding:22px}
  .ar-qr{width:120px;height:120px}
  .ar-qr i{font-size:28px}
  .ar-ctrls{flex-wrap:wrap;gap:8px}

  /* ECO — 2 column cards */
  .eco-top{grid-template-columns:1fr 1fr;gap:10px}
  .eco-card{padding:20px 14px}
  .eco-card i{font-size:22px}
  .eco-card .val{font-size:28px}
  .eco-card .lbl{font-size:11px}
  .eco-card .sts{font-size:10px}
  .eco-chart{height:260px;min-height:220px}
  .eco-trend{padding:16px;min-width:0}
  .eco-trend-val{font-size:22px}

  /* REVIEWS */
  .rev-pool{height:380px}
  .rev-bubble{padding:18px 16px}
  .rev-bubble blockquote{font-size:11px}
  .rev-stats{flex-wrap:wrap;gap:24px 32px}
  .rev-stat .num{font-size:22px}

  /* FOOTER — single column */
  .foot{padding:56px 4% 24px}
  .foot::before{left:4%;right:4%}
  .foot-grid{grid-template-columns:1fr;gap:32px}
  .foot-brand p{font-size:12px}
  .foot-col h4{font-size:11px;margin-bottom:12px}
  .foot-col a,.foot-col p{font-size:12px;margin-bottom:8px}
  .foot-bottom{font-size:11px;margin-top:28px}

  /* MODALS — full-width on phone */
  .modal-ov{padding:10px;align-items:flex-end}
  .modal{max-height:92vh;border-radius:14px 14px 0 0}
  .modal-hd{padding:20px 20px 0}
  .modal-hd h3{font-size:18px}
  .modal-bd{padding:18px 20px 22px}
  .modal-div{margin:0 20px}
  .modal-x{width:32px;height:32px;font-size:14px}
  .sl::-webkit-slider-thumb{width:20px;height:20px}
  .bp{padding:10px 16px;font-size:12px}
  .btn-gen{padding:14px;font-size:13px;margin-top:22px}
  .res-box,.book-res{padding:18px}
  .res-box h4,.book-res h4{font-size:16px}

  /* VIP modal */
  .vip-modal .modal{max-width:100%;max-height:95vh}
  .vip-hero{padding:22px 20px 20px}
  .vip-hero-inner{flex-direction:column;align-items:flex-start;gap:14px}
  .vip-hero-icon{width:48px;height:48px;font-size:22px;border-radius:12px}
  .vip-hero-text h3{font-size:18px}
  .vip-hero-text p{font-size:12px}
  .vip-close{top:14px;right:14px;width:30px;height:30px;font-size:14px}
  .vip-tabs{flex-wrap:wrap}
  .vip-tab{padding:10px 8px;font-size:12px}
  .vip-body{padding:18px 16px 24px}
  .vip-plans{grid-template-columns:1fr}
  .vip-plan{padding:22px 18px}
  .vip-plan .price .num{font-size:34px}
  .vip-plan .price .sym{font-size:14px}
  .vip-plan-icon{width:42px;height:42px;font-size:18px;margin-bottom:12px;border-radius:10px}
  .vip-plan.popular::before{font-size:9px;padding:2px 28px}
  .vip-benefit{padding:12px}
  .vip-benefit .ic{width:28px;height:28px;font-size:12px}
  .vip-benefit h5{font-size:12px}
  .vip-benefit p{font-size:10px}
  .vip-compare{font-size:10px}
  .vip-compare th,.vip-compare td{padding:6px 3px}
  .vip-footer{padding:0 16px 22px}
  .vip-footer p{font-size:10px}
  .vip-section-title{font-size:10px;margin-bottom:14px}
  .vip-pay{padding:24px 18px}
  .vip-pay-title{font-size:16px}
  .vip-pay-qr{width:170px;height:170px;padding:10px}
  .vip-pay-amount .num{font-size:28px}
  .vip-pay-tab{padding:9px 12px;font-size:11px}

  /* Growth system mobile */
  .growth-card{padding:20px 16px}
  .growth-top{flex-wrap:wrap;gap:12px}
  .growth-avatar{width:48px;height:48px;font-size:18px}
  .growth-avatar .lv-badge{width:18px;height:18px;font-size:8px}
  .growth-user-name{font-size:14px}
  .growth-checkin-btn{padding:7px 16px;font-size:11px;width:100%;justify-content:center;margin-top:4px}
  .growth-ms-name{font-size:7px;letter-spacing:0}
  .growth-ms-dot{width:14px;height:14px;font-size:6px}
  .growth-milestones{gap:2px}
  .growth-ms{gap:4px}
  .growth-task{padding:12px}
  .growth-task-icon{width:32px;height:32px;font-size:13px}
  .growth-task-name{font-size:12px}
  .growth-task-desc{font-size:10px}
  .growth-level-perks{grid-template-columns:1fr}
  .growth-perk{font-size:10px;padding:6px 8px}
  .growth-hist-item{padding:8px 10px;font-size:11px}

  /* CS panel mobile */
  .vip-cs-fab{width:44px;height:44px;font-size:16px;bottom:24px;right:24px}
  .vip-cs-overlay{padding:0}
  .vip-cs-panel{max-height:85vh;max-width:100%;width:100%;border-radius:12px 12px 0 0;transform:translateY(100%);margin-top:auto}
  .vip-cs-overlay.active .vip-cs-panel{transform:translateY(0)}
  .vip-cs-panel.open{transform:translateY(0)!important}
  .main-cs-panel{right:0;left:0;width:100%;max-height:70vh;border-radius:12px 12px 0 0}
  .vip-cs-hd{padding:14px 16px}
  .vip-cs-avatar{width:34px;height:34px;font-size:14px}
  .vip-cs-info .name{font-size:13px}
  .vip-cs-body{padding:12px 14px}
  .cs-msg-bubble{max-width:82%;padding:10px 14px;font-size:12px}
  .cs-contacts{grid-template-columns:1fr}
  .cs-contact{padding:10px}
  .cs-quick-btn{padding:6px 12px;font-size:10px}
  .vip-cs-input{padding:10px 12px}
  .vip-cs-input input{padding:9px 14px;font-size:12px}
  .vip-cs-send{width:34px;height:34px;font-size:13px}
  .main-cs-close,.vip-cs-close{width:38px;height:38px;font-size:20px}
  .growth-toast{max-width:90vw;padding:12px 18px;font-size:12px}

  /* Login modal */
  .login-modal .modal{max-width:100%}
  .login-tabs{margin:0 20px 16px}
  .login-tab{padding:10px;font-size:12px}
  .login-field{margin-bottom:12px}
  .login-field label{font-size:11px;margin-bottom:6px}
  .login-input{padding:11px 14px;font-size:13px}
  .login-row{margin-bottom:18px;flex-wrap:wrap;gap:8px}
  .login-submit{padding:13px;font-size:13px}
  .login-social{flex-direction:column;gap:8px}
  .login-social-btn{padding:11px;font-size:12px}
  .login-divider{margin:18px 0}

  /* Booking / Trip / AR / Product modals */
  .cal-g{gap:4px}
  .cal-d{padding:9px 0;font-size:11px}
  .cal-h{font-size:10px;padding:4px 0}
  .prod-g{grid-template-columns:1fr;gap:10px}
  .prod-it{padding:18px 12px}
  .prod-it i{font-size:26px}
  .prod-it h4{font-size:14px}
  .prod-it .pr{font-size:14px}
  .trace{padding:16px}
  .tr-row{font-size:11px;padding:6px 0}
  .btn-c,.btn-b{padding:10px;font-size:11px}
  .booking-card{padding:12px;gap:10px}
  .booking-icon{width:38px;height:38px;font-size:16px}
  .booking-info h4{font-size:13px}
  .prod-card-img{height:120px;font-size:36px}
  .prod-detail{max-width:100%;max-height:90vh;border-radius:12px 12px 0 0}
  .cart-fab{width:42px;height:42px;font-size:16px;bottom:20px;left:20px}
  .cart-panel{left:10px;right:10px;width:auto;bottom:74px}
  .route-fab{width:42px;height:42px;font-size:16px;bottom:78px;right:20px}
  .route-modal{max-width:100%;max-height:90vh;border-radius:12px 12px 0 0}
  .route-map{min-height:280px}
  .route-edit-btn{padding:5px 12px;font-size:10px}
  .add-poi-item{padding:4px 10px;font-size:10px}

  /* FAB */
  .fab{width:46px;height:46px;font-size:18px;bottom:24px;right:24px}
  .main-cs-btn{width:44px;height:44px;font-size:16px;bottom:80px;right:24px}

  /* User menu */
  .user-menu{min-width:180px}
  .user-menu-hd{padding:12px 14px}
  .user-menu-hd .av{width:30px;height:30px;font-size:13px}
  .user-menu-hd .info .name{font-size:13px}
  .user-menu-item{padding:8px 12px;font-size:12px}
}
