@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700;900&family=Noto+Sans+SC:wght@300;400;500;600;700;800;900&display=swap');

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --cream:#F7F5F2;--peach:#E8D5C0;--coral:#0D7377;--coral-soft:#14A3A8;
  --coral-light:#B8E4E0;--coral-glow:rgba(13,115,119,.12);
  --text:#1A2332;--text2:#5A6677;--text3:#8E99A8;
  --paper:#EDEAE5;--paper-dark:#DDD9D3;
  --white:#FEFEFE;--ink:#1A2332;
  --r:16px;--r2:10px;
  --sans:'Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --serif:'Noto Serif SC','STSong','SimSun',serif;
  --t:all .3s cubic-bezier(.4,0,.2,1);
  --accent:#C8956C;--accent-soft:#D4A87C;--accent-light:#E8D5C0;
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);color:var(--text);background:var(--cream);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;
background-image:radial-gradient(ellipse at 80% 20%,rgba(184,228,224,.4) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(13,115,119,.03) 0%,transparent 50%);
background-attachment:fixed;
}
a{color:var(--coral);text-decoration:none;transition:var(--t)}a:hover{color:var(--ink)}
img{max-width:100%;height:auto;display:block}
ul,li{list-style:none}

/* ===== SCROLL REVEAL ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes slideIn{from{transform:translateX(-100%)}to{transform:translateX(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ===== HEADER: Floating premium island ===== */
.header{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  padding:12px 24px 0;
  background:linear-gradient(180deg,rgba(250,247,243,.95) 0%,transparent 100%);
  backdrop-filter:blur(20px);
}
.hisland{
  max-width:1200px;margin:0 auto;
  background:rgba(254,254,254,.92);
  border:1px solid rgba(232,224,214,.6);
  border-radius:60px;
  box-shadow:0 8px 40px rgba(26,35,50,.08),0 1px 3px rgba(26,35,50,.04);
  padding:6px 8px 6px 6px;
  display:flex;align-items:center;gap:0;
  backdrop-filter:blur(16px);
  transition:var(--t);
}
.hisland:hover{box-shadow:0 12px 50px rgba(26,35,50,.12)}
.hlogo{
  display:flex;align-items:center;gap:10px;
  padding:4px 16px 4px 12px;text-decoration:none;
  flex-shrink:0;
}
.hlogo:hover{text-decoration:none;color:var(--text)}
.hlogo svg{width:34px;height:34px;flex-shrink:0}
.hlogo .ln{font-size:11px;font-weight:700;color:var(--coral);letter-spacing:-.2px;line-height:1.15;white-space:nowrap}
.hlogo .lt{font-size:10px;color:var(--text3);letter-spacing:.5px}

.hnav{display:flex;align-items:center;gap:0;margin-left:0;flex:1;justify-content:center}
.hnav a{
  padding:8px 14px;font-size:13px;font-weight:500;
  color:var(--text2);transition:var(--t);
  position:relative;white-space:nowrap;
}
.hnav a::after{
  content:'';position:absolute;bottom:4px;left:50%;
  width:0;height:2px;background:var(--coral);
  border-radius:1px;transition:var(--t);transform:translateX(-50%);
}
.hnav a:hover{color:var(--coral)}
.hnav a:hover::after{width:60%}
.hnav .sep{width:1px;height:16px;background:var(--paper-dark);margin:0 4px}
.hnav .hl{color:var(--coral);font-weight:600}
.hnav .hl::after{display:none}

.huser{display:flex;align-items:center;gap:10px;padding:4px 8px 4px 8px;flex-shrink:0}
.hu-btn{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--coral),var(--coral-soft));
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:#fff;
  transition:var(--t);
}
.hu-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px rgba(13,115,119,.3)}
.hud{position:relative}
.hud-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  min-width:130px;background:var(--white);
  border-radius:16px;padding:4px;
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:var(--t);
  box-shadow:0 8px 32px rgba(26,35,50,.1);
  border:1px solid var(--paper-dark);
}
.hud:hover .hud-menu{opacity:1;visibility:visible;transform:translateY(0)}
.hud-menu .hun{padding:8px 12px;font-size:12px;font-weight:600;color:var(--text);border-bottom:1px solid var(--cream);margin-bottom:3px}
.hud-menu a{display:block;padding:6px 12px;font-size:13px;color:var(--text2);border-radius:10px;transition:var(--t);cursor:pointer}
.hud-menu a:hover{background:var(--cream);color:var(--coral)}

