@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;font-size:16px;}

:root{
  --gold:    #b8860b;
  --gold-lt: #d4a017;
  --gold-bg: #f9f3e3;
  --cream:   #faf7f2;
  --paper:   #f5f0e8;
  --ink:     #1a1612;
  --ink2:    #2d2820;
  --ink3:    #4a4238;
  --muted:   #8a7d6e;
  --rule:    rgba(184,134,11,0.18);
  --ruleH:   rgba(184,134,11,0.45);
  --shadow:  rgba(26,22,18,0.08);
}

body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Crimson Pro',Georgia,serif;
  font-weight:400;line-height:1.7;
  min-height:100vh;overflow-x:hidden;
}

/* ── BG CANVAS ── */
#bg-canvas{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.55;
}

/* Subtle paper texture */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  opacity:1;mix-blend-mode:multiply;
}

/* ── NAV ── */
#site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:0 52px;height:62px;
  border-bottom:1px solid transparent;
  transition:background .3s,border-color .3s,backdrop-filter .3s;
}
#site-nav.scrolled{
  background:rgba(250,247,242,0.97);
  backdrop-filter:blur(12px);
  border-color:var(--rule);
}
.logo{
  font-family:'Playfair Display',serif;
  font-size:21px;font-weight:700;font-style:italic;
  color:var(--ink);text-decoration:none;white-space:nowrap;
  letter-spacing:-0.01em;
}
.logo em{color:var(--gold);font-style:italic;}
.logo span{color:var(--muted);font-style:normal;font-weight:400;}
.logo:hover em{color:var(--gold-lt);}

.nav-search{display:flex;flex:1;max-width:360px;}
.nav-search input{
  flex:1;background:#fff;
  border:1px solid var(--rule);border-right:none;
  color:var(--ink);padding:8px 14px;
  font-family:'Crimson Pro',serif;font-size:15px;font-weight:400;
  outline:none;transition:border-color .2s;
  border-radius:1px 0 0 1px;
}
.nav-search input:focus{border-color:var(--ruleH);}
.nav-search input::placeholder{color:var(--muted);font-style:italic;}
.nav-search button{
  background:var(--gold);border:none;color:#fff;
  padding:8px 14px;cursor:pointer;transition:background .15s;
  display:flex;align-items:center;border-radius:0 1px 1px 0;
}
.nav-search button:hover{background:var(--gold-lt);}

/* ── LAYOUT ── */
.wrap{max-width:1200px;margin:0 auto;padding:0 52px;position:relative;z-index:1;}
.section{padding:60px 0;}

/* ── TYPOGRAPHY ── */
.eyebrow{
  font-family:'DM Sans',sans-serif;
  font-size:9px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:10px;display:block;
}
.display{
  font-family:'Playfair Display',serif;
  font-size:clamp(52px,8vw,110px);
  font-weight:900;line-height:.92;letter-spacing:-.02em;
  color:var(--ink);
}
.display em{font-style:italic;color:var(--gold);}
.display-md{
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,3.5vw,42px);
  font-weight:700;color:var(--ink);line-height:1.1;
}
.display-md em{font-style:italic;color:var(--gold);}

/* ── RULES ── */
.rule{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--rule),var(--gold-lt),var(--rule),transparent);}
.rule-full{border:none;height:1px;background:var(--rule);}

/* ═══════════════════
   HERO
═══════════════════ */
.hero{
  position:relative;z-index:1;
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:80px 52px 52px;
  text-align:center;
  overflow:hidden;
}

/* Large italic watermark behind */
.hero-wm{
  position:absolute;
  font-family:'Playfair Display',serif;
  font-size:clamp(180px,28vw,420px);
  font-weight:900;font-style:italic;
  color:transparent;
  -webkit-text-stroke:1px rgba(184,134,11,.07);
  line-height:1;top:50%;left:50%;
  transform:translate(-50%,-52%);
  pointer-events:none;user-select:none;
  white-space:nowrap;z-index:0;
}

