

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=IBM+Plex+Mono:wght@400;500&family=Syne:wght@400;500;600;700;800&display=swap');

/* ─── TOKENS ─── */
:root {
  --bg:         #f5f2ec;
  --bg-card:    #ffffff;
  --bg-muted:   #eeebe4;
  --bg-deep:    #e8e4dc;

  --ink:        #0d0b08;
  --ink2:       #47423b;
  --ink3:       #9b958d;
  --ink4:       #c8c3bc;

  --p1:         #4f1fb8;
  --p2:         #b31558;
  --p3:         #0258a0;
  --p4:         #036b4a;
  --p5:         #a34907;
  --acc:        #4f1fb8;

  --bdr:        rgba(0,0,0,.09);
  --bdr2:       rgba(0,0,0,.06);
  --bdr-white:  rgba(255,255,255,.85);

  --s1: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --s2: 0 4px 12px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
  --s3: 0 8px 28px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.05);
  --s4: 0 16px 48px rgba(0,0,0,.12), 0 4px 14px rgba(0,0,0,.06);

  --fd: 'Syne', sans-serif;
  --fs: 'Instrument Serif', serif;
  --fm: 'IBM Plex Mono', monospace;

  --ease:   cubic-bezier(.16,1,.3,1);
  --spring: cubic-bezier(.34,1.56,.64,1);

  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 26px;
}

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth }
body {
  font-family: var(--fd);
  background: var(--bg);
  color: var(--ink);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ─── SUBTLE PAGE TINTING ─── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 55% at 0% 0%,   rgba(79,31,184,.055) 0%, transparent 65%),
    radial-gradient(ellipse 50% 40% at 100% 100%, rgba(2,88,160,.045) 0%, transparent 65%),
    radial-gradient(ellipse 40% 30% at 55% 50%,  rgba(179,21,88,.028) 0%, transparent 70%);
}

/* Disable heavy effects */
#bgc, .aurora, .shards, .trail-dot { display: none !important }
#cur, #ci, #co, #ct { display: none !important }

.page { position: relative; z-index: 2 }

/* ─── ANIMATIONS ─── */
@keyframes fade-up   { from { opacity:0; transform:translateY(16px) } to { opacity:1; transform:none } }
@keyframes fade-in   { from { opacity:0 } to { opacity:1 } }
@keyframes slide-l   { from { opacity:0; transform:translateX(-16px) } to { opacity:1; transform:none } }
@keyframes dot-pulse {
  0%   { box-shadow: 0 0 0 0 currentColor }
  70%  { box-shadow: 0 0 0 7px transparent }
  100% { box-shadow: 0 0 0 0 transparent }
}
@keyframes gem-spin  { to { transform: rotate(360deg) } }
@keyframes gem-pulse { 0%,100%{transform:scale(.94);opacity:.55} 50%{transform:scale(1.08);opacity:.9} }
@keyframes bar-load  { from { width:0 } to { width:100% } }
@keyframes stripe-shimmer {
  0%   { background-position: 200% 0 }
  100% { background-position: -200% 0 }
}

/* ═══════════════════════════════════════════════════
   LOADER
═══════════════════════════════════════════════════ */
.loader {
  position: fixed; inset: 0; z-index: 9500;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1.4rem; background: var(--bg);
}
.loader-gem { animation: fade-up .7s var(--spring) .1s both }
.loader-name {
  font-family: var(--fd); font-weight: 800; font-size: 1.4rem; letter-spacing: -.025em;
  background: linear-gradient(120deg, var(--p1) 0%, var(--p2) 45%, var(--p3) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: fade-in .4s .5s both;
}
.loader-track {
  width: 140px; height: 2px; background: var(--bdr); border-radius: 2px; overflow: hidden;
  animation: fade-in .3s .7s both;
}
.loader-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--p1), var(--p2), var(--p3));
  animation: bar-load .85s var(--ease) .8s both;
}

/* ═══════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════════ */
nav {
  position: sticky; top: 0; z-index: 500;
  height: 64px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 3rem;
  background: rgba(245,242,236,.94);
  backdrop-filter: blur(28px) saturate(200%);
  border-bottom: 1px solid var(--bdr);
}

.nav-prism {
  position: absolute; bottom: -1px; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--p1) 20%, var(--p2) 45%, var(--p3) 70%, var(--p4) 88%,
    transparent 100%);
  background-size: 300% 100%;
  animation: stripe-shimmer 5s linear infinite;
  opacity: .5;
}

.logo {
  font-family: var(--fd); font-weight: 800; font-size: 1rem; letter-spacing: -.025em;
  color: var(--ink); text-decoration: none;
  display: flex; align-items: center; gap: 10px;
  transition: opacity .2s;
}
.logo:hover { opacity: .7 }
.lgw { position: relative; width: 30px; height: 30px; flex-shrink: 0 }
.lgw svg { position: absolute; inset: 0 }
.lga { animation: gem-spin 15s linear infinite }
.lgb { animation: gem-spin  9s linear infinite reverse }
.lgc { animation: gem-spin 24s linear infinite }

