:root{
  --bg:#050505;
  --white:#ffffff;
  --text:rgba(255,255,255,.94);
  --muted:rgba(255,255,255,.82);
  --soft:rgba(255,255,255,.64);
  --line:rgba(255,255,255,.18);
  --glass:rgba(255,255,255,.14);
  --glass-strong:rgba(255,255,255,.2);
  --chip:#ffffff;
  --chip-text:#111111;
  --red:#ea5a52;
  --blue:#1cb8ff;
  --green:#37d167;
  --purple:#7f5be0;
  --pink:#ff69a8;
  --yellow:#ffd43b;
  --orange:#f59f38;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  color:var(--text);
  font-family:Arial,Helvetica,sans-serif;
  line-height:1.35;
  background-color:var(--bg);
  background-image:linear-gradient(180deg,rgba(8,8,8,.06),rgba(8,8,8,.25)),url('caleidofest-kaleidoscope-bg-long-clean.jpg');
  background-repeat:no-repeat;
  background-position:center top;
  background-size:min(1600px,100vw) auto;
}
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(3,3,3,.06),rgba(3,3,3,.18) 32%,rgba(3,3,3,.22) 62%,rgba(3,3,3,.42));
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1180px,calc(100% - 32px));margin:0 auto;position:relative;z-index:1}
.page{position:relative;z-index:1}
.topnav{position:sticky;top:0;z-index:90;padding:12px 0;background:linear-gradient(180deg,rgba(10,10,10,.16),rgba(10,10,10,.08));backdrop-filter:blur(14px)}
.nav-shell{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:rgba(255,255,255,.08);backdrop-filter:blur(18px)}
.brand{display:flex;align-items:center;gap:10px;font-size:clamp(21px,2.2vw,31px);font-weight:700;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.fest-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px 5px;border-radius:999px;background:#fff;color:#624cce;font-size:.54em;line-height:1;text-transform:uppercase;font-weight:800}
.links{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.links a{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:#fff;backdrop-filter:blur(10px)}
.links a[aria-current="page"],.links a.active{background:var(--chip);color:var(--chip-text);font-weight:800;border-color:#fff}
.links a:hover{background:rgba(255,255,255,.16)}
.section{padding:68px 0}
.poster-hero{padding-top:34px;padding-bottom:70px}
.poster-grid{display:grid;grid-template-columns:minmax(0,720px) minmax(260px,340px);gap:28px;align-items:start}
.poster-canvas{position:relative;min-height:1600px;border-radius:36px;overflow:hidden;background:#121212;border:1px solid rgba(255,255,255,.1)}
.poster-vac{position:absolute;inset:0;background:url('poster-bg.webp') center top/cover no-repeat;filter:saturate(1.04) contrast(1.03)}
.poster-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.06),rgba(0,0,0,.12) 44%,rgba(0,0,0,.22) 100%)}
.poster-item{position:absolute;z-index:3}
.poster-item img{display:block;width:100%;height:auto}
.poster-badge{position:absolute;left:52%;top:5.6%;transform:translateX(-50%);z-index:5;text-align:center}
.poster-badge .brand-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:16px;background:#6f4fd4;color:#fff;font-size:24px;letter-spacing:.03em;font-weight:800;text-transform:uppercase}
.poster-badge .date-chip{display:inline-flex;margin-top:8px;padding:8px 12px;border-radius:14px;background:rgba(109,77,204,.88);color:#fff;font-size:18px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.poster-title-strip,.poster-trueque-strip,.poster-entry-strip{position:absolute;z-index:6;text-transform:uppercase;font-weight:900;letter-spacing:.02em}
.poster-title-strip{left:51%;top:34.8%;transform:translateX(-50%) rotate(-2.4deg);font-size:72px;line-height:1;color:#fff;padding:0 20px;height:116px;display:flex;align-items:center;justify-content:center;background:url('strip-blue.png') center/100% 100% no-repeat;min-width:360px}
.poster-trueque-strip{left:51.5%;top:60.6%;transform:translateX(-50%) rotate(-2deg);display:flex;flex-direction:column;align-items:center;gap:8px}
.poster-trueque-main{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;height:78px;min-width:320px;font-size:50px;color:#fff;background:url('strip-red.png') center/100% 100% no-repeat}
.poster-trueque-tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.poster-trueque-tags span{padding:9px 12px;border-radius:999px;font-size:16px;line-height:1;font-weight:900}
.poster-trueque-tags .ropa{background:var(--orange);color:#111}
.poster-trueque-tags .libros{background:var(--white);color:#111}
.poster-trueque-tags .estampitas{background:var(--blue);color:#fff}
.poster-entry-strip{left:51%;bottom:14%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px}
.poster-entry-badge{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;height:74px;min-width:330px;font-size:40px;color:#fff;background:url('strip-green.png') center/100% 100% no-repeat}
.poster-location{font-size:15px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;text-align:center}
.item-biennali{width:180px;top:30.8%;right:12.8%;transform:rotate(-3deg)}
.item-pan{width:190px;top:41.2%;right:21.5%;transform:rotate(3deg)}
.item-books{width:270px;top:63%;left:7.3%;transform:rotate(-11deg)}
.item-cards{width:160px;top:57%;left:16%;transform:rotate(-4deg)}
.item-jerseys{width:235px;top:51.8%;right:3%;transform:rotate(1deg)}
.item-map{left:0;right:0;bottom:0;height:200px;overflow:hidden}
.item-map img{width:100%;height:100%;object-fit:cover;object-position:center bottom}
.poster-note{position:sticky;top:104px;align-self:start;padding:22px 18px 22px 20px;border-left:1px solid rgba(255,255,255,.4);max-width:320px}
.eyebrow{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);margin-bottom:12px}
.hero-note-title{font-size:clamp(34px,5vw,58px);line-height:.95;font-weight:300;text-transform:uppercase;letter-spacing:-.05em;margin:0 0 12px}
.lead{margin:0;color:var(--muted);font-size:clamp(17px,2vw,22px)}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:20px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:13px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.86);background:rgba(255,255,255,.08);backdrop-filter:blur(10px);font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.btn.fill{background:#fff;color:#111;border-color:#fff}
.btn.small{min-height:40px;padding:10px 14px;font-size:12px}
.section-title{margin:0;font-size:clamp(38px,7vw,86px);line-height:.9;font-weight:300;letter-spacing:-.05em;text-transform:uppercase}
.section-copy{max-width:760px;color:var(--muted);font-size:clamp(16px,2vw,21px);margin:12px 0 0}
.tear-banner{margin:0 auto 30px;max-width:980px;padding:22px 22px 26px;border-radius:18px;background:rgba(255,255,255,.9);color:#111;position:relative;overflow:hidden}
.tear-banner::before,.tear-banner::after{content:"";position:absolute;left:-2%;width:104%;height:22px;background:radial-gradient(circle at 12px 16px, transparent 11px, rgba(255,255,255,.9) 12px)}
.tear-banner::before{top:-10px;transform:rotate(180deg)}
.tear-banner::after{bottom:-10px}
.tear-label{display:block;font-size:11px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;opacity:.72;margin-bottom:8px}
.tear-banner strong{display:block;font-size:clamp(24px,4vw,42px);line-height:1;margin-bottom:8px;text-transform:uppercase}
.promos-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:28px}
.promo-card{display:grid;grid-template-columns:160px 1fr;gap:16px;align-items:center;padding:14px;border:1px solid rgba(255,255,255,.14);border-radius:26px;background:rgba(6,6,6,.26);backdrop-filter:blur(10px)}
.promo-thumb{aspect-ratio:1/1;border-radius:20px;overflow:hidden;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center}
.promo-thumb img{width:100%;height:100%;object-fit:contain;object-position:center}
.promo-label{display:inline-flex;padding:4px 10px;border-radius:999px;background:#fff;color:#111;font-size:11px;font-weight:900;letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}
.promo-card h3{margin:0 0 8px;font-size:clamp(28px,3vw,40px);line-height:.95;font-weight:300;text-transform:uppercase}
.promo-card p{margin:0;color:var(--muted);font-size:15px}
.placeholder-copy{font-size:13px;color:var(--soft);margin-top:10px;text-transform:uppercase;letter-spacing:.08em}
.mid-section{padding-top:24px}
.route-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:26px}
.route-card{padding:18px;border-top:1px solid var(--line);background:rgba(255,255,255,.04)}
.route-card h3{margin:0 0 8px;font-size:clamp(26px,3vw,36px);font-weight:300;line-height:.95;text-transform:uppercase}
.route-card p{margin:0;color:var(--muted)}
.map-cta-panel{margin-top:24px;padding:12px;border:1px solid rgba(255,255,255,.12);border-radius:28px;background:rgba(255,255,255,.06);backdrop-filter:blur(12px)}
.map-media{position:relative;border-radius:22px;overflow:hidden}
.map-media img{width:100%;height:auto;display:block}
.map-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.26))}
.map-overlay-inner{max-width:620px;text-align:center;padding:22px 18px;border-radius:24px;background:rgba(255,255,255,.14);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.24)}
.callout{display:inline-flex;padding:6px 10px;border-radius:999px;background:#fff;color:#111;font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.footer{padding:52px 0 72px}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:end;padding-top:20px;border-top:1px solid var(--line)}
.small{font-size:14px;color:var(--soft)}
.page-sub .sub-hero{padding:90px 0 40px}
.sub-grid{display:grid;grid-template-columns:minmax(0,700px) minmax(0,320px);gap:26px;align-items:end}
.sub-grid .hero-note-title{font-size:clamp(42px,7vw,88px)}
.sub-panel{padding:18px 0;border-top:1px solid var(--line)}
.sub-panel h2{margin:0 0 8px;font-size:clamp(30px,5vw,56px);font-weight:300;line-height:.92;text-transform:uppercase}
.sub-panel p,.sub-panel li{color:var(--muted);font-size:16px}
.sub-panel ul{margin:10px 0 0 18px;padding:0}

@media (max-width: 1080px){
  .poster-grid,.sub-grid,.footer-grid{grid-template-columns:1fr}
  .poster-note{position:relative;top:auto;max-width:none;border-left:0;border-top:1px solid rgba(255,255,255,.4);padding-left:0;padding-top:18px}
}
@media (max-width: 760px){
  .wrap{width:min(100% - 24px,680px)}
  .topnav{padding:10px 0}
  .nav-shell{border-radius:28px;align-items:flex-start}
  .links{justify-content:flex-start;overflow:auto;flex-wrap:nowrap;width:100%;padding-bottom:4px}
  .links a{white-space:nowrap}
  .poster-canvas{min-height:1280px;border-radius:26px}
  .poster-badge .brand-chip{font-size:18px;padding:8px 12px}
  .poster-badge .date-chip{font-size:14px;padding:7px 10px}
  .poster-title-strip{font-size:44px;min-width:250px;height:78px;top:34%}
  .poster-trueque-main{font-size:28px;min-width:220px;height:56px}
  .poster-trueque-tags span{font-size:12px;padding:7px 8px}
  .poster-entry-badge{font-size:24px;min-width:230px;height:52px}
  .poster-location{font-size:11px}
  .item-biennali{width:110px}
  .item-pan{width:110px}
  .item-books{width:170px}
  .item-cards{width:110px}
  .item-jerseys{width:150px}
  .item-map{height:120px}
  .promos-grid,.route-grid{grid-template-columns:1fr}
  .promo-card{grid-template-columns:110px 1fr;padding:12px;border-radius:22px}
  .promo-card h3{font-size:26px}
  .btn{width:100%}
  .cta-row{align-items:stretch}
}
