/* HavaNagila.org shared layout (PROMPT_0731 rework: real pages + top and left nav).
   Cream, Nunito, festive. No dark, no italics, no long dashes. */
:root{
  --cream:#FFF9F2;
  --cream-deep:#FBEFDD;
  --ink:#2B2622;
  --muted:#6E645B;
  --gold:#C8962A;
  --gold-deep:#A6791C;
  --line:#EFE3D2;
  --royal:#26386B;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Nunito',system-ui,-apple-system,'Segoe UI',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--gold-deep);font-weight:800;text-decoration:none;}
a:hover{text-decoration:underline;}
.wrap{width:100%;max-width:920px;margin:0 auto;padding:0 20px;}
.section{padding:clamp(1.8rem,4vw,2.8rem) 0;}
.section-label{
  font-weight:800;letter-spacing:0.2em;text-transform:uppercase;
  font-size:0.72rem;color:var(--gold);margin:0 0 10px;
}
h1{font-weight:900;font-size:clamp(2.1rem,6vw,3.4rem);line-height:1.05;margin:0 0 12px;}
h2{
  font-weight:900;font-size:clamp(1.5rem,3.4vw,2.1rem);
  line-height:1.14;margin:0 0 14px;color:var(--ink);
}

/* ---- Top bar ---- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,249,242,0.94);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.topbar-in{
  max-width:1240px;margin:0 auto;padding:10px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:8px 16px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;color:var(--ink);font-size:1rem;white-space:nowrap;}
.brand:hover{text-decoration:none;}
.brand img{width:32px;height:32px;border-radius:9px;display:block;border:1px solid var(--line);}
.topnav{display:flex;flex-wrap:wrap;gap:4px 18px;justify-content:flex-end;font-size:0.92rem;}
.topnav a{font-weight:800;color:var(--gold-deep);white-space:nowrap;padding:3px 0;}
.topnav a[aria-current="page"]{color:var(--ink);border-bottom:2px solid var(--gold);}
.topnav a:hover{text-decoration:none;color:var(--ink);}

/* ---- Shell: left sidebar + content ---- */
.shell{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:210px minmax(0,1fr);gap:0 12px;
  align-items:start;
}
.sidenav{
  position:sticky;top:64px;
  padding:22px 8px 22px 20px;
}
.sidenav .side-label{
  font-weight:800;letter-spacing:0.18em;text-transform:uppercase;
  font-size:0.66rem;color:var(--gold);margin:0 0 8px 12px;
}
.sidenav a{
  display:block;font-weight:800;color:var(--ink);font-size:0.95rem;
  padding:8px 12px;border-radius:10px;margin:2px 0;
}
.sidenav a:hover{background:#fff;text-decoration:none;color:var(--gold-deep);}
.sidenav a[aria-current="page"]{background:#fff;border:1px solid var(--line);color:var(--gold-deep);box-shadow:0 6px 18px rgba(168,121,28,0.07);}
.sidenav .side-out{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);}
.sidenav .side-out a{font-size:0.85rem;color:var(--muted);}
main{min-width:0;}

@media (max-width:900px){
  .shell{grid-template-columns:1fr;}
  .sidenav{display:none;}
  .topnav{font-size:0.8rem;gap:2px 12px;}
  .brand{font-size:0.92rem;}
}

/* ---- Hero (home) ---- */
.hero-sec{text-align:center;padding-top:clamp(2rem,5vw,3.4rem);}
.mark{
  margin:0 auto 22px;width:104px;height:104px;border-radius:22px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:#fff;border:1px solid var(--line);
  box-shadow:0 10px 30px rgba(168,121,28,0.08);
}
.mark img{width:100%;height:100%;object-fit:cover;display:block;}
.kicker{
  font-weight:800;letter-spacing:0.26em;text-transform:uppercase;
  font-size:0.8rem;color:var(--gold-deep);margin:0 0 12px;
}
.hero-sec h1{font-size:clamp(2.5rem,8vw,4.2rem);line-height:1.02;}
.subhead{
  font-weight:700;font-size:clamp(1.15rem,3.2vw,1.5rem);color:var(--gold-deep);
  margin:0 auto 26px;max-width:26ch;
}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:0 0 34px;}
.btn{
  display:inline-block;font-weight:800;font-size:0.98rem;letter-spacing:0.01em;
  padding:13px 26px;border-radius:999px;text-decoration:none;transition:transform .12s ease;
}
.btn:hover{text-decoration:none;transform:translateY(-1px);}
.btn-primary{background:var(--royal);color:#fff;}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);}

/* ---- Stats ---- */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
  max-width:760px;margin:0 auto;
}
.stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 10px;}
.stat .n{font-weight:900;font-size:clamp(1.2rem,3vw,1.7rem);color:var(--royal);line-height:1;}
.stat .l{font-weight:700;font-size:0.76rem;color:var(--muted);margin-top:6px;letter-spacing:0.02em;}
@media (max-width:600px){ .stats{grid-template-columns:1fr 1fr;} }