.nl { display: flex; gap: 2px; list-style: none }
.nl a {
  font-family: var(--fm); font-size: .62rem; letter-spacing: .06em;
  color: var(--ink3); text-decoration: none;
  padding: 6px 13px; border-radius: var(--r-sm);
  transition: color .18s, background .18s;
}
.nl a:hover { color: var(--ink); background: rgba(0,0,0,.05) }
.nl a.on   { color: var(--acc); font-weight: 500 }

.nav-r { display: flex; align-items: center; gap: 7px }
.nav-gh {
  font-family: var(--fm); font-size: .61rem; letter-spacing: .05em;
  padding: 6px 13px; border-radius: var(--r-sm);
  border: 1px solid var(--bdr);
  background: rgba(255,255,255,.7);
  color: var(--ink2); cursor: pointer; transition: all .2s;
  text-decoration: none; display: flex; align-items: center; gap: 6px;
}
.nav-gh:hover {
  background: rgba(255,255,255,.98); color: var(--ink);
  box-shadow: var(--s1); transform: translateY(-1px);
}
.magw { position: relative; display: inline-block }
.ncta {
  font-family: var(--fm); font-size: .62rem; letter-spacing: .05em;
  padding: 7px 18px; border-radius: var(--r-sm);
  background: var(--ink); color: #fff; border: none; cursor: pointer;
  transition: all .22s; box-shadow: var(--s1);
}
.ncta:hover {
  background: var(--p1);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(79,31,184,.38);
}
.ncta span { position: relative; z-index: 1 }

/* ═══════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════ */
.hero {
  display: grid; grid-template-columns: 1.15fr 1fr;
  min-height: calc(100vh - 64px); overflow: hidden;
}

.hero-l {
  display: flex; flex-direction: column; justify-content: center;
  padding: 5rem 3.5rem 5rem 6rem; position: relative;
}

.hero-stripe {
  position: absolute; top: 12%; left: 3.5rem; bottom: 12%; width: 2px;
  background: linear-gradient(to bottom,
    transparent,
    var(--p1) 25%, var(--p2) 55%, var(--p3) 82%,
    transparent);
  opacity: .2; border-radius: 2px;
}

.ep {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.95);
  border-radius: 100px; padding: 5px 16px; margin-bottom: 2rem;
  box-shadow: var(--s1);
  font-family: var(--fm); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink3); width: fit-content;
  animation: slide-l .6s .1s var(--ease) both;
}
.ep-live {
  width: 6px; height: 6px; border-radius: 50%; background: var(--p4); flex-shrink: 0;
  color: rgba(3,107,74,.6); animation: dot-pulse 2s ease-out infinite;
}
.ep-sep { width: 1px; height: 10px; background: var(--bdr) }

