/* =====================================================================
   BUILDR v2 — "BLUEPRINT & SAFETY"  ·  app.css (global components)
   Deep blueprint navy + safety orange. Archivo display / Inter body.
   Brand device: hazard stripe (diagonal navy/orange tape).
   Tokens live in theme.json; this file styles the components.
   ===================================================================== */

:root{
  --navy:#0A1830; --navy-2:#101F3C; --navy-3:#1B2E55;
  --orange:#FF5A1F; --orange-dark:#E04812; --orange-soft:#FFEDE5;
  --ink:#0E1524; --muted:#5B6474; --line:#E3E7EF; --surface:#F3F5F9; --paper:#fff;
  --c-defect:#DC2626; --c-panduan:#16A34A; --c-wp:#0891B2; --c-bahan:#7C3AED;
  --c-bisnes:#D97706; --c-kualiti:#2563EB; --c-projek:#FF5A1F;
  --ff-d:'Archivo',system-ui,-apple-system,sans-serif;
  --ff-b:'Inter',system-ui,-apple-system,sans-serif;
  --wrap:1240px; --gutter:clamp(16px,4vw,32px);
  --r:12px; --r-sm:8px;
  --shadow:0 1px 2px rgba(10,24,48,.05),0 8px 24px -12px rgba(10,24,48,.12);
  --shadow-lift:0 2px 4px rgba(10,24,48,.06),0 16px 36px -12px rgba(10,24,48,.2);
  --hazard:repeating-linear-gradient(-45deg,var(--orange) 0 10px,var(--navy) 10px 20px);
  --z-head:50;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--ff-b);font-size:16.5px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

.br-wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter);width:100%}
.br-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}

/* Signature: hazard tape strip at very top of the site */
.br-tape{height:6px;background:var(--hazard)}

/* Focus + motion a11y */
a:focus-visible,button:focus-visible,input:focus-visible,.wp-element-button:focus-visible{outline:3px solid var(--orange);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* ---- Labels / chips / meta ------------------------------------------- */
.br-kicker,.br-kicker a{font-family:var(--ff-d);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-dark);line-height:1.2;display:inline-block;margin:0 0 8px}
.br-meta{font-family:var(--ff-b);font-size:12.5px;font-weight:500;color:var(--muted);margin:0}

