/* ============================================================
   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}

: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:'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 */
.topbar{background:var(--brown-dark);color:#F2EADD;padding:10px 0;font-family:var(--serif);font-style:normal;font-size:17px}
.topbar-inner{display:flex;justify-content:center;align-items:center;gap:18px}
.topbar .pill{background:var(--accent-red);color:#fff;padding:4px 12px;border-radius:18px;font-family:var(--sans);font-style:normal;font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}

/* 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}
.search{display:flex;justify-content:flex-end}
.search input{border:1px solid #BFB6A6;border-radius:2px;padding:8px 12px;width:170px;font-family:var(--sans);font-size:14px;color:#666;background:#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(--sans);font-size:15px;letter-spacing:.04em;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 */
.hero{position:relative;margin-top:6px}
.hero img{width:100%;height:auto;object-fit:cover;max-height:560px;object-position:center}
.hero .overlay{position:absolute;left:0;right:0;bottom:0;padding:40px 32px;background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 70%);display:flex;justify-content:space-between;align-items:flex-end;gap:40px;color:#fff}
.hero h1{font-family:var(--serif);font-weight:500;font-style:normal;font-size:46px;line-height:1.05;max-width:520px}
.hero .blurb{background:rgba(255,255,255,.92);color:var(--ink);padding:14px 18px;max-width:340px;font-size:13.5px;line-height:1.55;font-family:var(--sans)}
.hero .blurb strong{font-weight:600}

/* 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}

/* 3-column feature row */
.feature-row{display:grid;grid-template-columns:1.1fr 1.3fr 1fr;gap:28px;align-items:start}
.feature-card{display:flex;flex-direction:column;gap:14px}
.feature-card .imgwrap{overflow:hidden;border-radius:2px;background:#eee;aspect-ratio:4/3}
.feature-card .imgwrap img{width:100%;height:100%;object-fit:cover}
.feature-card h3{font-family:var(--serif);font-size:24px;font-weight:500;line-height:1.15}
.feature-card p{font-family:var(--sans);font-size:15px;color:#3a3a3a;line-height:1.55}
.vermas{display:inline-block;margin-top:6px;font-family:var(--sans);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-red);font-weight:500;border-bottom:1px solid var(--accent-red);padding-bottom:2px;align-self:flex-start}
.stamp-archs{background:#1f1f1f;color:#fff;padding:32px;border-radius:2px;font-family:var(--serif);font-weight:600;font-size:50px;line-height:.95;letter-spacing:.04em;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;text-align:center}

/* Cover of the week */
.cover-week{display:flex;flex-direction:column;gap:14px;align-items:center}
.cover-week .label{font-family:var(--serif);font-style:normal;font-size:20px;color:#333}
.cover-week h3{font-family:var(--serif);font-size:24px;font-weight:500;text-align:center}
.cover-week .author{font-size:13px;color:#666;letter-spacing:.05em;text-transform:uppercase}

/* Brick / ladrillazo row */
.ladrillazo-row{display:grid;grid-template-columns:280px 1fr;gap:30px;align-items:center;margin-top:40px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ladrillazo-row img{max-height:220px;object-fit:contain}
.ladrillazo-row .txt h3{font-family:var(--serif);font-size:32px;font-weight:500;letter-spacing:.01em}
.ladrillazo-row .txt p{margin-top:6px;font-family:var(--sans);font-size:16px;color:#3a3a3a}

/* 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:32px}
  .hero .overlay{flex-direction:column;align-items:flex-start;padding:24px}
  .feature-row{grid-template-columns:1fr;gap:32px}
  .ladrillazo-row{grid-template-columns:1fr;text-align:center}
  .ladrillazo-row img{margin:0 auto}
  .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}
}