.hero-h1 {
  font-family: var(--fs); font-style: italic;
  font-size: clamp(3.6rem, 6.8vw, 7rem);
  line-height: .9; letter-spacing: -.02em; margin-bottom: .85rem;
}
.h1-row { display: block; overflow: hidden; padding-bottom: .06em }
.let { display: inline-block; animation: fade-up .5s var(--ease) both }
.let-inner {
  display: block;
  background: linear-gradient(128deg,
    var(--p1) 0%, var(--p2) 35%, var(--p3) 65%, var(--p4) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.let-shine { display: none }
.space-let { display: inline-block; width: .26em }

.hero-tag {
  font-family: var(--fd); font-size: clamp(1.1rem, 2vw, 1.6rem); font-weight: 600;
  color: var(--ink); letter-spacing: -.018em; line-height: 1.28;
  margin-bottom: .9rem;
  animation: fade-up .6s .85s var(--ease) both;
}
.hero-body {
  font-family: var(--fd); font-size: .89rem; color: var(--ink2);
  line-height: 1.82; max-width: 400px; margin-bottom: 2.2rem;
  font-weight: 400; animation: fade-up .6s .95s var(--ease) both;
}
.hero-body em { color: var(--acc); font-style: normal; font-weight: 600 }

.srch-wrap {
  max-width: 445px; margin-bottom: 1.8rem;
  animation: fade-up .6s 1.05s var(--ease) both;
}
.srch-glow { display: none }
.srch-box {
  display: flex; align-items: center;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(0,0,0,.1);
  border-radius: var(--r-md); padding: 4px 4px 4px 15px;
  box-shadow: var(--s2);
  transition: box-shadow .25s, border-color .25s;
}
.srch-wrap:focus-within .srch-box {
  box-shadow: var(--s3), 0 0 0 3px rgba(79,31,184,.11);
  border-color: rgba(79,31,184,.28);
}
.srch-box input {
  flex: 1; background: transparent; border: none; outline: none;
  font-family: var(--fd); font-size: .88rem; color: var(--ink); font-weight: 500;
}
.srch-box input::placeholder { color: var(--ink3); font-weight: 400 }
.sbtn {
  background: var(--ink); color: #fff; border: none;
  padding: 9px 19px; border-radius: 10px;
  font-family: var(--fm); font-size: .62rem; letter-spacing: .06em;
  cursor: pointer; transition: all .22s;
  display: flex; align-items: center; gap: 5px;
}
.sbtn:hover { background: var(--p1); transform: translateY(-1px) }
.sbtn span, .sbtn svg { position: relative; z-index: 1 }

.chips { display: flex; flex-wrap: wrap; gap: 6px; animation: fade-up .6s 1.15s var(--ease) both }
.chip {
  font-family: var(--fm); font-size: .57rem; letter-spacing: .07em;
  color: var(--ink3); border: 1px solid var(--bdr);
  border-radius: 100px; padding: 5px 13px; cursor: pointer;
  background: rgba(255,255,255,.65);
  transition: all .2s;
}
.chip:hover, .chip.on {
  background: rgba(255,255,255,.98); color: var(--acc);
  border-color: rgba(79,31,184,.28); transform: translateY(-1px);
  box-shadow: var(--s1), 0 0 0 3px rgba(79,31,184,.07);
}
.chip.on { font-weight: 500 }

.hero-r {
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  padding: 2.5rem 5rem 2.5rem 2rem; gap: 1.5rem;
}

/* Gem */
.gem-sys { position: relative; width: 240px; height: 240px; flex-shrink: 0 }
.gem-halo { position: absolute; border-radius: 50%; animation: gem-spin linear infinite }
.gh1 { inset:-14px; border:1px solid rgba(79,31,184,.14); animation-duration:14s }
.gh2 { inset:-28px; border:1px solid rgba(179,21,88,.09); animation-duration:22s; animation-direction:reverse }
.gh3 { inset:-44px; border:1px solid rgba(2,88,160,.06); animation-duration:34s }
.gh4 { inset:-60px; border:1px solid rgba(3,107,74,.04); animation-duration:48s; animation-direction:reverse }
.gem-halo::before, .gem-halo::after {
  content:''; position:absolute; border-radius:50%;
  width:6px; height:6px; margin-left:-3px; top:-3px; left:50%;
}
.gh1::before { background:var(--p1); box-shadow:0 0 10px rgba(79,31,184,.8) }
.gh1::after  { bottom:-3px; top:auto; background:var(--p2); box-shadow:0 0 8px rgba(179,21,88,.7); width:5px; height:5px; margin-left:-2.5px }
.gh2::before { background:var(--p2); box-shadow:0 0 10px rgba(179,21,88,.8) }
.gh3::before { background:var(--p3); box-shadow:0 0 8px rgba(2,88,160,.7) }
.gh4::before { background:var(--p4); box-shadow:0 0 8px rgba(3,107,74,.7); width:5px; height:5px; margin-left:-2.5px; top:-2.5px }
.gem-main { width:240px; height:240px; animation:gem-spin 28s linear infinite; position:relative; z-index:2 }
.gem-glow {
  position:absolute; inset:20px; border-radius:50%;
  background:radial-gradient(circle, rgba(79,31,184,.14), rgba(179,21,88,.08), transparent 65%);
  animation:gem-pulse 4s ease-in-out infinite; z-index:1;
}

/* Glass stat cards */
.gcard {
  width: 100%; max-width: 355px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.94);
  border-radius: var(--r-lg);
  padding: 1.4rem 1.6rem;
  box-shadow: var(--s2);
  transition: transform .3s var(--ease), box-shadow .3s;
  animation: fade-up .6s var(--ease) both;
  position: relative; overflow: hidden;
}
.gcard::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--p1), var(--p2), var(--p3));
  opacity: 0; transition: opacity .3s;
}
.gcard:hover { transform: translateY(-4px); box-shadow: var(--s3) }
.gcard:hover::before { opacity: 1 }
.gc1 { animation-delay: .5s } .gc2 { animation-delay: .65s }

