/* ============================================================
   QB by qube — main stylesheet
   ============================================================ */

/* Abiah — local typeface family */
@font-face{font-family:'Abiah';src:url('../../font/Abiah-Thin.otf') format('opentype');font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:'Abiah';src:url('../../font/Abiah-Light.otf') format('opentype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Abiah';src:url('../../font/Abiah-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Abiah';src:url('../../font/Abiah-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Abiah Distorted';src:url('../../font/Abiah-Distorted.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}

/* General Sans — secondary typeface */
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Extralight.otf') format('opentype');font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-ExtralightItalic.otf') format('opentype');font-weight:200;font-style:italic;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Light.otf') format('opentype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-LightItalic.otf') format('opentype');font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Italic.otf') format('opentype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Medium.otf') format('opentype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-MediumItalic.otf') format('opentype');font-weight:500;font-style:italic;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Semibold.otf') format('opentype');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-SemiboldItalic.otf') format('opentype');font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('../../font/GeneralSans-BoldItalic.otf') format('opentype');font-weight:700;font-style:italic;font-display:swap}

:root{
  --bg:#FFFFFF;
  --cream:#F6F1E8;
  --ink:#1A1A1A;
  --muted:#5B5B5B;
  --brown-dark:#3A1F18;
  --brown-deep:#4A2A1F;
  --accent-red:#C13B33;
  --line:#D9D2C5;
  --soft:#EFE9DE;
  --serif:'Abiah','Cormorant Garamond','Times New Roman', serif;
  --sans:'General Sans','Inter','Helvetica Neue', Arial, sans-serif;
  --display:'Jost', sans-serif;
  --distorted:'Abiah Distorted','Abiah', serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* Top announcement bar — pixel-exact replica del Canva (1400×103 px reference)
   Canvas: 1400px → topbar 103px tall, bg #333333
   Texto "Habitar Espacios / Sustentables": General Sans Bold blanco, 2 líneas, left=536, top=26
   Pill "Ya en circulación": bg #6B6B6B, esquinas 3px, blanco, left=722, top=37, 186×28 px */
.topbar{
  background:#333333;
  color:#fff;
  height:103px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:16px;
}
.topbar-text{
  font-family:var(--serif);
  font-weight:400;
  font-size:20px;
  line-height:1.15;
  color:#fff;
  text-align:left;
  letter-spacing:0;
}
.topbar .pill{
  background:#6B6B6B;
  color:#fff;
  padding:5px 18px;
  border-radius:3px;
  font-family:var(--serif);
  font-weight:400;
  font-size:18px;
  letter-spacing:0;
  text-transform:none;
  display:inline-block;
  line-height:1.2;
}

/* Header */
.header{padding:22px 0 8px;border-bottom:1px solid var(--line)}
.header-grid{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.menu-btn{background:transparent;border:0;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:6px;width:32px}
.menu-btn span{display:block;height:1.5px;background:var(--ink);width:100%}
.logo{display:flex;justify-content:center;align-items:center;line-height:1}
.logo img{height:64px;width:auto;display:block}
.subscribe{
  justify-self:end;
  font-family:var(--serif);
  font-size:18px;
  color:#1a1a1a;
  border:1px solid #1a1a1a;
  padding:6px 22px;
  border-radius:2px;
  letter-spacing:.02em;
  transition:background .15s, color .15s;
}
.subscribe:hover{background:#1a1a1a;color:#fff}

/* Nav */
nav.main{padding:18px 0 14px}
nav.main ul{list-style:none;display:flex;justify-content:space-between;gap:8px;font-family:var(--serif);font-size:18px;letter-spacing:.01em;color:#222}
nav.main li a{padding:6px 4px;display:inline-block;text-align:center;line-height:1.25}
nav.main li a:hover{color:var(--accent-red)}

/* Hero — texto blanco directo sobre imagen, sin caja, sin gradiente */
.hero{position:relative;margin-top:6px;overflow:hidden}
.hero img{width:100%;height:72vh;min-height:520px;max-height:760px;object-fit:cover;object-position:center;display:block}
.hero .overlay{
  position:absolute;left:0;right:0;bottom:0;
  padding:48px 48px 38px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:48px;color:#fff;
  background:transparent;
}
.hero h1{
  font-family:var(--serif);
  font-weight:500;
  font-size:60px;
  line-height:1.05;
  max-width:780px;
  color:#fff;
  letter-spacing:0;
}
.hero h1 strong{font-weight:700}
.hero .tag{
  display:inline-block;margin-top:14px;
  border:1px solid #fff;color:#fff;
  font-family:var(--serif);font-size:18px;
  padding:3px 16px;background:rgba(0,0,0,.25);
  border-radius:2px;
}
.hero .blurb{
  background:transparent;
  color:#fff;
  padding:0;
  max-width:380px;
  font-size:14px;
  line-height:1.55;
  font-family:var(--sans);
  text-shadow:0 1px 4px rgba(0,0,0,.45);
}
.hero .blurb strong{font-weight:500}
.hero .blurb a{color:#fff;text-decoration:underline;text-underline-offset:2px}

/* Horizontal banner */
.strip-banner{max-width:1180px;margin:32px auto 0;padding:0 24px}
.strip-banner .inner{width:100%;overflow:hidden;border-radius:2px;background:#F4C752}
.strip-banner img{width:100%;height:110px;object-fit:cover;object-position:center 32%;display:block}

/* Section labels */
.section-label{display:flex;align-items:center;gap:18px;margin:54px 0 22px}
.section-label h2{font-family:var(--serif);font-size:36px;font-weight:500;letter-spacing:.01em}
.section-label .rule{flex:1;height:1px;background:var(--line)}
.section-label .sub{font-family:var(--sans);font-size:15px;color:var(--muted);letter-spacing:.02em}

.section-head{margin:54px 0 22px}
.section-head h2{font-family:var(--serif);font-size:36px;font-weight:500;letter-spacing:.01em}
.section-head .underline{height:1px;background:var(--line);margin-top:8px}
.section-head .sub{font-family:var(--sans);font-size:15px;color:var(--muted);margin-top:8px}

/* Arquitectura split layout: left stack + right cover */
.arq-split{display:grid;grid-template-columns:1fr 1px 1fr;gap:36px;align-items:start;margin-top:8px}
.arq-split::before{content:"";grid-column:2;align-self:stretch;background:var(--line);width:1px}
.arq-left{display:flex;flex-direction:column;gap:30px;grid-column:1}
.arq-right{grid-column:3;display:flex;flex-direction:column;gap:18px;color:inherit;text-decoration:none}

/* Banner card (Between Archs + Ladrillazo) */
.banner-card{display:flex;flex-direction:column;color:inherit;text-decoration:none;transition:opacity .2s}
.banner-card:hover{opacity:.9}
.banner-img{position:relative;overflow:hidden;border-radius:2px;background:#222;aspect-ratio:16/9}
.banner-img img{width:100%;height:100%;object-fit:cover;display:block}
.banner-stamp{position:absolute;top:14px;left:18px;color:#fff;font-family:var(--serif);font-weight:600;font-size:24px;line-height:.95;letter-spacing:.05em;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.banner-brand{position:absolute;top:16px;right:18px;font-family:var(--serif);font-weight:500;font-size:18px;color:#fff;background:rgba(255,255,255,.18);padding:2px 10px;border-radius:2px;backdrop-filter:blur(4px)}

/* Brick stamps for Ladrillazo overlay */
.ladrillo{position:absolute;background:#D77324;color:#fff;font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.06em;line-height:1.1;padding:4px 8px;text-align:center;border-radius:1px;box-shadow:0 2px 6px rgba(0,0,0,.25);transform:rotate(-6deg)}
.ladrillo span{display:block}
.ladrillo-1{top:36%;left:8%;transform:rotate(-9deg);font-size:14px}
.ladrillo-2{top:30%;left:18%;font-size:13px;padding:4px 10px}
.ladrillo-3{top:48%;left:28%;transform:rotate(-8deg);font-size:14px}

.banner-foot{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:14px 0 0}
.banner-foot h3{font-family:var(--serif);font-size:24px;font-weight:500;line-height:1.15;margin-bottom:4px}
.banner-foot p{font-family:var(--sans);font-size:13px;color:#555;line-height:1.4}
.vermas-btn{
  flex-shrink:0;font-family:var(--sans);font-size:12px;
  border:1px solid #c8c0b0;color:#555;
  padding:6px 16px;border-radius:2px;letter-spacing:.04em;
  background:#fafafa;
}
.vermas{font-family:var(--sans);font-size:13px;color:#aa3a32;border-bottom:1px solid #aa3a32;padding-bottom:1px}

/* Cover of the Week (right column) */
.cover-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:8px}
.cover-head h2{font-family:var(--serif);font-size:42px;font-weight:500;line-height:1;color:#3d342c}
.cover-meta{text-align:right}
.cover-title{font-family:var(--serif);font-size:18px;color:#3d342c}
.cover-author{font-family:var(--sans);font-size:11px;color:#7a7268;letter-spacing:.04em;margin-top:2px}
.cover-img{overflow:hidden;border-radius:2px;background:#222}
.cover-img img{width:100%;height:auto;display:block;aspect-ratio:4/5;object-fit:cover}

/* Horizontal divider between split section and triplet */
.section-divider{border:0;border-top:1px solid var(--line);margin:48px 0 8px}

/* 3 small cards */
.triplet{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:32px}
.triplet .card .imgwrap{aspect-ratio:16/10;overflow:hidden;border-radius:2px;background:#eee}
.triplet .card .imgwrap img{width:100%;height:100%;object-fit:cover}
.triplet .card h4{margin-top:14px;font-family:var(--serif);font-size:20px;font-weight:500;line-height:1.25}

/* Big editorial image */
.editorial{margin:34px 0}
.editorial img{width:100%;height:auto;max-height:520px;object-fit:cover}

/* Full-width brown hero (Casa Tacuri) */
.full-hero{position:relative;margin-top:60px}
.full-hero img{width:100%;height:520px;object-fit:cover}
.full-hero .caption{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.full-hero .kicker{font-family:var(--sans);font-size:14px;letter-spacing:.3em;text-transform:uppercase;opacity:.9;margin-bottom:14px}
.full-hero h2{font-family:var(--serif);font-style:normal;font-weight:500;font-size:74px;line-height:1;letter-spacing:.02em}
.full-hero .sub{margin-top:6px;font-family:var(--serif);font-size:20px;font-style:normal;opacity:.95}

/* Style Cover */
.style-cover{position:relative;margin-top:40px}
.style-cover img{width:100%;max-height:560px;object-fit:cover;filter:grayscale(.05)}
.style-cover .text{position:absolute;top:32px;left:32px;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.style-cover .text h2{font-family:var(--serif);font-style:normal;font-weight:500;font-size:74px;line-height:.95;letter-spacing:.02em}
.style-cover .text .name{font-family:var(--serif);font-size:32px;margin-top:6px}
.style-cover .text .quote{margin-top:14px;font-family:var(--sans);font-size:15px;max-width:280px;line-height:1.5;font-style:normal}

/* Orange chair */
.chair{display:flex;justify-content:center;margin:50px 0 30px}
.chair img{max-width:300px}

/* Habitar Espacios Sostenibles section */
.habitar{background:var(--brown-deep);color:#F1E8D6;padding:60px 0;margin-top:60px}
.habitar .inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:1100px;margin:0 auto;padding:0 32px}
.habitar img{width:100%;border-radius:2px}
.habitar h2{font-family:var(--serif);font-style:normal;font-weight:500;font-size:56px;line-height:1.05;text-align:center}
.habitar p{margin-top:18px;font-family:var(--sans);font-size:16px;line-height:1.6;text-align:center;max-width:380px;margin-left:auto;margin-right:auto}
.habitar .cta{display:inline-block;margin-top:24px;padding:10px 26px;border:1px solid #F1E8D6;color:#F1E8D6;font-family:var(--serif);font-size:18px;font-style:normal;border-radius:2px}
.habitar .right{text-align:center}

/* QB Guide footer */
footer.qb-guide{padding:36px 0;background:#fff}
footer.qb-guide .qb-guide-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
footer.qb-guide .line{height:1px;background:var(--line);width:100%}
footer.qb-guide .label{font-family:var(--serif);font-size:26px;font-weight:500;color:#1a1a1a;letter-spacing:.01em;padding:0 8px}

/* Make any card clickable while preserving layout */
a.card,a.feature-card{color:inherit;text-decoration:none;display:flex;flex-direction:column;transition:opacity .2s}
a.card:hover,a.feature-card:hover{opacity:.85}
a.card h4,a.feature-card h3{cursor:pointer}

/* ============================================================
   Article page
   ============================================================ */
.demo-notice{
  background:#FFF7DC;border-bottom:1px solid #E9D8A0;
  padding:10px 24px;text-align:center;
  font-family:var(--sans);font-size:14px;color:#5C4A12;
}
.demo-notice strong{color:#3a2c00}
.demo-notice code{background:#F2E2A8;padding:1px 6px;border-radius:3px;font-size:13px}

.article-hero{position:relative}
.article-hero img{width:100%;height:520px;object-fit:cover;display:block}
.article-hero-overlay{
  position:absolute;inset:0;
  display:flex;align-items:flex-end;
  background:linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.7) 100%);
  color:#fff;padding-bottom:48px;
}
.article-hero-overlay .kicker{font-family:var(--sans);font-size:13px;letter-spacing:.25em;text-transform:uppercase;opacity:.95;margin-bottom:14px}
.article-hero-overlay h1{font-family:var(--serif);font-size:54px;font-weight:500;line-height:1.05;max-width:820px}
.article-hero-overlay .byline{margin-top:14px;font-family:var(--sans);font-size:14px;opacity:.9;letter-spacing:.02em}

.article-body{max-width:760px;padding-top:50px;padding-bottom:30px}
.article-body .lede{font-family:var(--serif);font-size:24px;line-height:1.4;color:#2a2a2a;margin-bottom:28px}
.article-body p{font-family:var(--sans);font-size:17px;line-height:1.75;color:#2a2a2a;margin-bottom:20px}
.article-body .back-link{
  display:inline-block;margin-top:24px;font-family:var(--sans);font-size:14px;
  color:var(--accent-red);letter-spacing:.04em;
  border-bottom:1px solid var(--accent-red);padding-bottom:2px;
}

/* Responsive */
@media (max-width:900px){
  .article-hero img{height:340px}
  .article-hero-overlay h1{font-size:34px}
  .article-body{padding-top:32px}
  .article-body .lede{font-size:20px}
  .hero h1{font-size:34px}
  .hero .overlay{flex-direction:column;align-items:flex-start;padding:24px;gap:18px}
  .hero .blurb{font-size:13px;max-width:100%}
  .arq-split{grid-template-columns:1fr;gap:36px}
  .arq-split::before{display:none}
  .cover-head h2{font-size:30px}
  .banner-foot{flex-direction:column;align-items:flex-start;gap:12px}
  .triplet{grid-template-columns:1fr;gap:24px}
  nav.main ul{flex-wrap:wrap;justify-content:center;gap:10px 14px;font-size:11px;letter-spacing:.02em}
  nav.main li a{padding:4px 2px;line-height:1.2}
  .full-hero h2{font-size:46px}
  .style-cover .text h2{font-size:46px}
  .habitar .inner{grid-template-columns:1fr;gap:30px}
  .habitar h2{font-size:40px}
  .logo img{height:48px}
  .strip-banner img{height:80px}
  .topbar{height:auto;padding:14px 16px}
  .topbar-text{font-size:14px}
  .topbar .pill{font-size:12px;padding:4px 12px}
}