/* ===== BODY SPACING for fixed header ===== */
main{max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== BUTTONS ===== */
.btn{padding:7px 18px;border-radius:50px;border:none;font-weight:600;font-size:13px;cursor:pointer;transition:var(--t);display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);white-space:nowrap}
.btn-p{background:var(--coral);color:#fff;box-shadow:0 2px 8px rgba(13,115,119,.2)}.btn-p:hover{background:var(--ink);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,35,50,.15)}
.btn-g{background:transparent;color:var(--text2);border:1.5px solid var(--paper-dark)}.btn-g:hover{border-color:var(--coral);color:var(--coral);transform:translateY(-1px)}
.btn-xl{padding:14px 32px;font-size:15px;font-weight:700}
.btn-md{padding:10px 22px;font-size:14px}
.btn-sm{padding:5px 12px;font-size:12px}

/* ===== SECTION STYLES ===== */
.sec{padding:60px 0;position:relative;overflow:hidden}
.sec-alt{
  margin:0 -24px;padding:60px 24px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,transparent 0%,var(--paper) 2%,var(--paper) 98%,transparent 100%);
}
.sec-hd{margin:0 -24px;padding:60px 24px;position:relative}
.sec-hd::before{content:'';position:absolute;top:0;left:24px;right:0;height:1px;background:linear-gradient(90deg,var(--paper-dark),transparent)}
.sh{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:12px}
.stt{font-family:var(--serif);font-size:24px;font-weight:700;display:flex;align-items:center;gap:12px;letter-spacing:-.3px;line-height:1.2}
.stt .bar{width:4px;height:24px;background:linear-gradient(180deg,var(--coral),var(--coral-light));border-radius:2px;flex-shrink:0}
.stt .sub{font-size:13px;font-weight:400;color:var(--text3);font-family:var(--sans);letter-spacing:0}
.smore{font-size:12px;font-weight:500;color:var(--text3);transition:var(--t);display:flex;align-items:center;gap:4px}
.smore:hover{color:var(--coral);transform:translateX(4px)}

