/* ═══════════════════════════════════════════════════
   AutumnFire Portfolio — Celeste Klyne / SassyCess
   Hand-crafted CSS. No frameworks. Pure craft.
   ═══════════════════════════════════════════════════ */

:root {
  --bg:         #0f1214;
  --bg-raised:  #151a1d;
  --bg-card:    #1a2025;
  --bg-card-2:  #1f272d;
  --surface:    #253035;
  --border:     rgba(78,205,196,0.18);
  --border-hot: rgba(168,120,210,0.35);
  --orange:     #a878d2;
  --orange-lt:  #c09ae6;
  --gold:       #4ecdc4;
  --gold-lt:    #6ee8df;
  --cyan:       #4ecdc4;
  --cyan-lt:    #6ee8df;
  --text:       #e0e8e6;
  --text-muted: #7a928d;
  --text-dim:   #4a6660;
  --ff-display: 'Cinzel', serif;
  --ff-serif:   'Cormorant Garamond', Georgia, serif;
  --ff-body:    'Inter', system-ui, sans-serif;
  --r: 6px; --r-lg: 12px; --r-xl: 20px;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 24px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.6);
  --glow-orange: 0 0 30px rgba(168,120,210,0.25);
  --glow-gold:   0 0 30px rgba(78,205,196,0.2);
  --green:       #2ecc71;
  --green-lt:    #55d98d;
  --rose:        #d4728c;
  --rose-lt:     #e895ab;
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ICONS */
.icon{display:inline-block;width:1em;height:1em;vertical-align:-0.125em;fill:currentColor;flex-shrink:0}
.icon-lg{width:1.5em;height:1.5em}
.icon-xl{width:2em;height:2em}

/* GAME ICONS */
.gi { display:inline-block; width:1em; height:1em; vertical-align:-0.125em; fill:currentColor; flex-shrink:0; }
.gi-lg { width:1.5em; height:1.5em; }
.gi-xl { width:2em; height:2em; }
.gi-3x { width:3em; height:3em; }

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--ff-body);font-weight:300;line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--surface);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--orange)}

/* GRAIN TEXTURE */
.hero-grain,.section-grain,.footer-grain{
  position:absolute;inset:0;pointer-events:none;z-index:1;opacity:0.035;
  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='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px 256px;mix-blend-mode:overlay
}

/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:0 clamp(1rem,5vw,3rem)}

/* NAV */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;transition:background .3s,box-shadow .3s}
.site-nav.scrolled{background:rgba(26,22,18,0.95);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:1.2rem clamp(1rem,5vw,3rem);gap:1rem}
.nav-logo{display:flex;align-items:center;gap:.5rem;font-family:var(--ff-display);font-size:1.2rem;font-weight:700;letter-spacing:.08em;color:var(--gold);transition:color .3s}
.nav-logo:hover{color:var(--gold-lt)}
.nav-logo-fire{font-size:1.1em}
.nav-links{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}
.nav-links a{font-size:.8rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:.4rem .75rem;border-radius:var(--r);transition:color .3s,background .3s}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,.05)}
.nav-links .nav-cta{color:var(--orange);border:1px solid rgba(168,120,210,.4)}
.nav-links .nav-cta:hover{color:#fff;background:var(--orange);border-color:var(--orange)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:4px;z-index:101;position:relative}
.nav-toggle span{width:22px;height:2px;background:var(--text-muted);border-radius:2px;transition:.3s;display:block}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.6rem;border-radius:var(--r);font-family:var(--ff-body);font-size:.85rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;transition:all .3s;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--orange);color:#fff;border-color:var(--orange);box-shadow:var(--glow-orange)}
.btn-primary:hover{background:var(--orange-lt);border-color:var(--orange-lt);transform:translateY(-1px);box-shadow:0 0 40px rgba(168,120,210,.4)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}
.btn-ghost:hover{color:var(--gold);border-color:var(--gold);background:rgba(78,205,196,.08);transform:translateY(-1px)}