.hero-inner{position:relative;z-index:1;}

.hero-kicker{
  display:inline-block;
  font-family:'DM Sans',sans-serif;
  font-size:10px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--rule);
  padding:6px 18px;border-radius:40px;
  margin-bottom:28px;
  background:rgba(255,255,255,.6);backdrop-filter:blur(4px);
}
.hero-title{margin-bottom:22px;}
.hero-sub{
  font-family:'Crimson Pro',serif;
  font-size:19px;font-weight:300;font-style:italic;line-height:1.7;
  color:var(--ink3);max-width:500px;margin:0 auto 36px;
}

.hero-search{
  display:flex;max-width:520px;margin:0 auto 14px;
  border:1px solid var(--ruleH);border-radius:2px;
  box-shadow:0 4px 32px var(--shadow),0 0 0 4px rgba(184,134,11,.04);
  background:#fff;
  transition:box-shadow .3s;
}
.hero-search:focus-within{box-shadow:0 8px 48px rgba(184,134,11,.12),0 0 0 4px rgba(184,134,11,.08);}
.hero-search input{
  flex:1;background:transparent;border:none;color:var(--ink);
  padding:15px 20px;
  font-family:'Crimson Pro',serif;font-size:17px;font-weight:400;
  outline:none;
}
.hero-search input::placeholder{color:var(--muted);font-style:italic;}
.hero-search button{
  background:var(--gold);border:none;color:#fff;
  padding:15px 26px;
  font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  cursor:pointer;transition:background .15s;
  border-radius:0 1px 1px 0;white-space:nowrap;
}
.hero-search button:hover{background:var(--gold-lt);}
.hero-hint{
  font-family:'Crimson Pro',serif;
  font-size:14px;font-style:italic;color:var(--muted);
}
.hero-hint a{color:var(--gold);text-decoration:none;}
.hero-hint a:hover{color:var(--gold-lt);}

/* Trending chips */
.chips-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;max-width:680px;margin:32px auto 0;}
.chip{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.75);
  border:1px solid var(--rule);border-radius:1px;
  padding:5px 13px;
  font-family:'Crimson Pro',serif;font-size:14px;color:var(--ink3);
  text-decoration:none;white-space:nowrap;
  transition:border-color .15s,color .15s,background .15s;
  backdrop-filter:blur(4px);
}
.chip:hover{border-color:var(--ruleH);color:var(--gold);background:#fff;}
.chip-n{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:12px;color:var(--gold);
}

/* ═══════════════════
   MARQUEE
═══════════════════ */
.marquee-wrap{
  overflow:hidden;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:11px 0;background:rgba(255,255,255,.5);
  position:relative;z-index:1;
}
.marquee-track{display:flex;white-space:nowrap;animation:mq 40s linear infinite;}
.marquee-track:hover{animation-play-state:paused;}
.marquee-item{
  flex-shrink:0;
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:13px;letter-spacing:.06em;
  color:var(--muted);padding:0 24px;
  display:flex;align-items:center;gap:12px;
}
.marquee-item a{color:var(--muted);text-decoration:none;transition:color .15s;}
.marquee-item a:hover{color:var(--gold);}
.marquee-sep{color:var(--rule);font-size:14px;}
@keyframes mq{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ═══════════════════
   SECTION HEAD
═══════════════════ */
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:28px;gap:16px;
}
.see-all{
  font-family:'DM Sans',sans-serif;
  font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;
  border-bottom:1px solid var(--muted);padding-bottom:2px;
  transition:color .15s,border-color .15s;white-space:nowrap;
}
.see-all:hover{color:var(--gold);border-color:var(--gold);}

/* ═══════════════════
   HORIZONTAL SCROLLER
═══════════════════ */
.hscroll-section{padding:40px 0;}
.hscroll-head{
  max-width:1200px;margin:0 auto 20px;padding:0 52px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
}
.hscroll-wrap{position:relative;}
.hscroll-wrap::before,.hscroll-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none;
}
.hscroll-wrap::before{left:0;background:linear-gradient(90deg,var(--cream),transparent);}
.hscroll-wrap::after{right:0;background:linear-gradient(270deg,var(--cream),transparent);}
.hscroll-track{
  display:flex;gap:14px;overflow-x:auto;
  padding:4px 52px 18px;
  scrollbar-width:none;-ms-overflow-style:none;
  cursor:grab;user-select:none;
}
.hscroll-track::-webkit-scrollbar{display:none;}
.hscroll-track:active{cursor:grabbing;}