/* ===== HERO: Cinematic editorial ===== */
.hero{
  padding:80px 0 40px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-30%;right:-15%;
  width:600px;height:600px;
  background:radial-gradient(circle,var(--coral-glow) 0%,transparent 70%);
  animation:pulse 6s ease-in-out infinite;
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;bottom:-20%;left:-10%;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(184,228,224,.3) 0%,transparent 70%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-htg{
  display:inline-flex;align-items:center;gap:0;
  padding:0;
  font-size:12px;font-weight:600;letter-spacing:.5px;
  margin-bottom:18px;color:var(--coral);
  position:relative;z-index:2;
}
.hero-htg .tag-l,.hero-htg .tag-r{
  padding:6px 14px;
  background:var(--white);
  border:1px solid var(--paper);
}
.hero-htg .tag-l{border-radius:6px 2px 2px 6px;border-right:none}
.hero-htg .tag-r{border-radius:2px 6px 6px 2px;border-left:none;background:var(--cream)}
.hero-htg .tag-icon{
  width:28px;height:28px;
  background:linear-gradient(135deg,var(--coral),var(--coral-soft));
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;color:#fff;
  box-shadow:0 2px 8px rgba(13,115,119,.25);
  transform:rotate(-6deg);
}
.hero h1{
  font-family:var(--serif);font-size:56px;font-weight:900;line-height:1.15;
  letter-spacing:-2px;color:var(--ink);margin-bottom:16px;
}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg,var(--coral) 0%,var(--coral-soft) 50%,var(--coral-light) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero .hd{font-size:17px;line-height:1.8;color:var(--text2);margin-bottom:28px;max-width:440px;font-weight:300}
.hero-acts{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-acts .btn-xl{position:relative;overflow:hidden}
.hero-acts .btn-xl::before{
  content:'';position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:.6s;
}
.hero-acts .btn-xl:hover::before{left:100%}
.hero-meta{margin-top:20px;display:flex;gap:20px;align-items:center}
.hero-meta .hm{font-size:12px;color:var(--text3)}
.hero-meta .hm b{color:var(--text);font-weight:600}

.hero-vis{position:relative;aspect-ratio:4/3;max-width:460px;margin:0 auto}
.hero-vf{position:absolute;border-radius:20px;overflow:hidden;box-shadow:0 12px 40px rgba(26,35,50,.12);transition:all .5s cubic-bezier(.4,0,.2,1)}
.hero-vf img{width:100%;height:100%;object-fit:cover}
.hero-vf1{top:0;left:0;width:68%;height:70%;transform:rotate(-5deg)}
.hero-vf1:hover{transform:rotate(0) translateY(-10px);box-shadow:0 20px 50px rgba(26,35,50,.15)}
.hero-vf2{bottom:0;right:0;width:60%;height:62%;transform:rotate(4deg);border:4px solid var(--white)}
.hero-vf2:hover{transform:rotate(0) translateY(-8px)}
.hero-vdot{position:absolute;border-radius:50%;opacity:.3;filter:blur(20px)}
.hero-vdot:nth-child(3){width:70px;height:70px;background:var(--coral-light);top:5%;right:15%;animation-duration:5s}
.hero-vdot:nth-child(4){width:50px;height:50px;background:var(--peach);bottom:10%;left:5%;animation-duration:6s;animation-delay:1s}
.hero-vdot:nth-child(5){width:30px;height:30px;background:var(--coral);top:40%;right:5%;animation-duration:4s;animation-delay:2s}

/* ===== STATS BAR ===== */
.stats{
  display:flex;justify-content:center;gap:56px;
  padding:32px 0;margin:0 0 8px;
  position:relative;
}
.stats::after{
  content:'';position:absolute;bottom:0;left:50%;
  transform:translateX(-50%);width:60px;height:2px;
  background:linear-gradient(90deg,var(--coral),transparent);
}
.st{text-align:center}
.st .n{font-size:36px;font-weight:900;color:var(--coral);letter-spacing:-.8px;font-family:var(--serif)}
.st .l{font-size:11px;color:var(--text3);margin-top:4px;letter-spacing:1px;font-weight:600;text-transform:uppercase}

/* ===== FEATURED: Asymmetric editorial spread ===== */
.msn{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;min-height:420px}
.msn .mc1{border-radius:24px;overflow:hidden;position:relative;background:var(--paper-dark)}
.msn .mc2{border-radius:18px;overflow:hidden;position:relative;background:var(--paper-dark)}
.msn a{display:block;width:100%;height:100%;text-decoration:none;color:#fff}
.msn img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.msn .mc1:hover img,.msn .mc2:hover img{transform:scale(1.05)}
.m-ov{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px;background:linear-gradient(transparent,rgba(26,35,50,.92));
  color:#fff;z-index:2;
}
.m-ov h3{font-family:var(--serif);font-size:22px;font-weight:700;margin-bottom:4px;letter-spacing:-.3px}
.m-ov p{font-size:13px;opacity:.85;margin-bottom:10px;line-height:1.6}
.m-ov .btn{font-size:12px;padding:6px 16px;background:var(--coral);border:none;border-radius:50px;color:#fff}
.m-ov .btn:hover{background:var(--coral-soft)}

/* ===== LATEST LIST: Staggered editorial ===== */
.llist{display:flex;flex-direction:column;gap:12px}
.llist .li{
  display:grid;grid-template-columns:130px 1fr auto;gap:20px;align-items:center;
  padding:16px 20px;
  background:var(--white);
  border-radius:18px;
  border:1px solid var(--paper);
  transition:var(--t);
}
.li:nth-child(1){margin-left:0}.li:nth-child(2){margin-left:12px}.li:nth-child(3){margin-left:24px}
.li:nth-child(3n+1){margin-left:0}.li:nth-child(3n+2){margin-left:12px}.li:nth-child(3n){margin-left:24px}
.li:hover{box-shadow:0 8px 32px rgba(26,35,50,.06);border-color:var(--coral-light);margin-left:0!important}
.li img{width:130px;height:90px;border-radius:14px;object-fit:cover;flex-shrink:0}
.li h3{font-size:16px;font-weight:600;margin-bottom:4px;letter-spacing:-.2px}
.li p{font-size:12px;color:var(--text3);line-height:1.5}
.li-act{display:flex;gap:8px;flex-shrink:0}

/* ===== COMIC GRID: Cover cards ===== */
.cgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.chl{
  display:block;position:relative;
  border-radius:16px;overflow:hidden;
  background:var(--white);
  border:1px solid var(--paper);
  transition:var(--t);
}
.chl:hover{transform:translateY(-6px);box-shadow:0 12px 32px rgba(13,115,119,.08);border-color:var(--coral-light);text-decoration:none}
.chl img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.chl .chn{
  padding:8px 10px 2px;
  font-size:12px;font-weight:600;color:var(--coral);
}
.chl .chd{
  padding:0 10px 8px;
  font-size:11px;color:var(--text3);
}
.ci{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--paper-dark);transition:var(--t);background:var(--white)}
.ci:hover{transform:translateY(-6px);box-shadow:0 12px 32px rgba(26,35,50,.08);border-color:var(--coral-light)}
.ci a{text-decoration:none;color:inherit;display:block}
.ci .cimg{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;transition:transform .5s}
.ci:hover .cimg{transform:scale(1.05)}
.ci .cv{
  position:absolute;bottom:0;left:0;right:0;
  padding:20px 12px 10px;
  background:linear-gradient(transparent,rgba(0,0,0,.85));
  color:#fff;font-size:13px;font-weight:600;
  text-align:center;
}

/* ===== HOT BENTO ===== */
.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.bi{
  padding:14px 16px;
  background:var(--white);
  border-radius:14px;
  border:1px solid var(--paper);
  display:flex;align-items:center;gap:12px;
  transition:var(--t);cursor:pointer;
  position:relative;overflow:hidden;
}
.bi::before{
  content:'';position:absolute;top:0;left:0;
  width:3px;height:0;background:var(--coral);
  transition:var(--t);border-radius:2px;
}
.bi:hover{border-color:var(--coral-light);box-shadow:0 4px 16px rgba(13,115,119,.06)}
.bi:hover::before{height:100%}
.bi .rki{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;flex-shrink:0;color:#fff;
}
.bi .rki.t1{background:linear-gradient(135deg,#0D7377,#14A3A8)}
.bi .rki.t2{background:linear-gradient(135deg,#14A3A8,#B8E4E0)}
.bi .rki.t3{background:linear-gradient(135deg,#8E99A8,#d4c8bc)}
.bi .rki.n{background:var(--paper-dark);color:var(--text3)}
.bi img{width:42px;height:42px;border-radius:10px;object-fit:cover;flex-shrink:0}
.bi .bin{font-size:13px;font-weight:600;line-height:1.3;margin-bottom:2px}
.bi .bid{font-size:11px;color:var(--text3)}

/* ===== HORIZONTAL SCROLL ===== */
.hscr{display:flex;gap:14px;overflow-x:auto;padding:10px 40px 12px 0;scroll-snap-type:x mandatory;-ms-overflow-style:none;scrollbar-width:none}
.hscr::-webkit-scrollbar{display:none}
.hscr>*{scroll-snap-align:start;flex-shrink:0}
.hc{
  width:190px;border-radius:16px;overflow:hidden;
  background:var(--white);border:1px solid var(--paper);
  transition:var(--t);
}
.hc:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(26,35,50,.06)}
.hc img{width:100%;aspect-ratio:3/4;object-fit:cover}
.hc .hci{padding:12px}
.hc .hci h4{font-size:14px;font-weight:600;margin-bottom:4px}
.hc .hci p{font-size:11px;color:var(--text3);margin-bottom:4px}
.hc .hci .btn{font-size:11px}

/* ===== AUTHORS ===== */
.authr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ath{
  padding:24px;
  background:var(--white);
  border-radius:20px;
  border:1px solid var(--paper);
  position:relative;overflow:hidden;
  transition:var(--t);
}
.ath::before{
  content:'';position:absolute;top:-30%;right:-20%;
  width:120px;height:120px;
  background:var(--peach);border-radius:50%;opacity:.4;
  transition:var(--t);
}
.ath:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(26,35,50,.06)}
.ath:hover::before{transform:scale(1.2)}
.ath .athv{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--coral),var(--coral-soft));
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;color:#fff;
  margin-bottom:14px;position:relative;z-index:1;
  box-shadow:0 4px 16px rgba(13,115,119,.25);
}
.ath h3{font-size:16px;font-weight:700;margin-bottom:4px;position:relative;z-index:1}
.ath .abio2{font-size:12px;color:var(--text2);margin-bottom:10px;line-height:1.6;position:relative;z-index:1}
.ath .atgs{display:flex;gap:6px;flex-wrap:wrap;position:relative;z-index:1}
.ath .att{padding:4px 10px;background:var(--cream);border-radius:50px;font-size:10px;color:var(--coral);font-weight:500;transition:var(--t)}
.ath .att:hover{background:var(--coral);color:#fff}

/* ===== GENRE TABS ===== */
.genre-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.genre-tab{
  padding:8px 16px;border-radius:50px;
  background:var(--white);border:1px solid var(--paper);
  font-size:13px;font-weight:500;color:var(--text2);
  cursor:pointer;transition:var(--t);
}
.genre-tab:hover,.genre-tab.active{
  background:var(--coral);color:#fff;border-color:var(--coral);
  box-shadow:0 4px 12px rgba(13,115,119,.2);
}

/* ===== GUIDE TIMELINE ===== */
.guide-wrap{position:relative;padding:20px 0}
.gtl{position:relative;padding-left:40px}
.gtl::before{content:'';position:absolute;top:20px;left:18px;width:2px;height:calc(100% - 40px);background:linear-gradient(180deg,var(--coral),var(--coral-light),transparent)}
.gts{display:flex;gap:16px;align-items:flex-start;position:relative;margin-bottom:28px}
.gts:last-child{margin-bottom:0}
.gtd{
  width:38px;height:38px;min-width:38px;border-radius:50%;
  background:var(--white);border:2px solid var(--coral);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;color:var(--coral);
  position:relative;z-index:1;
  box-shadow:0 2px 8px rgba(13,115,119,.12);
  transition:var(--t);
}
.gts:hover .gtd{background:var(--coral);color:#fff;transform:scale(1.1)}
.gtc h4{font-size:15px;font-weight:600;margin-bottom:4px}
.gtc p{font-size:13px;color:var(--text2);line-height:1.7}

/* ===== NOTICES ===== */
.notif{display:flex;flex-direction:column;gap:10px}
.ni{
  padding:14px 18px;
  background:var(--white);
  border-radius:14px;
  border:1px solid var(--paper);
  display:flex;align-items:center;justify-content:space-between;
  transition:var(--t);
}
.ni:hover{border-color:var(--coral-light);box-shadow:0 4px 16px rgba(26,35,50,.04)}
.ni strong{font-size:14px;font-weight:600}
.ni span{font-size:12px;color:var(--text3)}
.ni .ni-dot{width:8px;height:8px;border-radius:50%;background:var(--coral);margin-right:10px;flex-shrink:0}
.ni .ni-l{display:flex;align-items:center}

/* ===== PROMO: Full bleed gradient ===== */
.promo{
  margin:40px 0 48px;
  padding:48px 36px;
  background:linear-gradient(135deg,var(--coral) 0%,var(--coral-soft) 40%,var(--peach) 100%);
  border-radius:24px;
  color:#fff;text-align:center;
  position:relative;overflow:hidden;
}
.promo::before{
  content:'';position:absolute;top:-40%;right:-10%;
  width:300px;height:300px;
  background:rgba(255,255,255,.08);border-radius:50%;
  filter:blur(20px);
}
.promo::after{
  content:'';position:absolute;bottom:-30%;left:-5%;
  width:200px;height:200px;
  background:rgba(255,255,255,.05);border-radius:50%;
  filter:blur(15px);
}
.promo h2{font-family:var(--serif);font-size:32px;font-weight:800;margin-bottom:8px;position:relative;letter-spacing:-.4px}
.promo p{font-size:15px;opacity:.9;margin-bottom:20px;position:relative}
.promo .btn{background:#fff;color:var(--coral);font-weight:700;padding:12px 28px;font-size:14px;position:relative}
.promo .btn:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}

/* ===== COMIC DETAIL PAGE ===== */
.dhero{
  display:grid;grid-template-columns:240px 1fr;gap:32px;
  margin:24px 0 48px;
  align-items:start;
}
.dcv{
  width:240px;height:340px;object-fit:cover;
  border-radius:20px;
  box-shadow:0 8px 32px rgba(26,35,50,.1);
}
.dinfo .dnt{font-family:var(--serif);font-size:32px;font-weight:800;letter-spacing:-1px;margin-bottom:6px}
.dinfo .dau{font-size:14px;color:var(--text2);margin-bottom:14px;display:flex;align-items:center;gap:6px}
.dinfo .dau::before{content:'';width:16px;height:2px;background:var(--coral);border-radius:1px}
.dinfo .dds{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:14px}
.dtags{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.dtt{padding:6px 14px;border-radius:50px;background:var(--peach);color:var(--coral);font-size:12px;font-weight:600}
.dacts{display:flex;gap:10px}

/* ===== READER ===== */
.rpage{min-height:100vh;background:var(--cream)}
.rtop{
  position:sticky;top:0;z-index:100;
  background:rgba(250,247,243,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--paper);
  padding:8px 24px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.rtop .rbk{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text3);transition:var(--t)}
.rtop .rbk:hover{color:var(--coral)}
.rnav{display:flex;gap:6px;margin-left:auto}
.rtl{font-size:14px;font-weight:700;color:var(--text);margin-left:12px}
.cnav{display:flex;gap:8px;align-items:center;padding:12px 0;margin-bottom:16px}
.cnav .lk{
  padding:7px 16px;border-radius:10px;
  font-size:13px;color:var(--text2);background:var(--white);
  border:1px solid var(--paper);
  transition:var(--t);
}
.cnav .lk:hover{border-color:var(--coral);color:var(--coral)}
.cimgs{text-align:center;background:var(--cream)}
.cimgs img{max-width:800px;width:100%;height:auto;display:block;margin:0 auto;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.cimgs img.lk{filter:blur(15px);cursor:pointer;position:relative}
.cbtn-next{
  display:flex;justify-content:center;gap:12px;margin:24px 0;
}

/* Unlock modal */
.ulov{
  display:none;position:fixed;top:0;left:0;
  width:100%;height:100%;
  background:rgba(26,35,50,.6);
  backdrop-filter:blur(8px);
  z-index:2000;
  align-items:center;justify-content:center;
}
.ulov.show{display:flex}
.ulb{
  background:var(--white);padding:36px 32px;
  border-radius:24px;text-align:center;
  max-width:360px;width:90%;
  box-shadow:0 20px 60px rgba(26,35,50,.15);
  animation:scaleIn .3s ease;
}
.ulb h3{font-family:var(--serif);font-size:20px;margin-bottom:6px}
.ulb p{font-size:13px;color:var(--text2);margin-bottom:18px}

/* ===== RECHARGE / PRICING ===== */
.pgrd{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px}
.pcd{
  padding:24px 16px;
  background:var(--white);
  border-radius:20px;
  border:1px solid var(--paper);
  text-align:center;
  cursor:pointer;transition:var(--t);
  position:relative;overflow:hidden;
}
.pcd::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:3px;background:linear-gradient(90deg,var(--coral),var(--coral-light));
  transform:scaleX(0);transition:var(--t);
}
.pcd:hover{transform:translateY(-4px);border-color:var(--coral-light);box-shadow:0 12px 32px rgba(13,115,119,.1)}
.pcd:hover::before{transform:scaleX(1)}
.pcd.pop{
  border:2px solid var(--coral);
  background:linear-gradient(180deg,rgba(13,115,119,.03),var(--white));
}
.pcd.pop::before{transform:scaleX(1)}
.pcd .pn{font-size:14px;font-weight:600;margin-bottom:4px;color:var(--text)}
.pcd .pd2{font-size:11px;color:var(--text3);margin-bottom:10px}
.pcd .pa{font-size:28px;font-weight:900;color:var(--coral);letter-spacing:-.6px}
.pcd .pa small{font-size:14px;font-weight:400;color:var(--text3)}
.pcd .perks2{margin:12px 0 0;text-align:left;padding:12px 0 0}

.perks2{
  background:var(--white);padding:22px;
  border-radius:16px;border:1px solid var(--paper);
  margin-bottom:28px;
}
.perks2 h2{text-align:center;font-family:var(--serif);font-size:18px;font-weight:700;margin-bottom:16px}
.pkri{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--cream)}
.pkri:last-child{border:none}
.pkri svg{width:18px;height:18px;flex-shrink:0;color:var(--coral)}
.pkri strong{font-size:14px;color:var(--text)}
.pkri span{font-size:12px;color:var(--text3);margin-left:auto}

/* ===== AUTH PAGES: Centered premium card ===== */
.authw{
  min-height:calc(100vh - 80px);
  display:flex;align-items:center;justify-content:center;
  padding:32px 20px;
  position:relative;
  background:
    radial-gradient(ellipse at 20% 20%,rgba(13,115,119,.06),transparent 50%),
    radial-gradient(ellipse at 80% 80%,rgba(20,163,168,.04),transparent 50%),
    var(--cream);
}
.au-ornament{
  position:absolute;pointer-events:none;
}
.au-ornament svg{width:100%;height:100%}
.au-ornament-1{top:-60px;right:-40px;width:280px;height:280px;opacity:.06}
.au-ornament-2{bottom:-40px;left:-30px;width:200px;height:200px;opacity:.04}

.au-card{
  width:100%;max-width:440px;
  background:var(--white);
  border-radius:28px;
  border:1px solid var(--paper);
  box-shadow:0 24px 80px rgba(26,35,50,.07),0 2px 8px rgba(26,35,50,.03);
  overflow:hidden;
  position:relative;z-index:1;
  animation:scaleIn .4s ease;
}
.au-card-top{
  padding:36px 36px 0;
  text-align:center;
  position:relative;
}
.au-card-top::after{
  content:'';position:absolute;bottom:0;left:36px;right:36px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--paper-dark),transparent);
}
.au-logo-row{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-bottom:16px;
}
.au-logo-row svg{width:36px;height:36px}
.au-logo-row span{
  font-family:var(--serif);font-size:18px;font-weight:800;
  background:linear-gradient(135deg,var(--coral),var(--coral-soft));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.au-card-top h1{
  font-family:var(--serif);font-size:26px;font-weight:800;
  letter-spacing:-.4px;margin-bottom:4px;color:var(--ink);
}
.au-card-top .sub2{
  font-size:13px;color:var(--text3);margin-bottom:24px;
}

.au-card-body{padding:28px 36px 32px}

.au-social{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-bottom:20px;
}
.au-social button{
  padding:11px 0;border:1.5px solid var(--paper);
  border-radius:14px;background:var(--white);
  font-size:13px;font-weight:500;color:var(--text2);
  cursor:pointer;transition:var(--t);
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--sans);
}
.au-social button svg{width:18px;height:18px;flex-shrink:0}
.au-social button:hover{
  border-color:var(--coral);color:var(--coral);
  background:rgba(13,115,119,.03);
}

.au-divider{
  display:flex;align-items:center;gap:14px;
  margin:20px 0;font-size:11px;color:var(--text3);
  letter-spacing:1px;font-weight:500;
}
.au-divider::before,.au-divider::after{
  content:'';flex:1;height:1px;background:var(--paper);
}

.fld{margin-bottom:14px}
.fld label{
  display:flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;margin-bottom:6px;
  color:var(--text2);letter-spacing:.2px;
}
.fld label svg{width:14px;height:14px;color:var(--text3)}
.fld label .rq{color:var(--coral);font-size:10px}
.fld label .op{color:var(--text3);font-size:10px;font-weight:400;margin-left:auto}
.fld-input{
  position:relative;
}
.fld-input svg{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:16px;height:16px;color:var(--text3);pointer-events:none;
  transition:var(--t);
}
.fld-input input,.fld-input select{
  width:100%;padding:12px 14px 12px 40px;
  border:1.5px solid var(--paper);
  border-radius:12px;
  font-size:14px;
  background:var(--cream);
  color:var(--text);
  transition:var(--t);
  font-family:var(--sans);
  -webkit-appearance:none;
}
.fld-input select{padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a09489' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.fld-input input:focus,.fld-input select:focus{
  outline:none;
  border-color:var(--coral);
  box-shadow:0 0 0 3px var(--coral-glow);
  background:var(--white);
}
.fld-input input:focus + svg,
.fld-input input:focus ~ svg{color:var(--coral)}

.agg{
  display:flex;gap:8px;align-items:flex-start;
  padding:10px 12px;
  background:var(--cream);
  border-radius:10px;
  font-size:12px;color:var(--text2);
  margin-bottom:18px;
  border:1px solid var(--paper);
}
.agg input{width:16px;height:16px;accent-color:var(--coral);margin-top:1px;flex-shrink:0}
.agg a{color:var(--coral);font-weight:600}

.sub-btn{
  width:100%;padding:14px;
  border:none;border-radius:14px;
  background:linear-gradient(135deg,var(--coral),var(--coral-soft));
  color:#fff;font-size:15px;font-weight:700;
  letter-spacing:2px;cursor:pointer;
  transition:var(--t);
  box-shadow:0 4px 20px rgba(13,115,119,.2);
  position:relative;overflow:hidden;
}
.sub-btn::before{
  content:'';position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transition:.6s;
}
.sub-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(13,115,119,.3)}
.sub-btn:hover::before{left:100%}

.auf{
  text-align:center;margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--paper);
  font-size:13px;color:var(--text3);
}
.auf a{font-weight:700;color:var(--coral);letter-spacing:.3px}

/* ===== BACK LINK ===== */
.bk{
  display:inline-flex;align-items:center;gap:5px;
  color:var(--text3);font-size:13px;
  transition:var(--t);margin-bottom:18px;
}
.bk:hover{color:var(--coral);text-decoration:none;transform:translateX(-3px)}

/* ===== LEGAL PAGES ===== */
.lpage{max-width:680px;margin:0 auto;padding:16px 0 48px}
.lcard{
  background:var(--white);
  padding:32px 36px;
  border-radius:24px;
  border:1px solid var(--paper);
  box-shadow:0 4px 20px rgba(26,35,50,.04);
}
.lcard h1{font-family:var(--serif);font-size:28px;font-weight:800;margin-bottom:4px;letter-spacing:-.4px}
.lcard .upd{font-size:12px;color:var(--text3);margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--cream);display:flex;align-items:center;gap:6px}
.lcard .upd::before{content:'';display:inline-block;width:14px;height:14px;background:var(--coral);border-radius:3px;flex-shrink:0}
.lcard h2{font-size:16px;font-weight:600;margin:24px 0 8px;color:var(--text);display:flex;align-items:center;gap:8px}
.lcard h2::before{content:'';width:4px;height:20px;background:var(--coral);border-radius:2px;flex-shrink:0}
.lcard p{color:var(--text2);margin-bottom:10px;font-size:14px;line-height:1.85}

/* ===== FOOTER ===== */
.footer{
  border-top:1px solid var(--paper);
  padding:32px 24px;
  margin-top:40px;
  background:linear-gradient(180deg,transparent,var(--paper));
}
.fwrp{max-width:1100px;margin:0 auto}
.fct{text-align:center}
.fct .fn{font-size:14px;font-weight:600;color:var(--coral);margin-bottom:8px}
.fct .fif{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 18px;font-size:12px;color:var(--text2);margin-bottom:8px}
.fct .fif a{color:var(--text2)}
.fct .ffl{display:flex;justify-content:center;gap:18px;margin-bottom:10px;flex-wrap:wrap}
.fct .ffl a{font-size:11px;color:var(--text3);transition:var(--t)}
.fct .ffl a:hover{color:var(--coral)}
.fcp{text-align:center;font-size:11px;color:var(--text3)}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-vis{display:none}
  .hero h1{font-size:40px;max-width:100%}
  .msn{grid-template-columns:1fr;min-height:auto}.mc2{display:none}
  .pgrd{grid-template-columns:repeat(2,1fr)}
  .dhero{grid-template-columns:1fr}.dcv{width:100%;height:300px}
  .authr{grid-template-columns:1fr}
  .au-card{max-width:100%;border-radius:20px}
  .au-card-top,.au-card-body{padding-left:24px;padding-right:24px}
}
@media(max-width:768px){
  .hisland{border-radius:20px;padding:6px}
  .hnav{display:none}
  .header{padding:8px 16px 0}
  main{padding:0 16px}
  .sec{padding:40px 0}
  .sec-alt{margin:0 -16px;padding:40px 16px}
  .hero{padding:40px 0 24px}
  .hero h1{font-size:32px}
  .stats{gap:24px}.st .n{font-size:28px}
  .bgrid{grid-template-columns:1fr 1fr}
  .cgrid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .gtl{flex-direction:column;gap:14px}.gtl::before{display:none}
  .footer{padding:20px 16px}
  .rtop{padding:6px 16px}
}
@media(max-width:480px){
  .bgrid,.pgrd{grid-template-columns:1fr}
  .hero h1{font-size:28px}
  .cgrid{grid-template-columns:repeat(2,1fr);gap:8px}
  .li{grid-template-columns:90px 1fr!important}
  .li img{width:90px;height:65px}
  .li p,.li-act{display:none}
  .msn{min-height:300px}
  .promo{padding:32px 20px}
  .promo h2{font-size:24px}
}

/* ===== SCROLL REVEAL UTILITY ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.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}

/* ===== HOVER CARD EFFECT ===== */
.hover-lift{transition:transform .3s ease,box-shadow .3s ease}
.hover-lift:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(26,35,50,.08)}