/* SECTION COMMON */
.section{position:relative;padding:clamp(4rem,10vw,8rem) 0;overflow:hidden}
.section-header{text-align:center;margin-bottom:4rem}
.section-eyebrow{font-size:.7rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--orange);margin-bottom:.75rem}
.section-title{font-family:var(--ff-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:700;color:var(--gold);letter-spacing:.04em;line-height:1.1;margin-bottom:1rem}
.section-subtitle{font-family:var(--ff-serif);font-size:clamp(1rem,2vw,1.25rem);color:var(--text-muted);font-style:italic;line-height:1.6}
.section-rule{width:60px;height:2px;background:linear-gradient(90deg,var(--orange),var(--gold));margin:1.5rem auto 0;border-radius:1px}

/* HERO */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:8rem 1rem 4rem}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(168,120,210,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 60%,rgba(46,204,113,.08) 0%,transparent 50%),radial-gradient(ellipse 100% 80% at 20% 100%,rgba(78,205,196,.06) 0%,transparent 60%),var(--bg);z-index:0}
.hero-ink-splash{position:absolute;border-radius:50%;filter:blur(1px);opacity:.04;pointer-events:none}
.splash-1{width:400px;height:300px;background:radial-gradient(var(--orange),transparent);top:10%;left:-10%;animation:ink-drift 20s ease-in-out infinite alternate}
.splash-2{width:300px;height:400px;background:radial-gradient(var(--gold),transparent);bottom:20%;right:-5%;animation:ink-drift 25s ease-in-out infinite alternate-reverse}
.splash-3{width:200px;height:200px;background:radial-gradient(var(--cyan),transparent);top:30%;right:15%;animation:ink-drift 18s ease-in-out infinite alternate;opacity:.06}
@keyframes ink-drift{from{transform:translate(0,0) scale(1)}to{transform:translate(30px,20px) scale(1.1)}}
.hero-content{position:relative;z-index:2;text-align:center;max-width:900px;width:100%}
.hero-eyebrow{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem}
.hero-tag{font-size:.7rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--text-muted);padding:.25rem .75rem;border:1px solid var(--border);border-radius:20px}
.hero-divider{color:var(--gold);opacity:.5}
.hero-title{font-family:var(--ff-display);font-size:clamp(4rem,15vw,10rem);font-weight:900;letter-spacing:-.02em;line-height:.9;margin-bottom:1rem}
.hero-title-main{display:block;color:var(--text);text-shadow:0 0 80px rgba(168,120,210,.2)}
.hero-title-accent{display:block;background:linear-gradient(135deg,var(--orange) 0%,var(--gold) 60%,var(--orange-lt) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 30px rgba(78,205,196,.3))}
.hero-subtitle{font-family:var(--ff-serif);font-size:clamp(1rem,2.5vw,1.4rem);color:var(--text-muted);letter-spacing:.08em;margin-bottom:1rem}
.hero-tagline{font-family:var(--ff-serif);font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--text);line-height:1.5;margin-bottom:2.5rem}
.hero-tagline em{color:var(--gold);font-style:italic}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.hero-artwork{margin-top:2rem}
.hero-artwork-link{display:block;transition:transform .3s}
.hero-artwork-link:hover{transform:translateY(-4px)}
.hero-artwork-frame{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg-card);box-shadow:var(--shadow-lg),var(--glow-gold);max-width:700px;margin:0 auto}
.hero-artwork-placeholder{padding:2rem;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:linear-gradient(135deg,var(--bg-card) 0%,rgba(168,120,210,.06) 100%)}
.character-silhouettes{display:flex;align-items:flex-end;justify-content:center;gap:1.5rem}
.char-sil{border-radius:4px 4px 0 0;position:relative}
.char-sil::before{content:'';display:block;position:absolute;top:-35%;left:50%;transform:translateX(-50%);width:40%;height:40%;border-radius:50%;background:inherit}
.char-sil--1{width:50px;height:130px;background:rgba(168,120,210,.5)}
.char-sil--2{width:45px;height:150px;background:rgba(46,204,113,.5)}
.char-sil--3{width:42px;height:120px;background:rgba(78,205,196,.5)}
.char-sil--4{width:48px;height:110px;background:rgba(100,80,60,.4)}
.hero-artwork-label{display:flex;flex-direction:column;align-items:center;gap:.35rem}
.artwork-label-text{font-family:var(--ff-display);font-size:.85rem;letter-spacing:.12em;color:var(--gold);text-transform:uppercase}
.artwork-label-action{font-size:.75rem;color:var(--text-muted);letter-spacing:.08em}
.hero-scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.5;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);animation:fade-float 3s ease-in-out infinite}
.scroll-arrow{width:20px;height:30px;border:1px solid var(--text-muted);border-radius:10px;display:flex;align-items:flex-start;justify-content:center;padding-top:5px}
.scroll-arrow-inner{width:4px;height:8px;background:var(--text-muted);border-radius:2px;animation:scroll-dot 2s ease-in-out infinite}
@keyframes scroll-dot{0%{transform:translateY(0);opacity:1}100%{transform:translateY(12px);opacity:0}}
@keyframes fade-float{0%,100%{opacity:.3;transform:translateX(-50%) translateY(0)}50%{opacity:.7;transform:translateX(-50%) translateY(-5px)}}