/* ── CARD ── */
.card{
  flex-shrink:0;width:152px;
  background:#fff;
  border:1px solid rgba(184,134,11,.1);
  border-radius:2px;
  text-decoration:none;color:inherit;display:block;
  position:relative;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  box-shadow:0 2px 12px var(--shadow);
}
.card:hover{
  border-color:var(--ruleH);
  transform:translateY(-5px);
  box-shadow:0 12px 40px rgba(26,22,18,.14);
}
.card-img{width:100%;aspect-ratio:2/3;overflow:hidden;background:var(--paper);position:relative;border-radius:2px 2px 0 0;}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.card:hover .card-img img{transform:scale(1.05);}
.card-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:38px;color:rgba(184,134,11,.2);}
.card-rank{
  position:absolute;top:8px;left:8px;z-index:3;
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:14px;color:var(--gold);
  background:rgba(250,247,242,.92);
  border:1px solid var(--rule);
  padding:1px 7px;border-radius:1px;
  backdrop-filter:blur(4px);
}
.card-body{padding:10px 12px 13px;}
.card-name{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:14px;line-height:1.25;
  color:var(--ink);margin-bottom:3px;
}
.card-sub{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--muted);letter-spacing:.04em;}
.card-rating{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--gold);margin-top:4px;font-weight:500;}
.card.wide{width:182px;}

/* ═══════════════════
   RESULT GRID
═══════════════════ */
.result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(152px,1fr));gap:16px;}
.result-grid .card{width:auto;flex-shrink:unset;}

/* ═══════════════════
   PROFILE PAGES
═══════════════════ */
.profile-hero{position:relative;z-index:1;padding:82px 52px 52px;max-width:1200px;margin:0 auto;}
.profile-backdrop{
  position:fixed;inset:0;z-index:0;
  filter:blur(100px) saturate(.15) brightness(.92);
  opacity:.25;background-size:cover;background-position:top center;
  mix-blend-mode:multiply;
}
.profile-layout{display:grid;grid-template-columns:260px 1fr;gap:48px;align-items:start;}
.profile-poster{
  border-radius:2px;overflow:hidden;
  border:1px solid rgba(184,134,11,.15);
  box-shadow:0 20px 60px rgba(26,22,18,.18);
  position:relative;
}
.profile-poster img{width:100%;display:block;}
.profile-poster-ph{aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;font-size:72px;color:rgba(184,134,11,.15);background:var(--paper);}
/* Gold corner rule */
.profile-poster::after{
  content:'';position:absolute;top:0;right:0;
  width:36px;height:36px;
  border-top:2px solid var(--gold);border-right:2px solid var(--gold);
  pointer-events:none;
}