/* ===== BADGE / TAG ===== */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:50px;
  font-size:10px;font-weight:600;letter-spacing:.5px;
}
.badge-coral{background:var(--coral);color:#fff}
.badge-paper{background:var(--paper);color:var(--text2)}
.badge-new{background:var(--g12,#10b981);color:#fff}

/* ===== DIVIDER ===== */
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--paper-dark),transparent);margin:24px 0}

/* ===== GRAIN TEXTURE OVERLAY ===== */
body::after{
  content:'';position:fixed;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:9999;
  opacity:.025;
  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");
}

/* ===== READING PROGRESS BAR ===== */
.progress-bar{
  position:fixed;top:0;left:0;height:3px;
  background:linear-gradient(90deg,var(--coral),var(--coral-soft));
  z-index:10000;transition:width .1s linear;
  box-shadow:0 0 8px var(--coral-glow);
}

/* ===== MARQUEE TICKER ===== */
.marquee{
  overflow:hidden;white-space:nowrap;
  padding:14px 0;
  background:var(--ink);color:var(--cream);
  font-size:13px;font-weight:500;letter-spacing:1px;
  position:relative;
}
.marquee::before,.marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;
}
.marquee::before{left:0;background:linear-gradient(90deg,var(--ink),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--ink),transparent)}
.marquee-inner{
  display:inline-block;
  animation:marquee 30s linear infinite;
}
.marquee-inner span{
  display:inline-block;
  padding:0 32px;
}
.marquee-inner span .sep{
  display:inline-block;
  width:4px;height:4px;
  background:var(--coral);border-radius:50%;
  margin:0 16px;vertical-align:middle;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== PARALLAX QUOTE ===== */
.pquote{
  position:relative;
  padding:80px 24px;
  text-align:center;
  overflow:hidden;
  background:var(--ink);
  color:var(--cream);
}
.pquote::before{
  content:'';position:absolute;
  top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(ellipse at 30% 50%,rgba(13,115,119,.08),transparent 60%),
             radial-gradient(ellipse at 70% 50%,rgba(20,163,168,.06),transparent 60%);
  animation:flt 8s ease-in-out infinite;
}
.pquote .pq-mark{
  font-family:var(--serif);font-size:120px;
  line-height:.8;opacity:.1;
  position:absolute;top:20px;left:50%;
  transform:translateX(-50%);
}
.pquote blockquote{
  font-family:var(--serif);font-size:32px;
  font-weight:700;line-height:1.4;
  max-width:700px;margin:0 auto;
  position:relative;z-index:1;
  letter-spacing:-.5px;
}
.pquote cite{
  display:block;margin-top:20px;
  font-size:14px;font-style:normal;
  color:var(--coral-soft);
  position:relative;z-index:1;
  letter-spacing:2px;
}

/* ===== DECORATIVE SHAPES ===== */
.deco-circle{
  position:absolute;border-radius:50%;
  border:1px solid var(--paper-dark);
  pointer-events:none;opacity:.3;
}
.deco-line{
  position:absolute;
  height:1px;background:var(--paper-dark);
  pointer-events:none;opacity:.2;
}
.deco-dots{
  position:absolute;
  width:60px;height:60px;
  background-image:radial-gradient(circle,var(--paper-dark) 1px,transparent 1px);
  background-size:8px 8px;
  pointer-events:none;opacity:.4;
}

/* ===== FLOATING BADGE ===== */
.float-badge{
  position:absolute;
  padding:8px 16px 8px 12px;
  background:var(--ink);color:var(--cream);
  font-size:11px;font-weight:600;
  letter-spacing:.5px;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 50%,calc(100% - 10px) 100%,0 100%,10px 50%);
  animation:flt 4s ease-in-out infinite;
  z-index:3;
}
.float-badge .fb-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;
  background:var(--coral);border-radius:4px;
  font-size:10px;margin-right:6px;
  vertical-align:middle;
}