/* COMIC SECTION */
.comic-section{background:var(--bg-raised)}
.comic-intro{display:grid;grid-template-columns:1fr auto;gap:2rem 3rem;align-items:start;margin-bottom:3rem;padding:2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg)}
.comic-intro-text p{font-family:var(--ff-serif);font-size:1.15rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.8}
.comic-intro-text strong{color:var(--gold)}
.comic-intro-text em{color:var(--orange)}
.comic-intro-chars{display:flex;flex-direction:column;gap:.6rem;min-width:180px}
.char-badge{display:flex;align-items:center;gap:.6rem;padding:.5rem .9rem;background:var(--bg-card-2);border:1px solid var(--border);border-radius:var(--r);font-size:.82rem;letter-spacing:.04em;transition:border-color .3s}
.char-badge:hover{border-color:var(--gold)}
.char-badge-icon{font-size:1.1em}
.char-badge--mystery{border-style:dashed;border-color:rgba(255,255,255,.1);opacity:.6}
.comic-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:280px;gap:1px;background:var(--border);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);margin-bottom:2.5rem}
.comic-card{position:relative;overflow:hidden;background:var(--bg-card)}
.comic-card--featured{grid-column:span 2;grid-row:span 2}
.comic-card--wide{grid-column:span 2}
.comic-card-link{display:flex;flex-direction:column;height:100%;transition:transform .3s}
.comic-card-link:hover{transform:scale(1.01)}
.comic-card-art{flex:1;position:relative;overflow:hidden;background:var(--bg-card-2)}
.comic-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-card-2) 100%);transition:background .3s}
.comic-card:hover .comic-card-placeholder{background:linear-gradient(135deg,var(--bg-card-2) 0%,rgba(168,120,210,.1) 100%)}
.placeholder-icon{font-size:clamp(2rem,5vw,4rem);opacity:.3;transition:opacity .3s,transform .3s}
.comic-card:hover .placeholder-icon{opacity:.6;transform:scale(1.1)}
.comic-card-overlay{position:absolute;inset:0;background:rgba(26,22,18,.85);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.comic-card:hover .comic-card-overlay{opacity:1}
.view-badge{font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);padding:.5rem 1.2rem;border:1px solid var(--gold);border-radius:20px}
.comic-card-info{padding:.9rem 1rem;border-top:1px solid var(--border)}
.comic-card-info h3{font-family:var(--ff-display);font-size:.85rem;font-weight:700;letter-spacing:.06em;color:var(--gold);margin-bottom:.25rem}
.comic-card-info p{font-size:.75rem;color:var(--text-muted);line-height:1.4;margin-bottom:.4rem}
.comic-card-tag{font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);opacity:.8}
.comic-cta{text-align:center}