.profile-info{padding-top:4px;}
.profile-name{
  font-family:'Playfair Display',serif;
  font-size:clamp(42px,6vw,80px);font-weight:900;
  line-height:.92;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:8px;
}
.profile-dept{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:block;}
.profile-known{font-family:'Crimson Pro',serif;font-size:16px;font-style:italic;color:var(--ink3);margin-bottom:20px;}
.profile-meta{display:flex;flex-wrap:wrap;gap:24px;margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--rule);}
.meta-item strong{display:block;font-family:'DM Sans',sans-serif;font-size:8px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.meta-item span{font-family:'Crimson Pro',serif;font-size:16px;color:var(--ink3);}
.meta-item a{color:var(--gold);text-decoration:none;}
.meta-item a:hover{color:var(--gold-lt);}
.profile-bio{font-family:'Crimson Pro',serif;font-size:16px;font-weight:300;line-height:1.85;color:var(--ink3);max-width:580px;}

/* Stats */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);margin:28px 0;}
.stat-cell{background:#fff;padding:20px 14px;text-align:center;}
.stat-n{font-family:'Playfair Display',serif;font-size:38px;font-weight:700;font-style:italic;color:var(--gold);line-height:1;}
.stat-l{font-family:'DM Sans',sans-serif;font-size:8px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:4px;}

/* ═══════════════════
   FILM PAGE
═══════════════════ */
.film-hero-section{position:relative;z-index:1;padding:82px 52px 52px;max-width:1200px;margin:0 auto;}
.film-layout{display:grid;grid-template-columns:220px 1fr;gap:44px;align-items:start;}
.film-poster{
  border-radius:2px;overflow:hidden;
  border:1px solid rgba(184,134,11,.15);
  box-shadow:0 20px 60px rgba(26,22,18,.18);
  position:relative;
}
.film-poster img{width:100%;display:block;}
.film-poster::after{
  content:'';position:absolute;bottom:0;left:0;
  width:36px;height:36px;
  border-bottom:2px solid var(--gold);border-left:2px solid var(--gold);
  pointer-events:none;
}
.film-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(32px,5vw,66px);font-weight:900;
  line-height:.92;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:8px;
}
.film-tagline{font-family:'Crimson Pro',serif;font-size:16px;font-style:italic;color:var(--muted);margin-bottom:16px;}
.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px;}
.tag{
  font-family:'DM Sans',sans-serif;
  font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--rule);
  padding:4px 10px;border-radius:1px;background:var(--gold-bg);
}
.film-overview{font-family:'Crimson Pro',serif;font-size:16px;font-weight:300;line-height:1.85;color:var(--ink3);max-width:540px;margin-bottom:20px;}
.film-director{font-family:'Crimson Pro',serif;font-size:15px;font-style:italic;color:var(--muted);margin-bottom:16px;}
.film-director a{color:var(--gold);text-decoration:none;}
.film-director a:hover{color:var(--gold-lt);}

/* Cast */
.cast-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(22px,3vw,36px);font-weight:700;font-style:italic;
  color:var(--ink);margin-bottom:20px;padding-bottom:12px;
  border-bottom:1px solid var(--rule);
}
.cast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;}
.cast-card{
  background:#fff;border:1px solid rgba(184,134,11,.08);
  border-radius:2px;overflow:hidden;text-decoration:none;color:inherit;
  transition:border-color .2s,transform .2s,box-shadow .2s;display:block;
  box-shadow:0 1px 6px var(--shadow);
}
.cast-card:hover{border-color:var(--ruleH);transform:translateY(-3px);box-shadow:0 8px 28px rgba(26,22,18,.12);}
.cast-img{width:100%;aspect-ratio:1;overflow:hidden;background:var(--paper);position:relative;}
.cast-img img{width:100%;height:100%;object-fit:cover;object-position:top;display:block;transition:transform .3s;}
.cast-card:hover .cast-img img{transform:scale(1.06);}
.cast-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:30px;color:rgba(184,134,11,.15);}
.cast-body{padding:8px 10px;}
.cast-name{font-family:'Playfair Display',serif;font-size:12px;font-weight:600;color:var(--ink);line-height:1.3;}
.cast-char{font-family:'Crimson Pro',serif;font-size:12px;font-style:italic;color:var(--muted);margin-top:1px;}

