/*
Theme Name: AttiMatti
Theme URI: https://attimatti.it
Author: AttiMatti
Author URI: https://attimatti.it
Description: Tema ufficiale AttiMatti — Scuola di Improvvisazione Teatrale a Rimini. Design arancio su crema, Archivo typeface.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: attimatti
Tags: custom-colors, custom-logo, custom-menu, featured-images, theater, orange
*/

/* ============================================================
   Design System — variabili, tipo, palette
   ============================================================ */

:root{
  --font-display: "Archivo", "Helvetica Neue", Arial, sans-serif;
  --font-body:    "Archivo", "Helvetica Neue", Arial, sans-serif;

  /* brand (override via Customizer → wp_head) */
  --brand:       #FF6A00;
  --brand-deep:  #D95900;
  --brand-soft:  #FFE7D4;

  /* palette "Arancio / Crema" default */
  --bg:          #FBF6EF;
  --surface:     #FFFFFF;
  --surface-2:   #F4ECE2;
  --ink:         #161210;
  --ink-soft:    #4C443D;
  --muted:       #8A7F75;
  --line:        #E7DCCE;
  --hero-ink:    #FFFFFF;
  --accent:      var(--brand);
  --footer-bg:   #161210;
  --footer-ink:  #EDE6DD;
  --search-bg:   #161210;

  --radius: 4px;
  --maxw:   1240px;
  --cut:    26px;
}

*{ box-sizing: border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--brand); color:#fff; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 32px; }

.display{
  font-family: var(--font-display);
  font-weight: 800;
  font-stretch: 125%;
  line-height: .98;
  letter-spacing: -.01em;
  text-transform: uppercase;
}
.eyebrow{
  font-family: var(--font-display);
  font-weight: 700;
  font-stretch: 100%;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 12px;
  color: var(--brand-deep);
}