.gc-hd { display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem }
.gc-lbl { font-family:var(--fm); font-size:.54rem; letter-spacing:.18em; color:var(--ink3); text-transform:uppercase }
.lpill {
  display:flex; align-items:center; gap:5px;
  font-family:var(--fm); font-size:.53rem; letter-spacing:.05em;
  padding:3px 9px; border-radius:20px;
  background:rgba(3,107,74,.08); color:var(--p4);
  border:1px solid rgba(3,107,74,.18);
}
.lpdot { width:5px; height:5px; border-radius:50%; background:var(--p4); color:rgba(3,107,74,.6); animation:dot-pulse 2.2s infinite }
.stat-row { display:flex; border-radius:10px; overflow:hidden; border:1px solid var(--bdr2) }
.sc { flex:1; padding:.8rem .9rem; text-align:center; background:rgba(255,255,255,.5); border-right:1px solid var(--bdr2) }
.sc:last-child { border-right:none }
.sn {
  font-family:var(--fs); font-style:italic; font-size:1.55rem; line-height:1; margin-bottom:3px;
  background:linear-gradient(135deg,var(--p1),var(--p2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.sl { font-family:var(--fm); font-size:.49rem; letter-spacing:.13em; color:var(--ink3); text-transform:uppercase }

.tr-list { display:flex; flex-direction:column }
.tr-i { display:flex; align-items:center; gap:9px; padding:7px 0; border-bottom:1px solid var(--bdr2); cursor:pointer; transition:all .18s }
.tr-i:last-child { border-bottom:none; padding-bottom:0 }
.tr-i:hover { opacity:.62; transform:translateX(3px) }
.tr-n { font-family:var(--fm); font-size:.56rem; color:var(--ink4); min-width:15px }
.tr-t { font-family:var(--fd); font-size:.81rem; font-weight:500; color:var(--ink); flex:1; line-height:1.35 }
.tr-b { font-family:var(--fm); font-size:.51rem; letter-spacing:.05em; padding:2px 7px; border-radius:6px; border:1px solid var(--bdr); color:var(--ink3); background:rgba(255,255,255,.65); white-space:nowrap }

/* ═══════════════════════════════════════════════════
   DIVIDER
═══════════════════════════════════════════════════ */
.odiv { display:flex; align-items:center; gap:12px; padding:0 6rem; position:relative; z-index:2; margin:.5rem 0 }
.odl { flex:1; height:1px; background:linear-gradient(90deg,transparent,var(--bdr),transparent) }
.odc { display:flex; align-items:center; gap:6px; flex-shrink:0 }
.odg { width:16px; height:16px }
.odd { width:4px; height:4px; border-radius:50%; animation:dot-pulse 2.5s ease-out infinite }
.odd1{background:var(--p1);color:rgba(79,31,184,.6)}
.odd2{background:var(--p2);color:rgba(179,21,88,.6);animation-delay:.5s}
.odd3{background:var(--p3);color:rgba(2,88,160,.6);animation-delay:1s}
.odd4{background:var(--p4);color:rgba(3,107,74,.6);animation-delay:1.5s}

/* ═══════════════════════════════════════════════════
   CATEGORY PILLS
═══════════════════════════════════════════════════ */
.cat-zone { padding:2.5rem 6rem 2rem; position:relative; z-index:2 }
.zone-ey { display:flex; align-items:center; gap:8px; font-family:var(--fm); font-size:.55rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink3); margin-bottom:1.1rem }
.zone-ey::before { content:''; width:12px; height:1px; background:currentColor }
.cpills { display:flex; flex-wrap:wrap; gap:7px }
.cpill {
  font-family:var(--fm); font-size:.59rem; letter-spacing:.05em; color:var(--ink2);
  border:1px solid var(--bdr); border-radius:100px; padding:6px 16px; cursor:pointer;
  background:rgba(255,255,255,.65); transition:all .22s; display:flex; align-items:center; gap:6px;
  box-shadow: var(--s1);
}
.cpill:hover { transform:translateY(-2px); color:var(--acc); border-color:rgba(79,31,184,.26); box-shadow:var(--s2), 0 0 0 3px rgba(79,31,184,.06); background:rgba(255,255,255,.9) }
.cpill.on { background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); box-shadow:var(--s2) }
.cp-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0 }
.cp-n { font-size:.49rem; padding:1px 6px; border-radius:6px; background:rgba(0,0,0,.07) }
.cpill.on .cp-n { background:rgba(255,255,255,.2) }

/* ═══════════════════════════════════════════════════
   FEATURED ARTICLE
═══════════════════════════════════════════════════ */
.feat-zone { padding:0 6rem 3rem; position:relative; z-index:2 }
.fey { display:flex; align-items:center; gap:9px; font-family:var(--fm); font-size:.55rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink3); margin-bottom:1.5rem }
.fey-line { flex:1; height:1px; background:linear-gradient(to right, var(--bdr), transparent) }
.fey-dot { width:6px; height:6px; border-radius:50%; background:var(--p5); box-shadow:0 0 6px rgba(163,73,7,.45); color:rgba(163,73,7,.6); animation:dot-pulse 2.2s ease-out infinite }