/* ===== SECTION NUMBER ===== */
.sec-num{
  font-family:var(--serif);font-size:72px;
  font-weight:900;color:var(--paper);
  line-height:1;letter-spacing:-3px;
  position:absolute;top:20px;right:20px;
  pointer-events:none;user-select:none;z-index:0;
}

/* ===== CARD GLOW ===== */
.card-glow{
  position:relative;overflow:hidden;
}
.card-glow::after{
  content:'';position:absolute;
  top:var(--glow-y,50%);left:var(--glow-x,50%);
  width:200px;height:200px;
  background:radial-gradient(circle,var(--coral-glow),transparent 70%);
  transform:translate(-50%,-50%);
  opacity:0;transition:opacity .3s;
  pointer-events:none;
}
.card-glow:hover::after{opacity:1}

/* ===== SKELETON LOADING ===== */
.skeleton{
  background:linear-gradient(90deg,var(--paper) 25%,var(--paper-dark) 50%,var(--paper) 75%);
  background-size:200% 100%;
  animation:shimmer 1.5s infinite;
  border-radius:8px;
}

/* ===== MAGNETIC BUTTON ===== */
.mag-btn{
  position:relative;
  transition:transform .2s ease;
}

/* ===== WAVE DIVIDER ===== */
.wave-divider{
  width:100%;height:40px;overflow:hidden;
  position:relative;
}
.wave-divider svg{width:100%;height:100%;display:block}