/* UNIVERSES */
.universes-section{background:var(--bg)}
.timeline{position:relative;display:flex;flex-direction:column;gap:2.5rem}
.timeline-spine{position:absolute;left:28px;top:24px;bottom:24px;width:2px;background:linear-gradient(to bottom,var(--orange),var(--gold),var(--text-dim));border-radius:2px;z-index:0}
.universe-card{position:relative;display:grid;grid-template-columns:60px 1fr;gap:1.5rem;z-index:1}
.universe-card-connector{display:flex;justify-content:center;padding-top:24px}
.universe-dot{width:16px;height:16px;background:var(--bg-card);border:2px solid var(--text-dim);border-radius:50%;transition:border-color .3s,transform .3s;flex-shrink:0}
.universe-dot--fire{border-color:var(--orange);background:var(--orange);box-shadow:var(--glow-orange)}
.universe-dot--origin{border-color:var(--gold);background:rgba(78,205,196,.3)}
.universe-card:hover .universe-dot{transform:scale(1.3)}
.universe-card-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem 2rem;transition:border-color .3s,transform .3s,box-shadow .3s}
.universe-card--active .universe-card-inner{border-color:rgba(168,120,210,.4);box-shadow:var(--glow-orange)}
.universe-card:hover .universe-card-inner{border-color:var(--gold);transform:translateX(4px);box-shadow:var(--glow-gold)}
.universe-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:1rem}
.universe-badge{display:inline-flex;align-items:center;font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .7rem;border-radius:20px;background:var(--bg-card-2);color:var(--text-muted);border:1px solid var(--border)}
.universe-badge--fire{color:var(--orange);border-color:rgba(168,120,210,.4);background:rgba(168,120,210,.1)}
.universe-badge--origin{color:var(--gold);border-color:rgba(78,205,196,.3);background:rgba(78,205,196,.1)}
.universe-years{font-size:.75rem;color:var(--text-dim);letter-spacing:.05em}
.universe-title{font-family:var(--ff-display);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;color:var(--gold);letter-spacing:.04em;margin-bottom:.3rem}
.universe-genre{font-size:.78rem;color:var(--orange);letter-spacing:.1em;text-transform:uppercase;font-weight:500;margin-bottom:.75rem}
.universe-desc{font-family:var(--ff-serif);font-size:1.05rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem}
.universe-stats{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}
.universe-stats span{font-size:.72rem;color:var(--text-dim);padding:.2rem .6rem;background:var(--bg-card-2);border-radius:var(--r);border:1px solid var(--border)}
.universe-link{font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);transition:color .3s,letter-spacing .3s}
.universe-link:hover{color:var(--gold);letter-spacing:.15em}

/* ARTIST */
.artist-section{background:var(--bg-raised);background-image:radial-gradient(ellipse 80% 60% at 0% 50%,rgba(168,120,210,.05) 0%,transparent 70%)}
.artist-layout{display:grid;grid-template-columns:280px 1fr;gap:4rem;align-items:start}
.portrait-frame{position:sticky;top:7rem;text-align:center}
.portrait-placeholder{position:relative;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);background:var(--bg-card);margin-bottom:1rem;box-shadow:var(--shadow-lg)}
.portrait-placeholder svg{width:100%}
.portrait-label{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);font-family:var(--ff-display);font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.portrait-tools{display:flex;justify-content:center;gap:.75rem;font-size:1.4rem;opacity:.7}
.portrait-tools span{cursor:help;transition:transform .3s}
.portrait-tools span:hover{transform:scale(1.3)}
.artist-title{text-align:left;margin-bottom:.25rem;font-size:clamp(1.8rem,4vw,2.5rem)}
.artist-handle{font-size:.8rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.5rem}
.artist-quote{font-family:var(--ff-serif);font-size:clamp(1.2rem,2.5vw,1.6rem);font-style:italic;color:var(--gold);line-height:1.5;padding:1.2rem 1.5rem;border-left:3px solid var(--orange);background:rgba(78,205,196,.06);border-radius:0 var(--r) var(--r) 0;margin-bottom:1.75rem}
.artist-bio p{font-family:var(--ff-serif);font-size:1.1rem;color:var(--text-muted);line-height:1.8;margin-bottom:.9rem}
.artist-bio strong{color:var(--text)}
.artist-bio em{color:var(--orange)}
.artist-details{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin:2rem 0;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg)}
.detail-group h4{font-size:.72rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.75rem}
.detail-group li{font-size:.85rem;color:var(--text-muted);padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.04)}
.detail-group li:last-child{border-bottom:none}
.artist-socials{display:flex;gap:.75rem;flex-wrap:wrap}
.social-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);font-size:.82rem;color:var(--text-muted);transition:all .3s}
.social-link:hover{color:var(--gold);border-color:var(--gold);background:rgba(78,205,196,.08);transform:translateY(-2px)}
.social-link--da:hover{color:var(--orange);border-color:var(--orange);background:rgba(168,120,210,.08)}