/* ═══════════════════
   SEARCH
═══════════════════ */
.search-hero{position:relative;z-index:1;padding:82px 52px 44px;max-width:1200px;margin:0 auto;}
.search-page-title{font-family:'Playfair Display',serif;font-size:clamp(32px,4.5vw,56px);font-weight:900;color:var(--ink);margin-bottom:6px;letter-spacing:-.02em;}
.search-page-title em{font-style:italic;color:var(--gold);}
.search-count{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--muted);margin-bottom:20px;letter-spacing:.04em;}
.filter-tabs{display:flex;gap:2px;margin-bottom:28px;flex-wrap:wrap;}
.ftab{
  font-family:'DM Sans',sans-serif;
  font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:8px 18px;border:1px solid var(--rule);
  background:transparent;color:var(--muted);
  cursor:pointer;text-decoration:none;transition:all .15s;border-radius:1px;
}
.ftab.active,.ftab:hover{background:var(--gold-bg);color:var(--gold);border-color:var(--ruleH);}

/* Pagination */
.pager{display:flex;gap:4px;justify-content:center;margin-top:48px;}
.pager-btn{
  width:38px;height:38px;background:#fff;border:1px solid var(--rule);
  color:var(--ink3);font-family:'Playfair Display',serif;font-size:14px;font-style:italic;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;transition:all .15s;border-radius:1px;
  box-shadow:0 1px 4px var(--shadow);
}
.pager-btn:hover,.pager-btn.on{border-color:var(--ruleH);color:var(--gold);background:var(--gold-bg);}
.pager-btn.disabled{opacity:.3;pointer-events:none;}

/* 404 */
.page-404{position:relative;z-index:1;min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:100px 40px;}
.err-num{font-family:'Playfair Display',serif;font-size:clamp(120px,22vw,240px);font-weight:900;font-style:italic;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(184,134,11,.12);display:block;margin-bottom:14px;}
.err-msg{font-family:'Crimson Pro',serif;font-size:18px;font-style:italic;color:var(--muted);margin-bottom:24px;}
.btn-gold{
  display:inline-block;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;background:var(--gold);padding:13px 32px;text-decoration:none;border-radius:1px;transition:background .15s;
}
.btn-gold:hover{background:var(--gold-lt);}

/* Footer */
footer{position:relative;z-index:1;border-top:1px solid var(--rule);padding:24px 52px;margin-top:60px;background:rgba(255,255,255,.5);}
.f-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.f-logo{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;font-style:italic;color:var(--ink);text-decoration:none;}
.f-logo em{color:var(--gold);}
.f-copy{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--muted);}

/* Responsive */
@media(max-width:900px){
  #site-nav,.hscroll-head,.profile-hero,.film-hero-section,.search-hero,.wrap,footer{padding-left:20px;padding-right:20px;}
  .hscroll-track{padding-left:20px;padding-right:20px;}
  .hscroll-wrap::before{background:linear-gradient(90deg,var(--cream),transparent);}
  .hscroll-wrap::after{background:linear-gradient(270deg,var(--cream),transparent);}
  .hero{padding:76px 20px 44px;}
  .profile-layout,.film-layout{grid-template-columns:1fr;}
  .profile-poster,.film-poster{max-width:200px;}
  .stats-bar{grid-template-columns:repeat(2,1fr);}
  footer{margin-top:40px;}
}

/* FAQ */
.faq-item{padding:16px 0;border-bottom:1px solid var(--rule);}
.faq-item:last-child{border-bottom:none;}
.faq-q{font-family:'Playfair Display',serif;font-size:17px;font-weight:600;color:var(--ink);margin-bottom:6px;}
.faq-a{font-family:'Crimson Pro',serif;font-size:16px;font-weight:300;color:var(--ink3);line-height:1.75;}

/* Breadcrumb */
.breadcrumb-nav{position:relative;z-index:1;padding-top:68px;}
.breadcrumb-inner{
  display:flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;font-size:11px;
  color:var(--muted);letter-spacing:.04em;
  padding-top:12px;padding-bottom:12px;
  border-bottom:1px solid var(--rule);
}
.breadcrumb-inner a{color:var(--muted);text-decoration:none;transition:color .15s;}
.breadcrumb-inner a:hover{color:var(--gold);}
.breadcrumb-inner span:last-child{color:var(--ink3);}