.featured {
  display:grid; grid-template-columns:1.15fr 1fr;
  border-radius:var(--r-xl); overflow:hidden;
  border:1px solid rgba(255,255,255,.88);
  background:rgba(255,255,255,.72);
  box-shadow:var(--s3);
  cursor:pointer; position:relative;
  transition:transform .42s var(--ease), box-shadow .42s;
  animation:fade-up .7s .2s var(--ease) both;
}
.featured::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2.5px; z-index:10;
  background:linear-gradient(90deg, var(--p1), var(--p2), var(--p3), var(--p4));
  background-size:200% 100%; animation:stripe-shimmer 4s linear infinite;
  opacity:0; transition:opacity .3s;
}
.featured:hover::after { opacity:1 }
.featured:hover { transform:translateY(-6px); box-shadow:var(--s4) }

.fi { position:relative; overflow:hidden; min-height:420px }
.fi img { width:100%; height:100%; object-fit:cover; transition:transform .85s var(--ease) }
.featured:hover .fi img { transform:scale(1.06) }
.fi-ov {
  position:absolute; inset:0;
  background:linear-gradient(to right, transparent 30%, rgba(245,242,236,.48) 100%),
             linear-gradient(to top, rgba(245,242,236,.22) 0%, transparent 28%);
}
.fi-gloss { display:none }
.fi-stamp { position:absolute; top:14px; left:14px; display:flex; align-items:center; gap:5px; background:rgba(255,255,255,.9); border:1px solid rgba(255,255,255,.96); padding:4px 12px; border-radius:100px; font-family:var(--fm); font-size:.59rem; letter-spacing:.05em; color:var(--ink); box-shadow:var(--s1) }
.fi-star { color:var(--p5) }

.fb { padding:2.6rem; display:flex; flex-direction:column; justify-content:space-between }
.pmeta { display:flex; align-items:center; gap:6px; margin-bottom:1.1rem; flex-wrap:wrap }
.lchip { font-family:var(--fm); font-size:.57rem; letter-spacing:.05em; padding:3px 11px; border-radius:100px }
.ms { color:var(--ink3) }
.md { font-family:var(--fm); font-size:.68rem; color:var(--ink2) }
.fb h2 { font-family:var(--fd); font-size:1.7rem; font-weight:700; line-height:1.18; letter-spacing:-.022em; margin-bottom:.95rem; color:var(--ink) }
.fb p { font-family:var(--fd); font-size:.88rem; color:var(--ink2); line-height:1.82; margin-bottom:1.9rem; flex:1; font-weight:400 }
.fb-foot { display:flex; align-items:center; justify-content:space-between }
.auth { display:flex; align-items:center; gap:10px }
.auth-av { width:38px; height:38px; border-radius:50%; object-fit:cover; border:2px solid rgba(255,255,255,.96); box-shadow:0 0 0 2px rgba(79,31,184,.15), var(--s1); transition:transform .28s, box-shadow .28s }
.featured:hover .auth-av { transform:scale(1.07); box-shadow:0 0 0 2px rgba(79,31,184,.32), var(--s2) }
.anm { font-family:var(--fd); font-size:.84rem; font-weight:600; color:var(--ink) }
.arl { font-family:var(--fm); font-size:.57rem; color:var(--ink3); margin-top:2px }

.rbtn { display:flex; align-items:center; gap:6px; background:var(--ink); color:#fff; border:none; padding:11px 22px; border-radius:var(--r-sm); font-family:var(--fm); font-size:.65rem; letter-spacing:.05em; cursor:pointer; transition:all .26s; box-shadow:var(--s1); text-decoration:none }
.rbtn:hover { background:var(--p1); transform:translateY(-2px); box-shadow:0 6px 22px rgba(79,31,184,.4) }
.rbtn svg { transition:transform .2s }
.rbtn:hover svg { transform:translateX(4px) }
.rbtn span { position:relative; z-index:1 }

/* ═══════════════════════════════════════════════════
   CONTENT AREA
═══════════════════════════════════════════════════ */
.content-area { padding:0 6rem 6rem; position:relative; z-index:2; display:grid; grid-template-columns:1fr 310px; gap:2.5rem }
.sec-hd { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.7rem }
.sec-ttl { font-family:var(--fd); font-size:1.12rem; font-weight:700; letter-spacing:-.02em; display:flex; align-items:center; gap:8px }
.cnt-b { font-family:var(--fm); font-size:.53rem; background:rgba(0,0,0,.06); border:1px solid var(--bdr); color:var(--ink3); padding:2px 8px; border-radius:6px }
.sa { font-family:var(--fm); font-size:.61rem; letter-spacing:.04em; color:var(--ink2); text-decoration:none; display:flex; align-items:center; gap:4px; transition:all .2s }
.sa:hover { color:var(--acc); gap:8px }

.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(262px,1fr)); gap:14px; margin-bottom:2rem }