/* LINEAGE */
.lineage-section{background:var(--bg)}
.lineage-chart{display:flex;flex-direction:column;gap:3.5rem}
.lineage-line{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:2rem;overflow:hidden}
.lineage-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.lineage-icon{font-size:1.5rem}
.lineage-header h3{font-family:var(--ff-display);font-size:1rem;font-weight:700;letter-spacing:.1em;color:var(--gold);text-transform:uppercase}
.lineage-nodes{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:1rem;align-items:center}
.lineage-arrow{font-size:1.5rem;color:var(--orange);opacity:.5;text-align:center;flex-shrink:0}
.lineage-node{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;padding:1.25rem;background:var(--bg-card-2);border-radius:var(--r-lg);border:1px solid var(--border);transition:border-color .3s,box-shadow .3s}
.lineage-node:hover{border-color:var(--gold);box-shadow:var(--glow-gold)}
.lineage-node--current{border-color:rgba(168,120,210,.4);background:rgba(168,120,210,.05)}
.lineage-node--current:hover{border-color:var(--orange);box-shadow:var(--glow-orange)}
.lineage-node-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-size:1.2rem;font-weight:900;flex-shrink:0}
.lineage-era--1{background:rgba(78,205,196,.15);color:var(--gold);border:2px solid rgba(78,205,196,.4)}
.lineage-era--2{background:rgba(46,204,113,.15);color:var(--cyan);border:2px solid rgba(46,204,113,.4)}
.lineage-era--3{background:rgba(168,120,210,.2);color:var(--orange);border:2px solid rgba(168,120,210,.5)}
.lineage-node-info{display:flex;flex-direction:column;gap:.2rem}
.lineage-node-info strong{font-family:var(--ff-display);font-size:.8rem;font-weight:700;color:var(--text);letter-spacing:.04em;display:block}
.lineage-era-label{font-size:.68rem;color:var(--orange);letter-spacing:.08em;text-transform:uppercase;display:block}
.lineage-years{font-size:.65rem;color:var(--text-dim);display:block}
.lineage-node-info p{font-size:.78rem;color:var(--text-muted);line-height:1.4;margin-top:.3rem;font-family:var(--ff-serif);font-style:italic}

/* GALLERY */
.gallery-section{background:var(--bg-raised)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:8px;margin-bottom:2.5rem}
.gallery-item{position:relative;border-radius:var(--r);overflow:hidden}
.gallery-item--tall{grid-row:span 2}
.gallery-item--wide{grid-column:span 2}
.gallery-item-link{display:block;height:100%}
.gallery-item-inner{position:relative;height:100%;overflow:hidden;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r)}
.gallery-item-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:clamp(1.5rem,4vw,3rem);background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-card-2) 100%);opacity:.4;transition:opacity .3s,transform .3s}
.gallery-item:hover .gallery-item-placeholder{opacity:.8;transform:scale(1.05)}
.gallery-item-hover{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,22,18,.97) 0%,rgba(26,22,18,.6) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;opacity:0;transition:opacity .3s}
.gallery-item:hover .gallery-item-hover{opacity:1}
.gallery-item-hover h4{font-family:var(--ff-display);font-size:.8rem;font-weight:700;color:var(--gold);letter-spacing:.06em;margin-bottom:.2rem}
.gallery-item-hover p{font-size:.7rem;color:var(--text-muted);margin-bottom:.4rem}
.gallery-view-btn{font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--orange)}
.gallery-cta{text-align:center}