/* ============================== TOPBAR ============================== */
.topbar{
  background: var(--brand);
  color:#fff;
  font-family: var(--font-display);
  font-weight:700;
  font-size:12.5px;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-align:center;
  padding:8px 16px;
}
.topbar a{ color:#fff; text-decoration:underline; }

/* ============================== HEADER / NAV ============================== */
header.nav{
  position:sticky; top:0; z-index:60;
  background:var(--surface);
  border-bottom:1px solid var(--line);
}
.nav-top{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  height:80px;
}
.nav-logo{ display:flex; flex-direction:column; align-items:flex-start; gap:4px; flex:0 0 auto; text-decoration:none; }
.nav-logo img{ height:46px; width:auto; }
.nav-claim{
  font-family:var(--font-display); font-weight:700; font-size:9.5px;
  letter-spacing:.1em; text-transform:uppercase; color:var(--brand-deep); line-height:1.25;
}
.nav-links{
  display:flex; align-items:center; gap:0; flex:1; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-stretch:100%;
  text-transform:uppercase; letter-spacing:.03em; font-size:11.5px;
}
.nav-links a{
  position:relative; padding:10px; color:var(--ink);
  white-space:nowrap; display:inline-block;
}
.nav-links a::after{
  content:""; position:absolute; left:10px; right:100%; bottom:0; height:3px;
  background:var(--brand); transition:right .25s ease;
}
.nav-links a:hover::after{ right:10px; }
.nav-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.icon-btn{
  display:grid; place-items:center; width:40px; height:40px;
  border:none; background:transparent; color:var(--ink); border-radius:50%;
}
.icon-btn:hover{ background:var(--surface-2); }
.nav-cta{
  background:var(--ink); color:#fff;
  font-family:var(--font-display); font-weight:800; font-stretch:100%;
  text-transform:uppercase; letter-spacing:.04em; font-size:13px;
  padding:12px 20px; border:none; white-space:nowrap; cursor:pointer;
}
.nav-cta:hover{ background:var(--brand); }
.burger{ display:none; }

/* mobile menu */
.mobile-menu{
  display:none; flex-direction:column; background:var(--surface);
  border-top:1px solid var(--line); padding:16px 0;
}
.mobile-menu.is-open{ display:flex; }
.mobile-menu a{
  padding:14px 32px; font-family:var(--font-display); font-weight:700;
  text-transform:uppercase; letter-spacing:.04em; font-size:13px;
  border-bottom:1px solid var(--line); color:var(--ink);
}
.mobile-menu a:last-child{ border-bottom:none; }

/* ============================== HERO ============================== */
.hero{ position:relative; background:#0c0a09; overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media video,
.hero-media .stage-scene{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-grad{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg,rgba(12,10,9,.55) 0%,rgba(12,10,9,0) 28%,rgba(12,10,9,0) 45%,rgba(12,10,9,.82) 100%),
    linear-gradient(90deg,rgba(12,10,9,.7) 0%,rgba(12,10,9,.1) 55%,rgba(12,10,9,0) 100%);
}
.hero-inner{ position:relative; z-index:2; }

/* animated stage scene */
.stage-scene{ background:radial-gradient(120% 90% at 50% 120%,#2a1c12 0%,#14100c 45%,#0a0807 100%); }
.stage-scene .floor{
  position:absolute; left:-10%; right:-10%; bottom:-2%; height:42%;
  background:radial-gradient(60% 120% at 50% 0%,rgba(255,106,0,.18),rgba(255,106,0,0) 70%);
  transform:perspective(500px) rotateX(58deg); transform-origin:bottom;
}
.spot{
  position:absolute; top:-18%; width:55%; height:150%;
  background:linear-gradient(180deg,rgba(255,255,255,.32),rgba(255,210,160,.10) 40%,rgba(255,160,60,0) 78%);
  filter:blur(6px); mix-blend-mode:screen;
  clip-path:polygon(46% 0,54% 0,100% 100%,0 100%);
}
.spot.s1{ left:2%;  animation:sweep1 9s ease-in-out infinite; }
.spot.s2{ right:2%; animation:sweep2 11s ease-in-out infinite; background:linear-gradient(180deg,rgba(255,170,90,.30),rgba(255,120,30,.08) 45%,rgba(255,120,30,0) 80%); }
@keyframes sweep1{ 0%,100%{transform:rotate(-9deg) translateX(0)} 50%{transform:rotate(7deg) translateX(8%)} }
@keyframes sweep2{ 0%,100%{transform:rotate(8deg) translateX(0)} 50%{transform:rotate(-7deg) translateX(-8%)} }
.haze{ position:absolute; inset:0; background:radial-gradient(40% 30% at 50% 70%,rgba(255,150,60,.22),rgba(0,0,0,0) 70%); animation:pulse 6s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{opacity:.6} 50%{opacity:1} }
.dust{ position:absolute; inset:0; background-image:
  radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.5),transparent),
  radial-gradient(1.5px 1.5px at 70% 40%,rgba(255,255,255,.4),transparent),
  radial-gradient(1.5px 1.5px at 45% 65%,rgba(255,220,180,.5),transparent),
  radial-gradient(2px 2px at 85% 70%,rgba(255,255,255,.35),transparent),
  radial-gradient(1px 1px at 32% 80%,rgba(255,255,255,.4),transparent);
  animation:drift 12s linear infinite; opacity:.7; }
@keyframes drift{ from{transform:translateY(0)} to{transform:translateY(-40px)} }
.scene-zoom{ position:absolute; inset:0; animation:kb 18s ease-in-out infinite alternate; }
@keyframes kb{ from{transform:scale(1)} to{transform:scale(1.08)} }

/* hero content layouts */
.hero-inner{ display:flex; align-items:flex-end; min-height:620px; padding:56px 0 52px; }
.hero-content{ max-width:720px; }
.hero-tag{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; font-size:12.5px; color:#fff;
  background:var(--brand); padding:7px 13px; margin-bottom:18px;
}
.hero-tag .rec{ animation:rec 1.4s ease-in-out infinite; }
@keyframes rec{ 0%,100%{opacity:1} 50%{opacity:.25} }
.hero-date{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; font-size:14px; color:var(--brand); margin:0 0 10px;
}
.hero-title{ color:#fff; font-size:clamp(48px,7.2vw,104px); margin:0 0 16px; }
.hero-sub{ color:rgba(255,255,255,.86); font-size:clamp(17px,1.5vw,21px); max-width:560px; margin:0 0 28px; line-height:1.45; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; }

.hero[data-layout="centro"] .hero-inner{ align-items:center; justify-content:center; text-align:center; }
.hero[data-layout="centro"] .hero-content{ max-width:860px; }
.hero[data-layout="centro"] .hero-sub{ margin-left:auto; margin-right:auto; }
.hero[data-layout="centro"] .hero-ctas{ justify-content:center; }
.hero[data-layout="centro"] .hero-grad{
  background:linear-gradient(180deg,rgba(12,10,9,.5),rgba(12,10,9,.25) 45%,rgba(12,10,9,.8) 100%);
}
.hero[data-layout="split"] .hero-inner{ align-items:stretch; padding:0; min-height:600px; }
.hero[data-layout="split"] .split-text{
  position:relative; z-index:2; align-self:center;
  background:var(--brand); color:#fff;
  padding:52px 48px; max-width:560px; margin:0;
}
.hero[data-layout="split"] .hero-grad{ background:linear-gradient(90deg,rgba(12,10,9,0) 40%,rgba(12,10,9,.4) 100%); }
.hero[data-layout="split"] .hero-title{ font-size:clamp(40px,5vw,76px); }
.hero[data-layout="split"] .hero-date{ color:#fff; }
.hero[data-layout="split"] .hero-tag{ background:#fff; color:var(--brand-deep); }
.hero[data-layout="split"] .hero-sub{ color:rgba(255,255,255,.92); }

/* ============================== BUTTONS ============================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-display); font-weight:800; font-stretch:100%;
  text-transform:uppercase; letter-spacing:.05em; font-size:14px;
  padding:15px 26px; border:2px solid transparent; border-radius:0;
  transition:transform .12s ease, background .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap; cursor:pointer;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--brand); color:#fff; border-color:var(--brand); }
.btn-primary:hover{ background:var(--brand-deep); border-color:var(--brand-deep); }
.btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); }
.btn-ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.btn-dark{ background:var(--ink); color:#fff; border-color:var(--ink); }
.btn-dark:hover{ background:var(--brand); border-color:var(--brand); }
.btn-sm{ padding:11px 18px; font-size:12.5px; }
.btn-block{ width:100%; }

/* ============================== SEARCH ============================== */
.search-band{ background:var(--surface); padding:0; position:relative; }
.search-band .wrap{ position:relative; }
.search-card{
  margin-top:-34px; position:relative; z-index:5;
  background:var(--search-bg);
  padding:30px 34px 32px;
  box-shadow:0 24px 60px rgba(0,0,0,.28);
}
.search-card .s-title{
  color:#fff; font-family:var(--font-display); font-weight:800; font-stretch:115%;
  text-transform:uppercase; letter-spacing:.01em; font-size:24px; margin:0 0 4px; text-align:center;
}
.search-card .s-sub{ color:rgba(255,255,255,.6); text-align:center; font-size:14.5px; margin:0 0 18px; }
.search-form{ display:flex; max-width:720px; margin:0 auto; }
.search-form input{
  flex:1; border:none; background:#fff; color:var(--ink);
  padding:16px 20px; font-size:16px; font-family:var(--font-body); min-width:0;
}
.search-form input:focus{ outline:3px solid var(--brand); outline-offset:-3px; }
.search-form button{
  background:var(--brand); color:#fff; border:none; padding:0 26px;
  display:flex; align-items:center; gap:9px;
  font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:.05em; font-size:14px;
}
.search-form button:hover{ background:var(--brand-deep); }
.search-tags{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:16px; }
.search-tags span{ color:rgba(255,255,255,.5); font-size:13px; }
.search-tags a{ color:#fff; font-size:13px; border:1px solid rgba(255,255,255,.3); padding:5px 12px; border-radius:999px; }
.search-tags a:hover{ background:var(--brand); border-color:var(--brand); }

/* ============================== SECTIONS ============================== */
.section{ padding:64px 0 12px; }
.section.alt{ background:var(--surface-2); padding-bottom:56px; }
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:20px;
  border-bottom:3px solid var(--ink); padding-bottom:14px; margin-bottom:30px;
}
.section-head .titles{ display:flex; align-items:baseline; gap:16px; flex-wrap:wrap; }
.section-num{ font-family:var(--font-display); font-weight:800; font-stretch:125%; font-size:22px; color:var(--brand); }
.section-title{
  font-family:var(--font-display); font-weight:800; font-stretch:115%;
  text-transform:uppercase; font-size:clamp(26px,3.4vw,40px); line-height:1; margin:0; letter-spacing:-.01em; white-space:pre-line;
}
.section-link{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.05em; font-size:13.5px; color:var(--ink);
  display:inline-flex; align-items:center; gap:8px; padding-bottom:4px; flex:0 0 auto;
}
.section-link:hover{ color:var(--brand-deep); }
.section-link .arr{ transition:transform .2s ease; }
.section-link:hover .arr{ transform:translateX(4px); }
.section-tools{ display:flex; align-items:center; gap:20px; flex:0 0 auto; }
.carousel-nav{ display:flex; gap:9px; }
.cnav{
  width:44px; height:44px; display:grid; place-items:center;
  border:2px solid var(--ink); background:transparent; color:var(--ink); border-radius:50%;
  transition:background .15s, border-color .15s, color .15s, transform .12s;
}
.cnav:hover{ background:var(--brand); border-color:var(--brand); color:#fff; }
.cnav:active{ transform:translateY(1px); }
.cnav.prev svg{ transform:rotate(180deg); }

.card-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card-row.is-carousel{
  display:flex; grid-template-columns:none;
  overflow-x:auto; scroll-snap-type:x proximity;
  padding-bottom:8px; scrollbar-width:none; -ms-overflow-style:none;
}
.card-row.is-carousel::-webkit-scrollbar{ display:none; }
.card-row.is-carousel > .card{ flex:0 0 calc((100% - 52px)/3); scroll-snap-align:start; }

/* ============================== CARD ============================== */
.card{
  background:var(--surface); display:flex; flex-direction:column;
  border:1px solid var(--line);
  transition:transform .18s ease, box-shadow .18s ease;
}
.card:hover{ transform:translateY(-5px); box-shadow:0 18px 40px rgba(20,16,10,.14); }
.card-media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--surface-2); border-bottom:2px solid var(--brand); }
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.card:hover .card-media img{ transform:scale(1.05); }
.card-flag{
  position:absolute; top:0; left:0; background:var(--brand); color:#fff;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  font-size:11px; padding:6px 12px;
}
.card-body{ padding:18px 20px 22px; display:flex; flex-direction:column; flex:1; }
.card-date-row{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:10px; }
.card-date{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  font-size:12px; color:var(--brand-deep);
}
.card-meta{ display:inline-flex; flex-wrap:nowrap; gap:12px; }
.card-meta .meta-item{ display:inline-flex; align-items:center; gap:5px; color:var(--ink-soft); font-size:12px; font-weight:600; white-space:nowrap; }
.card-meta .meta-item svg{ color:var(--brand-deep); flex:0 0 auto; }
.card-title{ font-family:var(--font-display); font-weight:800; font-stretch:110%; font-size:21px; line-height:1.08; margin:0 0 8px; }
.card-desc{ color:var(--ink-soft); font-size:14.5px; line-height:1.5; margin:0 0 14px; flex:1; }
.card-loc{ display:flex; align-items:center; gap:7px; color:var(--muted); font-size:13px; margin-bottom:16px; }
.card-loc a{ color:var(--muted); display:inline-flex; align-items:center; gap:6px; }
.card-loc a:hover{ color:var(--brand-deep); }
.card-loc svg{ flex:0 0 auto; }
.card-actions{ display:flex; gap:10px; align-items:center; }

/* ============================== REVIEWS SECTION ============================== */
.reviews-section{ background:#000; padding:64px 0 72px; overflow:hidden; }

/* ============================== FOOTER CTA ============================== */
.footer-cta{ background:var(--brand); color:#fff; padding:44px 0; }
.footer-cta .wrap{ display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
.footer-cta h3{
  font-family:var(--font-display); font-weight:800; font-stretch:120%;
  text-transform:uppercase; font-size:clamp(26px,3.4vw,40px); margin:0; line-height:1; max-width:680px;
}

/* ============================== FOOTER ============================== */
footer.site{ background:var(--footer-bg); color:var(--footer-ink); margin-top:0; }
.footer-main{ padding:56px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; }
.footer-grid h4{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  font-size:13px; color:var(--brand); margin:0 0 16px;
}
.footer-logo{ height:44px; width:auto; margin-bottom:16px; }
.footer-about{ color:rgba(237,230,221,.7); font-size:14.5px; line-height:1.6; max-width:300px; }
.footer-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.footer-list a, .footer-contact a{ color:rgba(237,230,221,.82); font-size:14.5px; }
.footer-list a:hover, .footer-contact a:hover{ color:var(--brand); }
.footer-contact{ font-size:14.5px; line-height:1.7; color:rgba(237,230,221,.82); font-style:normal; }
.footer-contact strong{ color:#fff; }
.socials{ display:flex; gap:12px; margin-top:18px; }
.socials a{
  width:42px; height:42px; display:grid; place-items:center;
  border:1px solid rgba(237,230,221,.25); border-radius:50%; color:var(--footer-ink);
  transition:background .18s, border-color .18s, color .18s, transform .18s;
}
.socials a:hover{ background:var(--brand); border-color:var(--brand); color:#fff; transform:translateY(-3px); }
.footer-bottom{
  border-top:1px solid rgba(237,230,221,.14); padding:20px 0 30px;
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:13px; color:rgba(237,230,221,.55);
}
.footer-bottom a{ color:rgba(237,230,221,.7); }
.footer-bottom .legal{ display:flex; gap:18px; flex-wrap:wrap; }

/* ============================== CONTACT MODAL ============================== */
.modal-overlay{
  position:fixed; inset:0; z-index:200;
  background:rgba(0,0,0,.58); backdrop-filter:blur(4px);
  display:grid; place-items:center; padding:20px;
}
.modal-overlay.is-hidden{ display:none; }
.modal-box{
  background:var(--surface); width:100%; max-width:460px;
  padding:32px 28px 28px; position:relative;
  box-shadow:0 32px 80px rgba(0,0,0,.35);
}
.modal-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:6px; }
.modal-head h3{
  font-family:var(--font-display); font-weight:800; font-stretch:110%;
  text-transform:uppercase; font-size:20px; margin:0;
}
.modal-close{
  width:36px; height:36px; border:none; background:var(--surface-2);
  cursor:pointer; display:grid; place-items:center;
  font-size:18px; color:var(--muted); flex:0 0 auto; border-radius:50%;
}
.modal-close:hover{ background:var(--brand); color:#fff; }
.modal-event-tag{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.07em; font-size:12px; color:var(--brand-deep);
  margin-bottom:20px; display:block;
}
.modal-field{ display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.modal-field label{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; font-size:11px; color:var(--ink-soft);
}
.modal-field input,
.modal-field textarea{
  border:1.5px solid var(--line); background:var(--bg); color:var(--ink);
  padding:11px 14px; font-size:15px; font-family:var(--font-body); resize:vertical;
}
.modal-field input:focus,
.modal-field textarea:focus{ outline:none; border-color:var(--brand); }
.modal-actions{ display:flex; gap:10px; margin-top:22px; }
.modal-actions .btn{ flex:1; justify-content:center; }

/* ============================== BREADCRUMB ============================== */
.breadcrumb{
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  font-size:13px; color:var(--muted); padding:14px 0;
  font-family:var(--font-display); font-weight:600;
  text-transform:uppercase; letter-spacing:.06em;
}
.breadcrumb a{ color:var(--muted); }
.breadcrumb a:hover{ color:var(--brand); }
.breadcrumb .sep{ color:var(--line); }
.breadcrumb .curr{ color:var(--ink); }

/* ============================== EVENT / LISTING PAGES ============================== */
.event-hero{ position:relative; height:clamp(380px,52vw,600px); background:#0c0a09; overflow:hidden; }
.event-hero-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:brightness(.75); }
.event-hero-ph{
  position:absolute; inset:0;
  background:repeating-linear-gradient(135deg,#1d1712 0 13px,rgba(255,106,0,.16) 13px 14px);
}
.event-hero-grad{
  position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(12,10,9,.2) 0%,rgba(12,10,9,0) 30%,rgba(12,10,9,.88) 100%);
}
.event-hero-content{ position:absolute; bottom:0; left:0; right:0; padding:40px 0 36px; }
.event-hero-tag{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--brand); color:#fff;
  font-family:var(--font-display); font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; font-size:12px;
  padding:6px 13px; margin-bottom:14px;
}
.event-hero-title{ color:#fff; font-size:clamp(36px,5.5vw,76px); margin:0 0 8px; line-height:.98; }
.event-hero-venue{ color:rgba(255,255,255,.72); font-size:15px; display:flex; align-items:center; gap:8px; }

.event-body{
  display:grid; grid-template-columns:1fr 340px; gap:48px; align-items:start;
  padding:48px 0 72px;
}
.event-main{ min-width:0; }
.event-sidebar{ position:sticky; top:calc(80px + 16px + 2px); }
.event-desc{ font-size:17px; line-height:1.7; color:var(--ink-soft); }
.event-desc p{ margin:0 0 1.3em; }
.event-desc p:last-child{ margin-bottom:0; }
.event-gallery{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:36px; }
.event-gallery.single{ grid-template-columns:1fr; }
.event-gallery-item{ aspect-ratio:16/9; overflow:hidden; background:var(--surface-2); position:relative; }
.event-gallery-item img{ width:100%; height:100%; object-fit:cover; }

.event-people{ margin-top:40px; }
.event-people h3{
  font-family:var(--font-display); font-weight:800; font-stretch:110%;
  text-transform:uppercase; font-size:18px; letter-spacing:.02em;
  margin:0 0 20px; padding-bottom:10px; border-bottom:2px solid var(--ink);
}
.cast-list{ display:flex; flex-direction:column; gap:14px; }
.cast-item{ display:flex; align-items:center; gap:14px; }
.cast-avatar{
  width:44px; height:44px; border-radius:50%; background:var(--brand);
  display:grid; place-items:center; flex:0 0 auto;
  font-family:var(--font-display); font-weight:800; font-size:18px; color:#fff;
}
.cast-name{ font-family:var(--font-display); font-weight:700; font-size:15px; }
.cast-role{ color:var(--muted); font-size:13px; }
.docente-card{ display:flex; gap:20px; background:var(--surface-2); border:1px solid var(--line); padding:20px; }
.docente-photo{ width:80px; height:80px; flex:0 0 auto; overflow:hidden; background:var(--surface); }
.docente-photo img{ width:100%; height:100%; object-fit:cover; }
.docente-name{ font-family:var(--font-display); font-weight:800; font-size:17px; margin:0 0 6px; }
.docente-bio{ color:var(--ink-soft); font-size:14px; line-height:1.55; margin:0; }

.synoptic{ background:var(--ink); color:#fff; padding:28px 24px 24px; }
.synoptic-title{
  font-family:var(--font-display); font-weight:800; font-stretch:110%;
  text-transform:uppercase; font-size:13px; letter-spacing:.1em;
  color:var(--brand); margin:0 0 18px;
}
.synoptic-rows{ display:flex; flex-direction:column; gap:0; }
.synoptic-row{ display:flex; align-items:flex-start; gap:14px; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.synoptic-row:last-child{ border-bottom:none; }
.synoptic-icon{ flex:0 0 20px; color:var(--brand); margin-top:1px; }
.synoptic-label{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.07em; font-size:10.5px; color:rgba(255,255,255,.5); display:block; margin-bottom:2px;
}
.synoptic-val{ font-size:15px; color:#fff; line-height:1.35; }
.synoptic-sub{ font-size:12px; color:rgba(255,255,255,.5); margin-top:2px; display:block; }
.synoptic-price{ font-size:22px; font-family:var(--font-display); font-weight:800; color:#fff; }
.synoptic-actions{ display:flex; flex-direction:column; gap:10px; margin-top:22px; }
.synoptic-actions .btn{ width:100%; justify-content:center; }

.correlati{ padding:48px 0 64px; border-top:1px solid var(--line); }
.correlati h2{
  font-family:var(--font-display); font-weight:800; font-stretch:110%;
  text-transform:uppercase; font-size:clamp(20px,2.5vw,28px);
  margin:0 0 28px; letter-spacing:-.01em;
}

.listing-hero{ background:var(--ink); color:#fff; padding:52px 0 48px; position:relative; overflow:hidden; }
.listing-hero::after{
  content:""; position:absolute; right:-80px; top:-60px;
  width:420px; height:420px; border-radius:50%;
  background:var(--brand); opacity:.08; pointer-events:none;
}
.listing-eyebrow{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.14em; font-size:12px; color:var(--brand); margin-bottom:10px;
}
.listing-title{ font-size:clamp(40px,6vw,80px); margin:0 0 14px; color:#fff; line-height:.96; }
.listing-sub{ color:rgba(255,255,255,.72); font-size:17px; max-width:560px; margin:0; }
.listing-body{ padding:52px 0 72px; }
.listing-body .card-row{ grid-template-columns:repeat(3,1fr); }

/* social share */
.social-share{ border-top:1px solid rgba(255,255,255,.1); padding-top:18px; margin-top:20px; display:flex; flex-direction:column; gap:10px; }
.social-share-label{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:11px; color:rgba(255,255,255,.5); }
.share-btns{ display:flex; gap:10px; }
.share-btn{
  flex:1; display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.05em; font-size:12.5px;
  padding:11px 10px; border:none; cursor:pointer;
  transition:opacity .15s, transform .12s;
}
.share-btn:active{ transform:translateY(1px); }
.share-btn:hover{ opacity:.88; }
.share-fb{ background:#1877F2; color:#fff; }
.share-ig{ background:linear-gradient(135deg,#F58529,#DD2A7B 50%,#8134AF); color:#fff; }

/* search results */
.search-results{ padding:52px 0 72px; }
.search-results h1{ font-family:var(--font-display); font-weight:800; font-stretch:115%; text-transform:uppercase; font-size:clamp(28px,4vw,48px); margin:0 0 8px; }
.search-results .result-count{ color:var(--muted); font-size:15px; margin:0 0 36px; }
.search-results .card-row{ grid-template-columns:repeat(3,1fr); }
.search-no-results{ padding:80px 0; text-align:center; color:var(--muted); }
.search-no-results h2{ font-family:var(--font-display); font-size:24px; font-weight:800; text-transform:uppercase; }

/* ============================== RESPONSIVE ============================== */
@media(max-width:1000px){
  .card-row{ grid-template-columns:repeat(2,1fr); }
  .card-row.is-carousel > .card{ flex-basis:calc((100% - 26px)/2); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{ display:none; }
  .burger{ display:grid; }
  .listing-body .card-row{ grid-template-columns:repeat(2,1fr); }
  .search-results .card-row{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:760px){
  .wrap{ padding:0 18px; }
  .card-row{ grid-template-columns:1fr; }
  .card-row.is-carousel > .card{ flex-basis:84%; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-inner{ min-height:520px; }
  .hero[data-layout="split"] .split-text{ max-width:none; padding:36px 24px; }
  .search-card{ padding:24px 18px; }
  .search-form{ flex-direction:column; gap:10px; }
  .search-form button{ padding:14px; justify-content:center; }
  .section-head{ flex-direction:column; align-items:flex-start; }
  .event-body{ grid-template-columns:1fr; }
  .event-sidebar{ position:static; }
  .event-gallery{ grid-template-columns:1fr; }
  .docente-card{ flex-direction:column; }
  .listing-body .card-row{ grid-template-columns:1fr; }
  .search-results .card-row{ grid-template-columns:1fr; }
}
@media(prefers-reduced-motion:reduce){
  .spot,.haze,.dust,.scene-zoom,.rec{ animation:none !important; }
}