.card {
  background:rgba(255,255,255,.74);
  border:1px solid rgba(255,255,255,.92);
  border-radius:var(--r-lg); overflow:hidden; cursor:pointer;
  display:flex; flex-direction:column;
  box-shadow:var(--s2); position:relative;
  transition:transform .32s var(--ease), box-shadow .32s, border-color .32s;
  animation:fade-up .5s var(--ease) both;
}
.c-refract, .c-bar { display:none }

.card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; z-index:5; background:linear-gradient(90deg, var(--p1), var(--p2), var(--p3)); opacity:0; transition:opacity .25s }
.card:hover { transform:translateY(-5px); box-shadow:var(--s3) }
.card:hover::before { opacity:1 }

.ct { height:188px; overflow:hidden; position:relative; flex-shrink:0 }
.ct img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease) }
.card:hover .ct img { transform:scale(1.07) }
.ct-fade { position:absolute; bottom:0; left:0; right:0; height:64px; background:linear-gradient(to top,rgba(245,242,236,.92),transparent) }
.ct-gloss { display:none }
.c-chip { position:absolute; top:10px; left:10px; font-family:var(--fm); font-size:.54rem; letter-spacing:.05em; padding:3px 9px; border-radius:7px; background:rgba(255,255,255,.9); border:1px solid rgba(255,255,255,.96); box-shadow:var(--s1) }

.cb { padding:1.25rem; display:flex; flex-direction:column; flex:1 }
.crow { display:flex; align-items:center; justify-content:space-between; margin-bottom:.5rem }
.cdate { font-family:var(--fm); font-size:.57rem; color:var(--ink3) }
.cviews { font-family:var(--fm); font-size:.57rem; color:var(--ink3); display:flex; align-items:center; gap:4px }
.cttl { font-family:var(--fd); font-size:.96rem; font-weight:600; line-height:1.35; margin-bottom:.42rem; color:var(--ink); letter-spacing:-.012em; transition:color .2s }
.card:hover .cttl { color:var(--acc) }
.cexc { font-family:var(--fd); font-size:.8rem; color:var(--ink2); line-height:1.72; margin-bottom:.95rem; flex:1; display:-webkit-box; -webkit-box-orient:vertical; overflow:hidden; font-weight:400 }
.cfoot { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--bdr2); padding-top:.85rem }
.cauth { display:flex; align-items:center; gap:6px }
.cav { width:25px; height:25px; border-radius:50%; object-fit:cover; border:1.5px solid rgba(255,255,255,.9); box-shadow:0 0 0 1.5px rgba(79,31,184,.12) }
.canm { font-family:var(--fd); font-size:.73rem; font-weight:500; color:var(--ink2) }
.ccta { display:flex; align-items:center; gap:4px; font-family:var(--fm); font-size:.58rem; letter-spacing:.04em; color:var(--ink2); background:rgba(255,255,255,.7); border:1px solid var(--bdr); padding:5px 11px; border-radius:7px; cursor:pointer; transition:all .2s }
.ccta:hover { color:var(--acc); border-color:rgba(79,31,184,.25); transform:translateY(-1px) }
.ccta svg { transition:transform .2s }
.ccta:hover svg { transform:translateX(3px) }

.card.wide { grid-column:span 2; flex-direction:row }
.card.wide .ct { width:38%; height:auto; flex-shrink:0 }
.card.wide .cttl { font-size:1.08rem }

.lm-zone { text-align:center; padding:1.5rem 0 .5rem }
.lmbtn { font-family:var(--fm); font-size:.63rem; letter-spacing:.06em; color:var(--ink2); background:rgba(255,255,255,.72); border:1px solid var(--bdr); padding:11px 30px; border-radius:100px; cursor:pointer; transition:all .22s; display:inline-flex; align-items:center; gap:7px; box-shadow:var(--s1) }
.lmbtn:hover { color:var(--acc); border-color:rgba(79,31,184,.26); transform:translateY(-2px); box-shadow:var(--s2); background:rgba(255,255,255,.96) }

/* ═══════════════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════════════ */
.sw { background:rgba(255,255,255,.72); border:1px solid rgba(255,255,255,.92); border-radius:var(--r-lg); padding:1.35rem 1.45rem; margin-bottom:1.2rem; box-shadow:var(--s2); position:relative; overflow:hidden; transition:transform .28s var(--ease), box-shadow .28s }
.sw::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, var(--p1), var(--p2), var(--p3)); opacity:0; transition:opacity .28s }
.sw:hover { transform:translateY(-2px); box-shadow:var(--s3) }
.sw:hover::before { opacity:1 }
.sw-hd { font-family:var(--fm); font-size:.54rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink3); margin-bottom:1rem; display:flex; align-items:center; gap:6px }