/* SUPPORT */
.support-section{background:var(--bg)}
.support-bg-glow{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:600px;height:400px;background:radial-gradient(var(--orange),transparent);opacity:.04;pointer-events:none;border-radius:50%;filter:blur(60px)}
.support-title{color:var(--orange)}
.support-tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}
.tier-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:2rem 1.5rem;text-align:center;position:relative;transition:transform .3s,border-color .3s,box-shadow .3s}
.tier-card:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:var(--glow-gold)}
.tier-card--featured{border-color:rgba(168,120,210,.5);background:linear-gradient(135deg,var(--bg-card) 0%,rgba(168,120,210,.08) 100%);box-shadow:var(--glow-orange)}
.tier-card--featured:hover{border-color:var(--orange);box-shadow:0 0 60px rgba(168,120,210,.3)}
.tier-card--gold{border-color:rgba(78,205,196,.3);background:linear-gradient(135deg,var(--bg-card) 0%,rgba(78,205,196,.06) 100%)}
.tier-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--orange);padding:.3rem .9rem;border-radius:20px;white-space:nowrap}
.tier-flame{font-size:2.5rem;margin-bottom:.75rem;display:block}
.tier-flame--sm{font-size:1.8rem}
.tier-flame--hot{letter-spacing:-.3em}
.tier-price{font-family:var(--ff-display);font-size:2.5rem;font-weight:900;color:var(--gold);line-height:1;margin-bottom:.25rem}
.tier-price span{font-size:.9rem;font-weight:400;color:var(--text-muted)}
.tier-name{font-family:var(--ff-display);font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text);margin-bottom:1.25rem}
.tier-perks{text-align:left;margin-bottom:1.5rem}
.tier-perks li{font-size:.8rem;color:var(--text-muted);padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.04);line-height:1.4}
.tier-perks li:last-child{border-bottom:none}
.btn-tier{width:100%;justify-content:center;padding:.65rem 1rem;font-size:.75rem;cursor:default;opacity:.7;background:var(--bg-card-2);color:var(--text-muted);border-color:var(--border)}
.btn-tier--featured{background:rgba(168,120,210,.15);color:var(--orange);border-color:rgba(168,120,210,.4)}
.btn-tier--gold{background:rgba(78,205,196,.12);color:var(--gold);border-color:rgba(78,205,196,.3)}
.support-note{text-align:center;font-family:var(--ff-serif);font-size:1rem;color:var(--text-muted);padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg)}
.support-note a{color:var(--orange);transition:color .3s}
.support-note a:hover{color:var(--gold)}

/* FOOTER */
.site-footer{position:relative;background:var(--bg);border-top:1px solid var(--border);padding:4rem 0 2rem;overflow:hidden}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:3rem;margin-bottom:3rem}
.footer-logo{font-family:var(--ff-display);font-size:1.3rem;font-weight:700;color:var(--gold);letter-spacing:.06em;margin-bottom:.75rem}
.footer-tagline{font-family:var(--ff-serif);font-size:.9rem;color:var(--text-dim);font-style:italic;line-height:1.6}
.footer-nav h4,.footer-social h4{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem}
.footer-nav li{padding:.3rem 0}
.footer-nav a{font-size:.85rem;color:var(--text-dim);transition:color .3s}
.footer-nav a:hover{color:var(--gold)}
.footer-social-links{display:flex;flex-direction:column;gap:.5rem}
.footer-social-link{font-size:.82rem;color:var(--text-dim);transition:color .3s;line-height:1.4}
.footer-social-link:hover{color:var(--orange)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:2rem;text-align:center}
.footer-credit{font-size:.78rem;color:var(--text-dim);line-height:1.8}
.footer-forge{font-size:.7rem;opacity:.6}
.footer-forge a{color:var(--gold);transition:color .3s}
.footer-forge a:hover{color:var(--orange)}