/* Category chips — post-terms rendered as colored pills, hue per pillar */
.br-chips a{font-family:var(--ff-d);font-size:10.5px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;line-height:1;display:inline-block;padding:5px 9px;border-radius:999px;background:var(--surface);color:var(--navy);margin:0 6px 6px 0;transition:filter .15s}
.br-chips a:hover{filter:brightness(.92)}
.br-chips a[href*="isu-tapak"]{background:#FDE8E8;color:var(--c-defect)}
.br-chips a[href*="panduan-pemilik"]{background:#E5F6EB;color:var(--c-panduan)}
.br-chips a[href*="waterproofing"]{background:#E0F4F8;color:var(--c-wp)}
.br-chips a[href*="bahan-binaan"]{background:#F0E9FC;color:var(--c-bahan)}
.br-chips a[href*="bisnes"],.br-chips a[href*="kerjaya"]{background:#FCF0DE;color:var(--c-bisnes)}
.br-chips a[href*="kualiti-bangunan"]{background:#E4EDFD;color:var(--c-kualiti)}
.br-chips a[href*="kontraktor"],.br-chips a[href*="projek"]{background:var(--orange-soft);color:var(--orange-dark)}
.br-chips{margin:0 0 10px;display:block}

/* =====================================================================
   HEADER
   ===================================================================== */
.br-head{position:sticky;top:0;z-index:var(--z-head);background:rgba(255,255,255,.96);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.br-head-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:64px}

.br-logo{display:inline-flex;align-items:center;gap:10px;flex:0 0 auto}
.br-mark{width:26px;height:26px;border-radius:6px;background:var(--navy);position:relative;overflow:hidden;display:inline-block}
.br-mark::after{content:"";position:absolute;inset:auto -6px 4px;height:7px;background:var(--hazard);transform:rotate(-8deg)}
.br-word{font-family:var(--ff-d);font-weight:900;font-style:italic;font-size:23px;letter-spacing:-.03em;color:var(--navy);line-height:1}
.br-word .dot{color:var(--orange);font-style:normal}
.br-logo.light .br-word{color:#fff}

.br-nav{display:flex;align-items:center;gap:4px;margin-inline:auto}
.br-nav a{font-family:var(--ff-d);font-size:13.5px;font-weight:700;color:var(--navy);padding:8px 11px;border-radius:8px;white-space:nowrap;transition:background .15s,color .15s}
.br-nav a:hover{background:var(--surface);color:var(--orange-dark)}

.br-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.br-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--navy);cursor:pointer;background:none;border:0;border-radius:10px;transition:background .15s}
.br-icon:hover{background:var(--surface)}
.br-icon svg{width:20px;height:20px}
.br-subscribe{font-family:var(--ff-d);font-size:13.5px;font-weight:800;color:#fff;background:var(--orange);padding:10px 18px;border-radius:10px;transition:background .15s;white-space:nowrap}
.br-subscribe:hover{background:var(--navy);color:#fff}
.br-burger{display:none}

/* Mobile menu */
.br-mobile{display:none;flex-direction:column;padding:8px var(--gutter) 22px;border-bottom:1px solid var(--line);background:var(--paper)}
.br-mobile a{font-family:var(--ff-d);font-weight:700;font-size:16px;padding:13px 4px;border-bottom:1px solid var(--line);color:var(--navy)}
.br-mobile a.br-subscribe{background:var(--orange);color:#fff;text-align:center;border:0;margin-top:14px;border-radius:10px}
.br-mobile[hidden]{display:none}

@media(max-width:1080px){
  .br-nav{display:none}
  .br-burger{display:inline-flex}
  .br-mobile:not([hidden]){display:flex}
}
@media(max-width:520px){
  .br-subscribe{display:none}
  .br-word{font-size:20px}
}

/* =====================================================================
   SECTION HEADS
   ===================================================================== */
.br-section{padding-block:clamp(36px,5.5vw,64px)}
.br-sec-head{align-items:center;margin:0 0 24px;gap:14px}
.br-sec-title{margin:0;font-family:var(--ff-d);font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:-.01em;display:flex;align-items:center;gap:12px}
.br-sec-title::before{content:"";width:26px;height:14px;background:var(--hazard);border-radius:3px;flex:0 0 auto}
.br-sec-link a{font-family:var(--ff-d);font-size:13px;font-weight:800;color:var(--orange-dark);white-space:nowrap}
.br-sec-link a:hover{color:var(--navy)}

/* =====================================================================
   CARDS + GRIDS (query-loop output)
   ===================================================================== */
.br-grid .wp-block-post-template{list-style:none;margin:0;padding:0;display:grid;gap:26px 22px;grid-template-columns:repeat(4,1fr)}
.br-grid.br-grid-3 .wp-block-post-template{grid-template-columns:repeat(3,1fr)}
.br-grid .wp-block-post-template>li{margin:0;min-width:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;padding-bottom:16px}
.br-grid .wp-block-post-template>li:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}
@media(max-width:1024px){.br-grid .wp-block-post-template,.br-grid.br-grid-3 .wp-block-post-template{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.br-grid .wp-block-post-template,.br-grid.br-grid-3 .wp-block-post-template{grid-template-columns:1fr;gap:18px}}

.br-card-img{margin:0 0 14px;overflow:hidden}
.br-card-img img{width:100%;aspect-ratio:16/10;object-fit:cover;background:var(--surface);transition:transform .3s}
.br-grid .wp-block-post-template>li:hover .br-card-img img{transform:scale(1.05)}

.br-grid .br-chips,.br-grid .wp-block-post-title,.br-grid .wp-block-post-excerpt,.br-grid .br-meta{padding-inline:16px}
.br-grid .wp-block-post-title{margin:0 0 8px;font-family:var(--ff-d);font-weight:800;font-size:17.5px;line-height:1.3;letter-spacing:-.015em}
.br-grid .wp-block-post-title a:hover{color:var(--orange-dark)}
.br-grid .wp-block-post-excerpt{margin:0 0 10px;font-size:14px;line-height:1.6;color:var(--muted)}
.br-grid .wp-block-post-excerpt__more-text{display:none}
.br-grid .br-meta{margin-top:auto}

.br-empty{color:var(--muted);font-family:var(--ff-b);font-size:15px}

/* =====================================================================
   ARCHIVE / SEARCH
   ===================================================================== */
.br-archive{padding-bottom:64px;background:var(--surface)}
.br-arch-head{background:var(--navy);color:#fff;padding-block:clamp(36px,5vw,60px);margin-bottom:40px;position:relative}
.br-arch-head::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:var(--hazard)}
.br-arch-title{margin:0;font-family:var(--ff-d);font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:-.01em;color:#fff}
.br-arch-title .wp-block-query-title__prefix{color:rgba(255,255,255,.5)}
.br-arch-desc{margin:12px 0 0;color:rgba(255,255,255,.75);font-size:16px;max-width:640px}
.br-archive .br-grid .wp-block-post-template>li{border:0}

/* Pagination */
.br-pagination{margin-top:44px;gap:6px}
.br-pagination .page-numbers{font-family:var(--ff-d);font-size:14px;font-weight:700;min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 13px;background:var(--paper);border:1px solid var(--line);border-radius:10px;color:var(--navy)}
.br-pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
.br-pagination a.page-numbers:hover{border-color:var(--orange);color:var(--orange-dark)}

/* =====================================================================
   SINGLE ARTICLE
   ===================================================================== */
.br-article{padding-top:clamp(26px,4vw,44px);padding-bottom:64px}
.br-article-head{max-width:760px;margin-inline:auto}
.br-article-head .wp-block-post-title{margin:.1em 0 .35em;font-weight:900;letter-spacing:-.025em}
.br-byline{align-items:center;gap:14px;margin-top:14px;padding:12px 16px;background:var(--surface);border-radius:10px}
.br-byline .wp-block-post-author-name{font-family:var(--ff-d);font-size:13px;font-weight:800;color:var(--navy)}
.br-byline .wp-block-shortcode,.br-byline .br-meta{font-family:var(--ff-b);font-size:12.5px;color:var(--muted);margin:0}
.br-article-img{margin:30px auto}
.br-article-img img{width:100%;border-radius:var(--r)}

/* Prose */
.br-prose{font-size:17.5px;line-height:1.75}
.br-prose>*{max-width:760px;margin-inline:auto}
.br-prose>.alignwide{max-width:1000px}
.br-prose>.alignfull{max-width:none}
.br-prose p{margin:0 0 1.3em}
.br-prose h2{font-family:var(--ff-d);font-weight:800;font-size:clamp(23px,2.8vw,29px);letter-spacing:-.02em;margin:1.7em auto .5em;padding-left:14px;border-left:4px solid var(--orange)}
.br-prose h3{font-family:var(--ff-d);font-weight:700;font-size:20px;margin:1.5em auto .4em}
.br-prose a{color:var(--orange-dark);font-weight:600;border-bottom:2px solid var(--orange-soft);transition:border-color .15s}
.br-prose a:hover{border-color:var(--orange)}
.br-prose ul,.br-prose ol{padding-left:1.3em;margin:0 auto 1.3em}
.br-prose li{margin:.35em 0}
.br-prose blockquote{border-left:4px solid var(--orange);background:var(--surface);border-radius:0 10px 10px 0;padding:14px 20px;margin:1.5em auto;color:var(--navy-2)}
.br-prose img{border-radius:var(--r)}
.br-prose figcaption{font-size:12.5px;color:var(--muted);text-align:center;margin-top:8px}

.br-article-foot{max-width:760px;margin:36px auto 0}
.br-tags{font-size:13px;color:var(--muted)}
.br-tags a{background:var(--surface);padding:6px 12px;border-radius:999px;margin:0 6px 6px 0;display:inline-block;font-weight:600;transition:background .15s}
.br-tags a:hover{background:var(--orange-soft);color:var(--orange-dark)}
.br-related{border-top:1px solid var(--line);margin-top:52px}

/* =====================================================================
   PAGES
   ===================================================================== */
.br-page{padding-top:clamp(26px,4vw,44px);padding-bottom:64px}
.br-page-title{max-width:760px;margin:0 auto .5em;font-weight:900;letter-spacing:-.025em}
.br-page-full{padding-block:0 64px}

/* =====================================================================
   KONTRAKTOR — profiles (CPT)
   ===================================================================== */
.br-kprofile{padding-bottom:64px}
.br-khero{background:var(--navy);color:#fff;padding-block:clamp(36px,5vw,60px);position:relative;margin-bottom:36px}
.br-khero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:var(--hazard)}
.br-khero .wp-block-post-title{color:#fff;margin:.1em 0 .2em;font-weight:900;font-style:italic;text-transform:uppercase}
.br-khero .br-kicker{color:var(--orange)}
.br-khero .br-chips a{background:rgba(255,255,255,.12);color:#fff}
.br-kprofile .wp-block-post-featured-image{max-width:1000px;margin:0 auto 30px}
.br-kprofile .wp-block-post-featured-image img{border-radius:var(--r)}
.br-kcta{max-width:760px;margin:36px auto 0;background:var(--orange-soft);border:1px solid #FFD6C2;border-radius:var(--r);padding:24px;text-align:center}
.br-kcta h3{margin:0 0 6px;font-family:var(--ff-d);font-weight:800}
.br-kcta p{margin:0 0 14px;color:var(--muted);font-size:14.5px}

/* Kontraktor cards (archive + home band) */
.br-kgrid .wp-block-post-template{list-style:none;margin:0;padding:0;display:grid;gap:22px;grid-template-columns:repeat(3,1fr)}
.br-kgrid .wp-block-post-template>li{margin:0;background:var(--paper);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;padding-bottom:16px}
.br-kgrid .wp-block-post-template>li:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.br-kgrid .br-card-img img{aspect-ratio:4/3}
.br-kgrid .wp-block-post-title{font-family:var(--ff-d);font-weight:800;font-size:18px;margin:0 0 8px;padding-inline:16px}
.br-kgrid .br-chips,.br-kgrid .wp-block-post-excerpt{padding-inline:16px}
.br-kgrid .wp-block-post-excerpt{font-size:13.5px;color:var(--muted);margin:0}
@media(max-width:900px){.br-kgrid .wp-block-post-template{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.br-kgrid .wp-block-post-template{grid-template-columns:1fr}}

/* =====================================================================
   BUTTONS / SEARCH
   ===================================================================== */
.wp-element-button,.wp-block-button__link{font-family:var(--ff-d);font-weight:700;background:var(--orange);color:#fff;border-radius:10px;padding:13px 26px;transition:background .15s}
.wp-element-button:hover,.wp-block-button__link:hover{background:var(--navy);color:#fff}
.is-style-outline .wp-block-button__link{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.is-style-outline .wp-block-button__link:hover{background:var(--navy);color:#fff}
.br-searchform{max-width:520px;margin:20px auto 0}
.br-searchform .wp-block-search__input{border:1px solid var(--line);border-radius:10px;font-family:var(--ff-b);font-size:15px;padding:12px 14px}
.br-searchform .wp-block-search__button{background:var(--orange);color:#fff;border-radius:10px;font-family:var(--ff-d);font-weight:700;border:0}
.br-searchform .wp-block-search__button:hover{background:var(--navy)}

/* =====================================================================
   404
   ===================================================================== */
.br-404{padding-block:clamp(48px,8vw,96px)}

/* =====================================================================
   NEWSLETTER (kolam)
   ===================================================================== */
.br-kolam{background:var(--orange);color:#fff;position:relative}
.br-kolam::before{content:"";position:absolute;left:0;right:0;top:0;height:6px;background:var(--hazard)}
.br-kolam-in{display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;padding-block:clamp(36px,5vw,56px)}
.br-kolam-copy{flex:1 1 340px}
.br-kolam .br-kicker{color:#fff;opacity:.85}
.br-kolam h2{margin:.15em 0 .3em;font-family:var(--ff-d);font-weight:900;font-style:italic;text-transform:uppercase;font-size:clamp(23px,3.2vw,32px);letter-spacing:-.01em;color:#fff}
.br-kolam p{margin:0;font-size:15px;max-width:460px;color:rgba(255,255,255,.92)}
.br-kolam-form{display:flex;gap:8px;flex:1 1 320px;max-width:440px}
.br-kolam-form input{flex:1;border:0;border-radius:10px;background:#fff;padding:14px 15px;font-family:var(--ff-b);font-size:15px;color:var(--ink)}
.br-kolam-form button{background:var(--navy);color:#fff;border:0;border-radius:10px;font-family:var(--ff-d);font-weight:800;padding:0 22px;cursor:pointer;transition:background .15s}
.br-kolam-form button:hover{background:var(--navy-3)}

/* =====================================================================
   FOOTER
   ===================================================================== */
.br-foot{background:var(--navy);color:#9AA6BD;padding-block:clamp(44px,6vw,72px) 26px}
.br-foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px}
.br-foot-brand p{margin:16px 0 0;font-size:14px;line-height:1.6;max-width:320px;color:#8590A8}
.br-foot-col h5{font-family:var(--ff-d);font-size:11.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin:0 0 14px}
.br-foot-col a{display:block;font-size:14px;color:#9AA6BD;padding:5px 0;transition:color .15s}
.br-foot-col a:hover{color:var(--orange)}
.br-socials{display:flex;gap:9px;margin-top:18px}
.br-socials a{width:38px;height:38px;background:var(--navy-2);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#9AA6BD;transition:all .15s}
.br-socials a:hover{background:var(--orange);color:#fff}
.br-socials svg{width:17px;height:17px}
.br-foot-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:42px;padding-top:20px;border-top:1px solid var(--navy-3);font-size:12.5px;color:#6B7692}
@media(max-width:900px){.br-foot-grid{grid-template-columns:1fr 1fr}.br-foot-brand{grid-column:1/-1}}
@media(max-width:440px){.br-foot-grid{grid-template-columns:1fr}}