/* ===== BENTO GRID ===== */
.bento{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto;
  gap:14px;
}
.bento-item{
  border-radius:20px;overflow:hidden;
  background:var(--white);
  border:1px solid var(--paper);
  transition:var(--t);
  padding:20px;
}
.bento-item:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(26,35,50,.06)}
.bento-span-2{grid-column:span 2}
.bento-span-3{grid-column:span 3}
.bento-row-2{grid-row:span 2}

/* ===== COUNTER ANIMATION ===== */
.counter{font-variant-numeric:tabular-nums}

/* ===== TOOLTIP ===== */
.tip{position:relative;cursor:pointer}
.tip::after{
  content:attr(data-tip);
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(4px);
  padding:6px 12px;
  background:var(--ink);color:var(--cream);
  border-radius:8px;font-size:11px;white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:var(--t);
}
.tip:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== STAGGER CHILDREN ===== */
.stagger > *{opacity:0;transform:translateY(20px);animation:fadeUp .5s ease forwards}
.stagger > *:nth-child(1){animation-delay:.05s}
.stagger > *:nth-child(2){animation-delay:.1s}
.stagger > *:nth-child(3){animation-delay:.15s}
.stagger > *:nth-child(4){animation-delay:.2s}
.stagger > *:nth-child(5){animation-delay:.25s}
.stagger > *:nth-child(6){animation-delay:.3s}
.stagger > *:nth-child(7){animation-delay:.35s}
.stagger > *:nth-child(8){animation-delay:.4s}
.stagger > *:nth-child(9){animation-delay:.45s}
.stagger > *:nth-child(10){animation-delay:.5s}

/* ===== RESPONSIVE ADDITIONS ===== */
@media(max-width:900px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-span-2,.bento-span-3{grid-column:span 2}
  .pquote blockquote{font-size:24px}
}
@media(max-width:768px){
  .marquee{font-size:11px;padding:10px 0}
  .pquote{padding:48px 16px}
  .pquote blockquote{font-size:20px}
  .bento{grid-template-columns:1fr}
  .bento-span-2,.bento-span-3{grid-column:span 1}
}
@media(max-width:480px){
  .pquote blockquote{font-size:18px}
}