/* REVEAL ANIMATION */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ═══════════════════════════════════════════════════
   REAL IMAGE STYLES — added for image integration
   ═══════════════════════════════════════════════════ */

/* Comic card images */
.comic-card-art img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.comic-card:hover .comic-card-art img {
  transform: scale(1.04);
}

/* Gallery item images */
.gallery-item-inner img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1), opacity 0.3s;
  opacity: 0.75;
}
.gallery-item:hover .gallery-item-inner img {
  transform: scale(1.05);
  opacity: 1;
}

/* Novastar page ns-piece frame images */
.ns-piece-frame img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.ns-piece-frame:hover img {
  transform: scale(1.03);
}

/* Hero — real image treatment */
.hero-artwork-real {
  position: relative;
  max-width: 860px;
  margin: 2rem auto 0;
}
.hero-image-bg {
  width: 100%;
  border-radius: var(--r-lg);
  overflow: hidden;
  position: relative;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg), var(--glow-gold);
}
.hero-image-bg img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 420px;
  object-fit: cover;
  object-position: center top;
}
.hero-image-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(15,18,20,0.15) 0%,
    rgba(15,18,20,0.05) 40%,
    rgba(15,18,20,0.55) 80%,
    rgba(15,18,20,0.85) 100%
  );
  pointer-events: none;
}
.hero-image-label {
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  z-index: 2;
  pointer-events: none;
}
.hero-image-label .artwork-label-text {
  font-family: var(--ff-display);
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  color: var(--gold);
  text-transform: uppercase;
}
.hero-image-label .artwork-label-action {
  font-size: 0.75rem;
  color: var(--text-muted);
  letter-spacing: 0.08em;
}

/* Character portrait thumbnails below hero image */
.hero-char-row {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}
.hero-char-thumb {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  text-decoration: none;
  transition: transform 0.3s;
}
.hero-char-thumb:hover {
  transform: translateY(-4px);
}
.hero-char-thumb-img {
  width: 72px;
  height: 120px;
  border-radius: var(--r);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  transition: border-color 0.3s, box-shadow 0.3s;
}
.hero-char-thumb:hover .hero-char-thumb-img {
  border-color: var(--gold);
  box-shadow: var(--glow-gold);
}
.hero-char-thumb-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.hero-char-thumb-name {
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  transition: color 0.3s;
}
.hero-char-thumb:hover .hero-char-thumb-name {
  color: var(--gold);
}

/* Dark Streets comic page frames */
.comic-page-frame img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--r);
}

/* Dark Streets character art */
.comic-char-art img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.comic-char-card:hover .comic-char-art img {
  transform: scale(1.04);
}

/* RESPONSIVE */
@media(max-width:1100px){
  .support-tiers{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .artist-layout{grid-template-columns:1fr}
  .portrait-frame{position:static}
  .comic-intro{grid-template-columns:1fr}
  .comic-intro-chars{flex-direction:row;flex-wrap:wrap}
  .artist-details{grid-template-columns:1fr 1fr}
  .lineage-nodes{grid-template-columns:1fr;gap:.5rem}
  .lineage-arrow{transform:rotate(90deg);text-align:center}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item--tall{grid-row:span 1}
}
@media(max-width:768px){
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(26,22,18,.97);flex-direction:column;align-items:center;justify-content:center;gap:.5rem;z-index:99}
  .nav-links.open{display:flex}
  .nav-links a{font-size:1.1rem;padding:.75rem 2rem}
  .nav-toggle{display:flex}
  .comic-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .comic-card--featured{grid-column:span 2;grid-row:span 1}
  .timeline-spine{left:22px}
  .universe-card{grid-template-columns:46px 1fr}
  .support-tiers{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:480px){
  .comic-grid{grid-template-columns:1fr}
  .comic-card--featured,.comic-card--wide{grid-column:span 1}
  .support-tiers{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .hero-title{font-size:clamp(3.5rem,20vw,6rem)}
  .artist-details{grid-template-columns:1fr}
}
