/* Chaos Meets Circus — design tokens */
:root{
  --bg-0:#0b0a14;
  --bg-1:#141023;
  --bg-2:#1c1530;
  --panel:#1a1226;
  --panel-2:#221733;
  --gold:#e0a83a;
  --gold-soft:#c89234;
  --red:#c8332e;
  --red-bright:#e0473b;
  --cream:#f4e8d0;
  --cream-dim:#c9bfa6;
  --muted:#8a8095;
  --shadow:0 20px 60px rgba(0,0,0,.55);
  --display:"Cinzel", "Trajan Pro", Georgia, serif;
  --body:"Lora", Georgia, serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(ellipse at top, rgba(80,30,60,.35), transparent 60%),
    radial-gradient(ellipse at bottom, rgba(120,50,20,.28), transparent 60%),
    var(--bg-0);
  color:var(--cream);
  font-family:var(--body);
  font-size:16px;
  line-height:1.65;
  min-height:100vh;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--gold);text-decoration:none;transition:color .2s}
a:hover{color:var(--red-bright)}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:.04em;line-height:1.15;color:var(--cream)}
h1{font-size:clamp(2.4rem,5vw,4.4rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:1.35rem}
h4{font-size:1.05rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
p{margin-bottom:1rem;color:var(--cream-dim)}

.container{max-width:1240px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0;position:relative}

/* ===== Top Nav ===== */
.topbar{
  background:linear-gradient(180deg, rgba(11,10,20,.95), rgba(11,10,20,.78));
  border-bottom:1px solid rgba(224,168,58,.15);
  position:sticky;top:0;z-index:50;backdrop-filter:blur(6px);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;max-width:1280px;margin:0 auto;gap:1rem}
.logo{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;color:var(--gold);font-size:1.05rem;letter-spacing:.08em}
.logo-mark{
  width:54px;height:54px;border-radius:50%;
  background:radial-gradient(circle,#3a1e1c 30%,#1c0e1a 70%);
  border:2px solid var(--gold);
  display:grid;place-items:center;
  box-shadow:0 0 16px rgba(224,168,58,.45) inset;
  position:relative;
  flex-shrink:0;
}
.logo-mark::after{
  content:"★";color:var(--gold);font-size:1.1rem;
}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-text small{font-size:.55rem;letter-spacing:.3em;color:var(--cream-dim)}
.nav-links{display:flex;gap:1.8rem;list-style:none;align-items:center}
.nav-links a{color:var(--cream);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-family:var(--display);font-weight:500;padding:.4rem 0;border-bottom:1px solid transparent}
.nav-links a.active,.nav-links a:hover{color:var(--gold);border-bottom-color:var(--gold)}
.nav-cta{
  background:var(--red);color:#fff;border:2px solid var(--gold);
  padding:.55rem 1.4rem;font-family:var(--display);font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;font-size:.75rem;
  border-radius:2px;transition:all .2s;box-shadow:0 0 0 1px rgba(0,0,0,.3) inset;
}
.nav-cta:hover{background:var(--red-bright);color:#fff;transform:translateY(-1px)}

.menu-toggle{display:none;background:transparent;border:none;color:var(--gold);font-size:1.6rem;cursor:pointer}

/* ===== Buttons / Marquee CTA ===== */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--display);font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;font-size:.78rem;
  padding:.95rem 1.7rem;border-radius:3px;
  transition:transform .15s, box-shadow .15s, background .2s;
  border:2px solid transparent;cursor:pointer;
}
.btn-primary{
  background:var(--red);color:#fff;border-color:var(--red-bright);
  box-shadow:0 6px 22px rgba(200,51,46,.4);
}
.btn-primary:hover{transform:translateY(-2px);background:var(--red-bright);color:#fff}
.btn-ghost{
  background:transparent;color:var(--cream);
  border:1.5px solid var(--gold);
}
.btn-ghost:hover{background:rgba(224,168,58,.12);color:var(--gold)}
.btn .ico{width:18px;height:18px;display:inline-block}

.marquee-cta{
  display:inline-block;padding:1.3rem 2.4rem;
  background:linear-gradient(180deg,#231632,#150d20);
  border:2px solid var(--gold);
  position:relative;border-radius:4px;
  font-family:var(--display);font-size:1.3rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);font-weight:700;
  box-shadow:0 0 24px rgba(224,168,58,.25), inset 0 0 18px rgba(224,168,58,.1);
}
.marquee-cta::before,.marquee-cta::after{
  content:"";position:absolute;inset:6px;border:1px solid rgba(224,168,58,.45);
  pointer-events:none;border-radius:2px;
}
.marquee-cta::after{
  inset:-1px;background:
    radial-gradient(circle, var(--gold) 30%, transparent 32%) 0 0/14px 14px;
  background-clip:border-box;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  padding:6px;border:none;opacity:.0;
}

/* ===== Section heading w/ scroll flourish ===== */
.eyebrow{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  font-family:var(--display);font-size:.85rem;letter-spacing:.4em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;
}
.eyebrow::before,.eyebrow::after{
  content:"";flex:0 0 70px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.section-title{text-align:center;font-size:clamp(2rem,4vw,3rem);margin-bottom:.4rem}
.section-sub{text-align:center;color:var(--cream-dim);max-width:640px;margin:0 auto 3rem}
.flourish{display:block;text-align:center;color:var(--gold);font-size:1.4rem;margin:.4rem 0 1.6rem;letter-spacing:.6em;opacity:.85}
.flourish::before{content:"❦ ✦ ❦"}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  padding:4.5rem 0 5rem;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(140,40,30,.35), transparent 60%),
    radial-gradient(ellipse at 80% 70%, rgba(80,20,70,.32), transparent 60%),
    linear-gradient(180deg, #0e0918 0%, #1a0e22 100%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:3rem;align-items:center}
.hero-eyebrow{font-family:var(--display);color:var(--red-bright);letter-spacing:.32em;text-transform:uppercase;font-size:.8rem;margin-bottom:1.2rem}
.hero h1{margin-bottom:1.2rem}
.hero h1 .accent{color:var(--red-bright)}
.hero p.lead{font-size:1.05rem;color:var(--cream-dim);margin-bottom:2rem;max-width:520px}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-art{
  position:relative;text-align:center;
}
.hero-art img{
  width:100%;max-width:560px;margin:0 auto;
  border-radius:8px;
  filter:drop-shadow(0 18px 40px rgba(0,0,0,.6));
}

/* ===== Cast preview ===== */
.cast-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem}
.cast-card{
  text-align:center;
  background:linear-gradient(180deg, rgba(34,23,51,.6), rgba(20,14,33,.6));
  border:1px solid rgba(224,168,58,.18);
  border-radius:6px;padding:2rem 1.5rem;
  transition:transform .25s, border-color .25s;
}
.cast-card:hover{transform:translateY(-5px);border-color:var(--gold)}
.cast-card .frame{
  width:170px;height:170px;border-radius:50%;
  margin:0 auto 1.2rem;overflow:hidden;
  border:3px solid var(--gold);
  box-shadow:0 0 32px rgba(224,168,58,.25);
  background:#1a0e22;
}
.cast-card .frame img{width:100%;height:100%;object-fit:cover}
.cast-card h3{color:var(--gold);font-size:1.25rem;letter-spacing:.14em;text-transform:uppercase}
.cast-card .role{color:var(--red-bright);font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;margin:.4rem 0 .9rem;font-family:var(--display)}
.cast-card p{font-size:.92rem;color:var(--cream-dim)}

/* ===== Feature grid ===== */
.feature-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:2rem}
.feature{
  text-align:center;padding:1.4rem 1rem;
  background:linear-gradient(180deg, rgba(28,21,48,.7), rgba(20,14,33,.7));
  border:1px solid rgba(224,168,58,.15);border-radius:4px;
}
.feature .ico-circle{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,#2a1a3f,#1a0e22);
  border:1.5px solid var(--gold);display:grid;place-items:center;
  margin:0 auto .8rem;color:var(--gold);
}
.feature h4{font-size:.82rem;letter-spacing:.18em;color:var(--gold);margin-bottom:.3rem}
.feature p{font-size:.78rem;color:var(--cream-dim);margin:0}

/* ===== Why-us split ===== */
.split{
  background:linear-gradient(180deg, rgba(36,21,28,.65), rgba(28,16,28,.65));
  border-top:2px solid var(--red);border-bottom:2px solid var(--red);
  padding:4rem 0;position:relative;
}
.split-inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split::before,.split::after{
  content:"";position:absolute;left:0;right:0;height:18px;
  background:repeating-linear-gradient(90deg, var(--red) 0 28px, #8a1f1c 28px 56px);
}
.split::before{top:-10px;clip-path:polygon(0 0,3% 100%,6% 0,9% 100%,12% 0,15% 100%,18% 0,21% 100%,24% 0,27% 100%,30% 0,33% 100%,36% 0,39% 100%,42% 0,45% 100%,48% 0,51% 100%,54% 0,57% 100%,60% 0,63% 100%,66% 0,69% 100%,72% 0,75% 100%,78% 0,81% 100%,84% 0,87% 100%,90% 0,93% 100%,96% 0,100% 100%,100% 0)}
.split::after{bottom:-10px;transform:scaleY(-1)}
.split .col{padding:0 1rem}
.split h2{color:var(--gold);margin-bottom:1rem}

/* ===== Footer ===== */
.footer{
  background:linear-gradient(180deg, #0a0712, #06040d);
  border-top:1px solid rgba(224,168,58,.18);
  padding:3rem 0 1.5rem;margin-top:4rem;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2rem}
.footer h4{color:var(--gold);margin-bottom:1rem;font-size:.85rem;letter-spacing:.2em}
.footer ul{list-style:none}
.footer ul li{margin-bottom:.4rem}
.footer ul a{color:var(--cream-dim);font-size:.9rem}
.footer ul a:hover{color:var(--gold)}
.socials{display:flex;gap:.6rem;margin-top:.6rem}
.socials a{
  width:34px;height:34px;border-radius:50%;border:1px solid var(--gold);
  display:grid;place-items:center;color:var(--gold);
}
.socials a:hover{background:var(--gold);color:#0b0a14}
.copyright{text-align:center;color:var(--muted);font-size:.8rem;border-top:1px solid rgba(224,168,58,.08);padding-top:1.2rem}

/* ===== Page banner (non-home) ===== */
.page-banner{
  padding:3rem 0 2rem;
  background:
    radial-gradient(ellipse at center, rgba(120,40,30,.3), transparent 70%),
    linear-gradient(180deg, #110a1c, #1a0e22);
  border-bottom:1px solid rgba(224,168,58,.14);
}
.crumb{font-size:.75rem;color:var(--cream-dim);letter-spacing:.22em;text-transform:uppercase;margin-bottom:.6rem}
.crumb a{color:var(--gold)}

/* ===== Specialties list (cast detail) ===== */
.spec-list{list-style:none;display:grid;gap:1.1rem;margin-top:1rem}
.spec-list li{display:grid;grid-template-columns:42px 1fr;gap:1rem;align-items:start}
.spec-list .si{
  width:42px;height:42px;border-radius:50%;
  border:1.5px solid var(--gold);display:grid;place-items:center;
  color:var(--gold);background:#1a0e22;
}
.spec-list h4{font-size:.95rem;color:var(--gold);letter-spacing:.14em;margin-bottom:.2rem}
.spec-list p{font-size:.9rem;margin:0}

/* ===== Blog cards ===== */
.blog-list{display:grid;gap:1.6rem}
.blog-card{
  display:grid;grid-template-columns:200px 1fr;gap:1.4rem;
  background:linear-gradient(180deg, rgba(28,21,48,.55), rgba(20,14,33,.55));
  border:1px solid rgba(224,168,58,.15);
  border-radius:6px;padding:1rem;align-items:center;
  transition:transform .2s, border-color .2s;
}
.blog-card:hover{transform:translateY(-3px);border-color:var(--gold)}
.blog-card .thumb{width:200px;height:140px;border-radius:4px;overflow:hidden;background:#1a0e22}
.blog-card .thumb img{width:100%;height:100%;object-fit:cover}
.blog-card .meta{font-size:.72rem;color:var(--red-bright);letter-spacing:.18em;text-transform:uppercase;margin-bottom:.5rem}
.blog-card .meta span{color:var(--cream-dim);margin-left:.6rem}
.blog-card h3{font-size:1.2rem;margin-bottom:.4rem;color:var(--cream)}
.blog-card .read{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-family:var(--display)}

.sidebar{display:grid;gap:1.6rem}
.side-card{
  background:linear-gradient(180deg, rgba(28,21,48,.6), rgba(20,14,33,.6));
  border:1px solid rgba(224,168,58,.15);border-radius:6px;padding:1.4rem;
}
.side-card h4{margin-bottom:1rem;font-size:.82rem;letter-spacing:.2em}
.side-card .cat-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px dashed rgba(224,168,58,.18);font-size:.88rem;color:var(--cream-dim)}
.side-card .cat-row:last-child{border:none}
.side-card .cat-row span{color:var(--gold)}
.side-card .featured-img{width:100%;border-radius:4px;margin-bottom:.9rem;height:140px;object-fit:cover}
.side-card input[type=email]{
  width:100%;padding:.7rem .9rem;background:#0e0918;border:1px solid rgba(224,168,58,.3);
  color:var(--cream);border-radius:3px;margin-bottom:.6rem;font-family:var(--body);
}
.side-card .btn{width:100%;justify-content:center}

.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:2.5rem}
.pagination{display:flex;gap:.4rem;justify-content:center;margin-top:2rem}
.pagination a{
  width:36px;height:36px;display:grid;place-items:center;
  border:1px solid rgba(224,168,58,.25);color:var(--cream);font-family:var(--display);
  font-size:.85rem;border-radius:3px;
}
.pagination a.active,.pagination a:hover{background:var(--red);color:#fff;border-color:var(--red)}

/* ===== Gallery ===== */
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.gallery-grid .g{
  position:relative;border-radius:6px;overflow:hidden;
  border:1px solid rgba(224,168,58,.18);background:#1a0e22;
  aspect-ratio:1/1;cursor:pointer;transition:transform .2s;
}
.gallery-grid .g:hover{transform:scale(1.02);border-color:var(--gold)}
.gallery-grid .g img{width:100%;height:100%;object-fit:cover}
.gallery-grid .tall{grid-row:span 2;aspect-ratio:auto;height:100%}
.gallery-grid .wide{grid-column:span 2}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem}
.form-card{
  background:linear-gradient(180deg, rgba(28,21,48,.7), rgba(20,14,33,.7));
  border:1px solid rgba(224,168,58,.2);border-radius:8px;padding:2.4rem;
}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--display);letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;color:var(--gold);margin-bottom:.4rem}
.field input,.field textarea,.field select{
  width:100%;padding:.85rem 1rem;background:#0e0918;
  border:1px solid rgba(224,168,58,.25);color:var(--cream);
  border-radius:3px;font-family:var(--body);font-size:.95rem;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.contact-info p{font-size:.95rem}
.contact-info .info-row{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.4rem}
.contact-info .info-row .ico-circle{flex-shrink:0}
.contact-info .info-row h4{margin-bottom:.2rem}

/* ===== Layouts: about / cast ===== */
.two-col{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center}
.two-col img{width:100%;border-radius:6px;filter:drop-shadow(0 18px 40px rgba(0,0,0,.5))}

.expect-cast{display:grid;grid-template-columns:1.1fr .9fr 1.1fr;gap:2rem;margin-top:2rem}
.expect-cast .col h3{color:var(--gold);text-align:center;margin-bottom:1.4rem;letter-spacing:.18em;font-size:1.05rem;text-transform:uppercase}
.expect-cast .item{display:grid;grid-template-columns:48px 1fr;gap:1rem;margin-bottom:1.4rem;align-items:start}
.expect-cast .item .ico-circle{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--gold);display:grid;place-items:center;color:var(--gold);background:#1a0e22}
.expect-cast .item h4{font-size:.95rem;letter-spacing:.14em;margin-bottom:.2rem;color:var(--gold)}
.expect-cast .item p{font-size:.86rem;margin:0}
.expect-cast .center-img img{width:100%;border-radius:6px}

.bottom-cta{
  display:grid;grid-template-columns:1fr 1fr;gap:2rem;
  background:linear-gradient(180deg, rgba(36,21,28,.7), rgba(28,16,28,.7));
  border:2px solid var(--red);padding:2.4rem;border-radius:6px;align-items:center;margin-top:3rem;
}
.bottom-cta h3{font-size:1.8rem;color:var(--gold)}
.bottom-cta .actions{display:flex;gap:1rem;flex-wrap:wrap}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .hero-grid,.two-col,.contact-grid,.split-inner,.expect-cast,.bottom-cta,.blog-layout{grid-template-columns:1fr}
  .cast-row{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .blog-card{grid-template-columns:1fr}
  .blog-card .thumb{width:100%;height:200px}
  .footer-grid{grid-template-columns:1fr}
  .nav-links{display:none;flex-direction:column;background:#0e0918;position:absolute;top:100%;left:0;right:0;padding:1.4rem;border-bottom:1px solid var(--gold)}
  .nav-links.open{display:flex}
  .menu-toggle{display:block}
  .split::before,.split::after{display:none}
  .gallery-grid .tall,.gallery-grid .wide{grid-row:auto;grid-column:auto;aspect-ratio:1/1}
}