.nw-sw { background:linear-gradient(148deg, rgba(188,170,248,.22), rgba(247,200,220,.17), rgba(154,232,246,.14)); border:1px solid rgba(255,255,255,.88); border-radius:var(--r-lg); padding:1.55rem 1.45rem; margin-bottom:1.2rem; box-shadow:var(--s2); position:relative; overflow:hidden }
.nw-sw::before { content:''; position:absolute; top:-60px; right:-60px; width:180px; height:180px; background:radial-gradient(circle, rgba(79,31,184,.12), transparent 65%); pointer-events:none }
.nw-ico { width:42px; height:42px; border-radius:10px; background:linear-gradient(135deg,rgba(79,31,184,.13),rgba(179,21,88,.08)); border:1px solid rgba(79,31,184,.18); display:flex; align-items:center; justify-content:center; margin-bottom:.8rem; font-size:20px; position:relative; z-index:1 }
.nw-title { font-family:var(--fd); font-size:.96rem; font-weight:700; margin-bottom:.4rem; letter-spacing:-.014em; position:relative; z-index:1 }
.nw-sub { font-family:var(--fd); font-size:.77rem; color:var(--ink2); line-height:1.65; margin-bottom:1rem; font-weight:400; position:relative; z-index:1 }
.nw-in { width:100%; background:rgba(255,255,255,.82); border:1px solid var(--bdr); color:var(--ink); padding:9px 13px; border-radius:8px; font-family:var(--fd); font-size:.83rem; outline:none; margin-bottom:6px; font-weight:500; transition:border-color .2s, box-shadow .2s; position:relative; z-index:1 }
.nw-in::placeholder { color:var(--ink3); font-weight:400 }
.nw-in:focus { border-color:rgba(79,31,184,.32); box-shadow:0 0 0 3px rgba(79,31,184,.08) }
.nw-btn { width:100%; background:var(--ink); color:#fff; border:none; padding:10px; border-radius:8px; font-family:var(--fm); font-size:.63rem; letter-spacing:.06em; cursor:pointer; transition:all .22s; position:relative; z-index:1; box-shadow:var(--s1) }
.nw-btn:hover { background:var(--p1); transform:translateY(-1px); box-shadow:0 5px 18px rgba(79,31,184,.38) }

.act-g { display:grid; grid-template-columns:repeat(7,1fr); gap:3px; margin-top:.5rem }
.ac { aspect-ratio:1; border-radius:2px; background:rgba(0,0,0,.06); cursor:pointer; transition:transform .14s }
.ac:hover { transform:scale(1.55) }
.ac.l1{background:rgba(79,31,184,.17)} .ac.l2{background:rgba(79,31,184,.36)}
.ac.l3{background:rgba(79,31,184,.57)} .ac.l4{background:var(--p1);box-shadow:0 0 4px rgba(79,31,184,.42)}
.act-leg { display:flex; align-items:center; gap:4px; margin-top:7px; font-family:var(--fm); font-size:.52rem; color:var(--ink3) }
.ald { display:flex; gap:2px }
.aldd { width:8px; height:8px; border-radius:2px }

.tag-cloud { display:flex; flex-wrap:wrap; gap:5px }
.tag { font-family:var(--fm); font-size:.57rem; letter-spacing:.05em; background:rgba(255,255,255,.62); border:1px solid var(--bdr); color:var(--ink3); padding:5px 12px; border-radius:100px; cursor:pointer; transition:all .2s; text-decoration:none; display:inline-block }
.tag:hover { border-color:rgba(79,31,184,.26); color:var(--acc); background:rgba(79,31,184,.06); transform:translateY(-1px) }

/* ═══════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════ */
footer { position:relative; z-index:2; background:rgba(218,213,202,.92); border-top:1px solid var(--bdr); padding:3.2rem 6rem 2.2rem }
.ft-sh { position:absolute; top:0; left:0; right:0; height:1.5px; background:linear-gradient(90deg, transparent, var(--p1), var(--p2), var(--p3), var(--p4), transparent); opacity:.4 }
.ft-grid { display:grid; grid-template-columns:1.7fr repeat(3,1fr); gap:3rem; margin-bottom:2.5rem }
.ft-logo { font-family:var(--fd); font-weight:800; font-size:.98rem; letter-spacing:-.022em; color:var(--ink); text-decoration:none; display:flex; align-items:center; gap:8px; margin-bottom:.85rem }
.ft-desc { font-family:var(--fd); font-size:.78rem; color:var(--ink2); line-height:1.72; max-width:215px; font-weight:400 }
.ft-hd { font-family:var(--fm); font-size:.53rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink3); margin-bottom:.85rem }
.ft-col a { display:block; font-family:var(--fd); font-size:.82rem; color:var(--ink2); text-decoration:none; margin-bottom:.5rem; transition:all .18s; width:max-content; font-weight:400 }
.ft-col a:hover { color:var(--ink); transform:translateX(3px) }
.ft-bot { display:flex; align-items:center; justify-content:space-between; padding-top:1.5rem; border-top:1px solid var(--bdr); flex-wrap:wrap; gap:1rem }
.ft-copy { font-family:var(--fm); font-size:.6rem; color:var(--ink3) }
.ft-chips { display:flex; gap:5px }
.ft-chip { font-family:var(--fm); font-size:.53rem; background:rgba(255,255,255,.5); border:1px solid var(--bdr); color:var(--ink3); padding:3px 9px; border-radius:6px }