/* ---- Text blocks ---- */
.lede p{font-size:1.08rem;color:var(--ink);margin:0 auto 16px;max-width:64ch;}
.lede .muted{color:var(--muted);font-size:1rem;}

/* ---- Series band ---- */
.band{background:var(--royal);color:#fff;border-radius:22px;padding:clamp(1.6rem,4vw,2.4rem);}
.band .section-label{color:#F1CE7E;}
.band h2{color:#fff;}
.band p{color:#E7E3F0;font-size:1.06rem;margin:0 0 6px;max-width:66ch;}
.band .pill{
  display:inline-block;margin-top:14px;background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.22);border-radius:999px;
  padding:7px 15px;font-weight:800;font-size:0.82rem;color:#fff;letter-spacing:0.03em;
}

/* ---- Video grid ---- */
.videos{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:600px){ .videos{grid-template-columns:1fr;} }
.vid{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 8px 24px rgba(168,121,28,0.06);transition:transform .12s ease,box-shadow .12s ease;}
.vid:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(168,121,28,0.12);text-decoration:none;}
.vid .thumb{position:relative;aspect-ratio:16/9;background:var(--cream-deep);}
.vid .thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.vid .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
.vid .play span{width:54px;height:54px;border-radius:50%;background:rgba(38,56,107,0.86);
  display:flex;align-items:center;justify-content:center;}
.vid .play span::after{content:"";border-style:solid;border-width:10px 0 10px 17px;
  border-color:transparent transparent transparent #fff;margin-left:4px;}
.vid .meta{padding:13px 15px 15px;}
.vid .t{font-weight:900;color:var(--ink);font-size:1.02rem;margin:0 0 3px;}
.vid .s{font-weight:700;color:var(--muted);font-size:0.85rem;margin:0;}

/* ---- Projects ---- */
.projects{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media (max-width:600px){ .projects{grid-template-columns:1fr;} }
.proj{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 20px;
  box-shadow:0 8px 24px rgba(168,121,28,0.06);transition:transform .12s ease,box-shadow .12s ease;}
.proj:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(168,121,28,0.12);text-decoration:none;}
.proj-name{font-weight:900;font-size:1.06rem;color:var(--ink);margin:0 0 4px;}
.proj-desc{font-weight:600;font-size:0.92rem;color:var(--muted);margin:0 0 8px;line-height:1.45;}
.proj-go{font-weight:800;font-size:0.85rem;color:var(--gold-deep);}
.proj.small{background:var(--cream);box-shadow:none;}

/* ---- Teaser cards (home) ---- */
.teasers{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
@media (max-width:760px){ .teasers{grid-template-columns:1fr;} }

/* ---- Contact ---- */
.contact{text-align:center;background:var(--cream-deep);border:1px solid var(--line);border-radius:22px;
  padding:clamp(1.8rem,4vw,2.6rem);}
.contact p{font-size:1.08rem;color:var(--ink);font-weight:600;margin:0 auto 18px;max-width:48ch;}

/* ---- RIGLI world footer ---- */
.rigli-portfolio{margin:38px 0 0;text-align:center;font-size:0.95rem;color:var(--muted);font-weight:600;}
.rigli-portfolio-lead{margin:0 0 4px;}
.rigli-portfolio-links{margin:0;}
.rigli-portfolio .sep{color:var(--gold);margin:0 8px;font-weight:800;}
.rigli-footer{margin-top:24px;font-size:0.82rem;color:var(--muted);border-top:1px solid var(--line);
  padding-top:18px;text-align:center;padding-bottom:26px;}