/* ─── CATEGORY CHIP COLORS ─── */
.cjs{color:#92400e;background:rgba(251,191,36,.14);border-color:rgba(251,191,36,.28)}
.cts{color:#0e7490;background:rgba(8,145,178,.12);border-color:rgba(8,145,178,.26)}
.cpy{color:#065f46;background:rgba(5,150,105,.11);border-color:rgba(5,150,105,.25)}
.cre{color:#0c4a6e;background:rgba(14,165,233,.1);border-color:rgba(14,165,233,.23)}
.ccs{color:#3b0764;background:rgba(79,31,184,.1);border-color:rgba(79,31,184,.23)}
.cwb{color:#881337;background:rgba(244,63,94,.1);border-color:rgba(244,63,94,.23)}
.cdo{color:#7c2d12;background:rgba(234,88,12,.1);border-color:rgba(234,88,12,.23)}
.cca{color:#831843;background:rgba(219,39,119,.1);border-color:rgba(219,39,119,.23)}
.cai{color:#3b0764;background:rgba(79,31,184,.1);border-color:rgba(79,31,184,.23)}

/* ═══════════════════════════════════════════════════
   FAQ
═══════════════════════════════════════════════════ */
.faq-section { padding:56px 6rem; position:relative; z-index:2 }
.faq-list { background:rgba(255,255,255,.64); border:1px solid rgba(255,255,255,.88); border-radius:var(--r-xl); padding:0 2rem; box-shadow:var(--s2); max-width:820px }
.faq-item { border-bottom:1px solid var(--bdr2); padding:0 }
.faq-item:last-child { border-bottom:none }
.faq-item summary { cursor:pointer; padding:18px 0; font-size:.93rem; font-weight:600; font-family:var(--fd); list-style:none; display:flex; justify-content:space-between; align-items:center; gap:14px; user-select:none; letter-spacing:-.012em; color:var(--ink); transition:color .2s }
.faq-item summary:hover { color:var(--acc) }
.faq-item summary::-webkit-details-marker { display:none }
.faq-chevron { transition:transform .28s var(--ease); flex-shrink:0; color:var(--ink3) }
.faq-item[open] summary .faq-chevron { transform:rotate(180deg); color:var(--acc) }
.faq-item[open] summary { color:var(--acc) }
.faq-answer { padding:0 0 18px; color:var(--ink2); font-size:.87rem; line-height:1.8; font-weight:400 }
.faq-answer a { color:var(--acc); text-decoration:none; border-bottom:1px solid rgba(79,31,184,.28); transition:border-color .2s }
.faq-answer a:hover { border-color:var(--acc) }

/* ─── BREADCRUMB ─── */
.breadcrumb-nav { padding:10px 6rem 0; font-family:var(--fm); font-size:.6rem; color:var(--ink3); display:flex; align-items:center; gap:5px; position:relative; z-index:10 }
.breadcrumb-nav ol { display:flex; align-items:center; gap:5px; list-style:none }
.breadcrumb-nav a { color:var(--ink3); text-decoration:none; transition:color .18s }
.breadcrumb-nav a:hover { color:var(--ink2) }

/* ─── UTILITIES ─── */
.hidden { display:none !important }
.no-res { grid-column:1/-1; text-align:center; padding:5rem 2rem; color:var(--ink3) }
.no-res h3 { font-family:var(--fd); font-weight:600; font-size:1.1rem; color:var(--ink2); margin-bottom:.4rem }

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media(max-width:1100px) {
  .card.wide { grid-column:span 1; flex-direction:column }
  .card.wide .ct { width:100%; height:188px }
}
@media(max-width:960px) {
  .hero { grid-template-columns:1fr }
  .hero-r { display:none }
  .hero-l { padding:2.5rem 2rem }
  nav { padding:0 1.5rem }
  .feat-zone,.cat-zone,.content-area,.odiv,.faq-section,.breadcrumb-nav { padding-left:1.5rem; padding-right:1.5rem }
  .content-area { grid-template-columns:1fr }
  .sidebar { display:none }
  .nl { display:none }
  footer { padding-left:1.5rem; padding-right:1.5rem }
  .ft-grid { grid-template-columns:1fr 1fr }
}
@media(max-width:600px) {
  .blog-grid { grid-template-columns:1fr }
  .fb h2 { font-size:1.28rem }
  .ft-grid { grid-template-columns:1fr }
  .featured { grid-template-columns:1fr }
  .fi { min-height:230px }
}
