/*
Theme Name: Bluer Prime
Theme URI: https://bluerprime.com
Author: Bluer Prime
Description: Custom block theme for Bluer Prime — a B2B food-ingredients supplier based in Dubai, UAE. Built on the official brand identity (warm palette: deep navy, bronze, gold, butter, vermilion, cream).
Version: 1.4.2
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: bluer-prime
*/

/* =========================================================
   Bluer Prime — global styles (ported from approved prototype)
   Brand palette is also mirrored in theme.json so it appears
   inside the WordPress editor.
   ========================================================= */

:root{
    --blue:#134474;          /* deep navy */
    --blue-deep:#0d3258;
    --blue-ink:#0a223c;
    --bronze:#ae6a2a;         /* copper / caramel */
    --caramel:#ae6a2a;
    --gold:#f4b82d;           /* golden amber */
    --butter:#ffd260;         /* soft yellow */
    --vermilion:#e14525;      /* CTA red-orange */
    --amber:#e14525;
    --cocoa:#6d4430;
    --espresso:#392517;
    --powder:#e8c98a;         /* warm tint */
    --ink:#1a1009;           /* warm near-black */
    --paper:#f8f7ef;          /* cream */
    --paper-2:#f3eadc;        /* warm cream */
    --line:#e7ddcc;
    --muted:#6f6253;
    --display:"Martian Mono",ui-monospace,monospace;
    --body:"Reddit Sans",-apple-system,sans-serif;
    --cond:"Reddit Sans Condensed","Reddit Sans",sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{text-decoration:none;color:inherit}
  ::selection{background:var(--amber);color:#fff}

  /* ---------- flower symbol ---------- */
  .flower{display:inline-block;color:var(--blue);line-height:0}
  .flower svg{width:100%;height:100%;display:block}

  .wrap{max-width:1280px;margin:0 auto;padding:0 32px}

  /* ---------- header ---------- */
  header{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .4s cubic-bezier(.4,0,.2,1)}
  header .bar{display:flex;align-items:center;justify-content:space-between;padding:22px 32px;max-width:1280px;margin:0 auto;transition:padding .4s}
  header.scrolled{background:rgba(248,247,239,.88);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
  header.scrolled .bar{padding:14px 32px}
  .brand{display:flex;align-items:center;gap:11px}
  .brand .mark{width:34px;height:34px;color:#fff}
  header.scrolled .brand .mark{color:var(--blue)}
  .brand .wm{font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:-1.5px;color:#fff;position:relative}
  header.scrolled .brand .wm{color:var(--ink)}
  .brand .prime{font-family:var(--cond);font-weight:700;font-size:9px;letter-spacing:1px;background:var(--amber);color:#fff;padding:1px 6px 2px;border-radius:3px;margin-left:4px;vertical-align:7px;text-transform:uppercase}
  header nav{display:flex;align-items:center;gap:34px}
  nav .links{display:flex;gap:30px}
  nav .links a{font-size:14px;font-weight:500;color:rgba(255,255,255,.82);letter-spacing:.2px;transition:color .25s;position:relative}
  nav .links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--amber);transition:width .3s}
  nav .links a:hover{color:#fff}
  nav .links a:hover::after{width:100%}
  header.scrolled nav .links a{color:var(--muted)}
  header.scrolled nav .links a:hover{color:var(--ink)}
  .btn{font-family:var(--body);font-weight:600;font-size:14px;padding:12px 22px;border-radius:100px;border:none;cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
  .btn-amber{background:var(--amber);color:#fff}
  .btn-amber:hover{background:#c5371b;transform:translateY(-2px);box-shadow:0 12px 28px -10px rgba(225,69,37,.65)}
  .btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
  .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
  .btn-dark{background:var(--blue);color:#fff}
  .btn-dark:hover{background:var(--blue-deep);transform:translateY(-2px);box-shadow:0 12px 28px -10px rgba(19,68,116,.6)}
  .menu-toggle{display:none}

  /* ---------- hero ---------- */
  .hero{position:relative;min-height:600px;background:var(--ink);color:#fff;display:flex;align-items:center;overflow:hidden;padding:150px 0 96px}
  .hero .mesh{position:absolute;inset:0;background-image:url("assets/hero-bg.jpg");background-size:cover;background-position:center right;background-repeat:no-repeat}
  .hero .grain{position:absolute;inset:0;opacity:.16;mix-blend-mode:overlay;pointer-events:none;
     background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
  .hero .vignette{position:absolute;inset:0;background:linear-gradient(90deg,rgba(26,16,9,.95) 8%,rgba(26,16,9,.35) 45%,rgba(26,16,9,0) 70%)}
  .hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;width:100%;padding-top:0}
  .eyebrow{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:26px;display:flex;align-items:center;gap:12px}
  .eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);display:inline-block}
  h1.hero-title{font-family:var(--display);font-weight:600;font-size:clamp(38px,5.4vw,74px);line-height:1.02;letter-spacing:-2.5px;margin-bottom:26px}
  h1.hero-title em{font-style:normal;color:var(--gold)}
  .hero p.lede{font-size:18px;line-height:1.65;color:rgba(255,255,255,.78);max-width:520px;margin-bottom:18px;font-weight:300}
  .motto{display:inline-flex;align-items:center;gap:10px;font-family:var(--cond);font-weight:600;font-size:14px;letter-spacing:.4px;color:var(--butter);border:1px solid rgba(255,210,96,.42);padding:7px 16px;border-radius:100px;margin-bottom:34px}
  .motto .dot{width:7px;height:7px;border-radius:50%;background:var(--amber)}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:54px}
  .hero-stats{display:flex;gap:46px}
  .hero-stats .s .n{font-family:var(--display);font-weight:600;font-size:34px;letter-spacing:-1px;line-height:1}
  .hero-stats .s .l{font-size:12.5px;color:rgba(255,255,255,.6);margin-top:8px;letter-spacing:.3px}
  .hero-flower{position:relative;display:flex;justify-content:center;align-items:center}
  .hero-flower .big{width:min(420px,38vw);height:min(420px,38vw);color:#fff;filter:drop-shadow(0 30px 80px rgba(174,106,42,.55));animation:float 9s ease-in-out infinite}
  @keyframes float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-22px) rotate(6deg)}}

  /* reveal */
  .rv{opacity:1;transform:none;transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
  html.js .rv{opacity:0;transform:translateY(30px)}
  html.js .rv.in{opacity:1;transform:none}
  .d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}

  /* ---------- section shell ---------- */
  section{padding:60px 0}
  .sec-head{max-width:660px;margin-bottom:34px}
  .kicker{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:3px;color:var(--blue);text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:12px}
  .kicker::before{content:"";width:30px;height:1px;background:var(--blue)}
  h2{font-family:var(--display);font-weight:600;font-size:clamp(30px,3.6vw,46px);line-height:1.06;letter-spacing:-2px}
  .sec-head p{margin-top:20px;font-size:17px;line-height:1.6;color:var(--muted);font-weight:300}

  /* ---------- advantages ---------- */
  .adv{background:var(--paper-2);position:relative}
  .adv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden}
  .adv-card{background:var(--paper);padding:34px 28px;transition:background .3s,transform .3s;position:relative}
  .adv-card:not(.feature):not(.cta):hover{background:var(--blue);transform:scale(1.02);z-index:2;box-shadow:0 24px 50px -20px rgba(19,68,116,.5);border-radius:14px}
  .adv-card:not(.feature):not(.cta):hover *{color:#fff!important}
  .adv-card .idx{font-family:var(--display);font-weight:500;font-size:13px;color:var(--caramel);margin-bottom:30px}
  .adv-card h3{font-family:var(--cond);font-weight:700;font-size:21px;line-height:1.1;letter-spacing:.2px;color:var(--ink)}
  .adv-card.feature{grid-column:span 1;background:var(--blue);color:#fff}
  .adv-card.feature .idx{color:var(--butter)}
  .adv-card.feature h3{color:#fff}
  .adv-card.feature p{color:rgba(255,255,255,.78);font-size:13.5px;line-height:1.55;margin-top:14px;font-weight:300}

  /* ---------- products ---------- */
  .prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .pcard{border:1px solid var(--line);border-radius:16px;padding:30px 26px 26px;background:var(--paper);transition:all .3s;cursor:pointer;position:relative;overflow:hidden;min-height:215px;display:flex;flex-direction:column}
  .pcard .pf{width:42px;height:42px;color:var(--powder);margin-bottom:auto;transition:all .35s}
  .pcard h3{font-family:var(--cond);font-weight:700;font-size:20px;line-height:1.08;margin:26px 0 8px;letter-spacing:.2px}
  .pcard p{font-size:13px;color:var(--muted);line-height:1.5}
  .pcard .cnt{position:absolute;top:26px;right:26px;font-family:var(--display);font-size:12px;font-weight:500;color:var(--caramel)}
  .pcard:hover{background:var(--ink);border-color:var(--ink);transform:translateY(-6px);box-shadow:0 26px 50px -24px rgba(0,0,0,.6)}
  .pcard:hover h3{color:#fff}.pcard:hover p{color:rgba(255,255,255,.65)}
  .pcard:hover .pf{color:var(--amber);transform:rotate(45deg) scale(1.1)}
  .pcard:hover .cnt{color:var(--butter)}

  /* ---------- suppliers strip ---------- */
  .suppliers{background:var(--ink);color:#fff;padding:46px 0;overflow:hidden}
  .sup-label{text-align:center;font-family:var(--display);font-size:11px;letter-spacing:3px;color:rgba(255,255,255,.5);text-transform:uppercase;margin-bottom:38px}
  .marquee{display:flex;gap:64px;white-space:nowrap;animation:scroll 32s linear infinite;width:max-content}
  .marquee span{font-family:var(--cond);font-weight:700;font-size:28px;color:rgba(255,255,255,.42);letter-spacing:.5px;transition:color .3s}
  .marquee span:hover{color:#fff}
  @keyframes scroll{to{transform:translateX(-50%)}}

  /* ---------- blog ---------- */
  .blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .bcard{border-radius:16px;overflow:hidden;border:1px solid var(--line);transition:all .3s;cursor:pointer;background:var(--paper)}
  .bcard:hover{transform:translateY(-6px);box-shadow:0 24px 46px -22px rgba(19,68,116,.4)}
  .bcard .thumb{height:180px;position:relative;overflow:hidden}
  .bcard .thumb .fl{position:absolute;width:150px;height:150px;right:-30px;bottom:-30px;opacity:.25}
  .bt1{background:linear-gradient(135deg,var(--blue),var(--blue-deep))}.bt1 .fl{color:var(--powder)}
  .bt2{background:linear-gradient(135deg,var(--bronze),var(--cocoa))}.bt2 .fl{color:#fff}
  .bt3{background:linear-gradient(135deg,var(--espresso),var(--vermilion))}.bt3 .fl{color:var(--butter)}
  .bcard .body{padding:24px 24px 28px}
  .bcard .tag{font-family:var(--display);font-size:10.5px;letter-spacing:2px;color:var(--amber);text-transform:uppercase}
  .bcard h3{font-family:var(--cond);font-weight:700;font-size:21px;line-height:1.12;margin:12px 0 10px}
  .bcard p{font-size:13.5px;color:var(--muted);line-height:1.55}

  /* ---------- cta band ---------- */
  .cta-band{background:var(--blue);color:#fff;border-radius:26px;padding:72px 64px;display:flex;align-items:center;justify-content:space-between;gap:40px;position:relative;overflow:hidden}
  .cta-band .deco{position:absolute;color:rgba(255,255,255,.08);width:280px;height:280px;right:-40px;top:-60px}
  .cta-band h2{color:#fff;max-width:600px;position:relative;z-index:2}
  .cta-band .r{position:relative;z-index:2}

  /* ---------- footer ---------- */
  footer{background:var(--ink);color:#fff;padding:90px 0 36px}
  .foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.4fr;gap:32px 48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.12)}
  .foot-brand .mark{width:40px;height:40px;color:#fff;margin-bottom:20px}
  .foot-brand p{color:rgba(255,255,255,.6);font-size:14px;line-height:1.65;max-width:300px;font-weight:300}
  .fcol .fcol-h{font-family:var(--display);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--caramel);margin-bottom:22px;font-weight:500}
  .fcol a,.fcol p{display:block;color:rgba(255,255,255,.66);font-size:14px;margin-bottom:13px;transition:color .25s;line-height:1.5;font-weight:300}
  .fcol a:hover{color:#fff}
  .foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:30px;flex-wrap:wrap;gap:14px}
  .foot-bot p{font-size:12.5px;color:rgba(255,255,255,.45)}
  .foot-bot .motto2{font-family:var(--cond);font-weight:600;color:var(--butter);font-size:13px;letter-spacing:.4px}

  /* ---------- responsive ---------- */
  @media(max-width:1024px){
    .adv-grid{grid-template-columns:repeat(2,1fr)}
    .prod-grid{grid-template-columns:repeat(2,1fr)}
    .blog-grid{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:820px){
    .wrap{padding:0 22px}
    header nav .links,header nav .btn{display:none}
    .menu-toggle{display:flex;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
    .menu-toggle span{width:24px;height:2px;background:#fff;display:block}
    header.scrolled .menu-toggle span{background:var(--ink)}
    .hero-grid{grid-template-columns:1fr;gap:0}
    .hero-flower{order:-1;margin-bottom:18px}
    .hero-flower .big{width:170px;height:170px}
    .hero{min-height:auto;padding:120px 0 80px}
    .hero-stats{gap:30px;flex-wrap:wrap}
    section{padding:52px 0}
    .cta-band{flex-direction:column;text-align:center;padding:54px 30px}
    .foot-grid{grid-template-columns:1fr}
  }
  @media(max-width:560px){
    .adv-grid,.prod-grid{grid-template-columns:1fr}
  }

/* ---------- WordPress integration ---------- */
.admin-bar header{top:32px}
@media(max-width:782px){.admin-bar header{top:46px}}
.alignfull{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
img{max-width:100%;height:auto}
/* WP editor: keep brand container width for blocks added later */
.is-layout-constrained > *{max-width:1280px;margin-left:auto;margin-right:auto}

/* Single post / page basic typography */
.bp-article{max-width:760px;margin:0 auto;padding:140px 32px 100px}
.bp-article h1{font-family:var(--display);font-weight:600;font-size:clamp(30px,4vw,52px);letter-spacing:-2px;line-height:1.05;margin-bottom:24px}
.bp-article h2{font-size:clamp(24px,3vw,34px);margin:40px 0 16px}
.bp-article p{font-size:17px;line-height:1.75;color:#3a3228;margin-bottom:20px;font-weight:300}
.bp-article a{color:var(--blue);text-decoration:underline}
.bp-meta{font-family:var(--display);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--bronze);margin-bottom:18px}

/* ---------- Product archive & single (CPT) ---------- */
.bp-cpt{padding:140px 0 100px}
.bp-cpt .wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.bp-archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px}
.bp-archive-grid .wp-block-post{border:1px solid var(--line);border-radius:16px;padding:30px 26px;background:#fff;transition:all .3s}
.bp-archive-grid .wp-block-post:hover{transform:translateY(-6px);box-shadow:0 24px 46px -22px rgba(19,68,116,.35);border-color:var(--blue)}
.bp-archive-grid .wp-block-post-title{font-family:var(--cond);font-weight:700;font-size:20px;line-height:1.12;margin:0 0 8px}
.bp-archive-grid .wp-block-post-title a{color:var(--ink);text-decoration:none}
.bp-archive-grid .wp-block-post-excerpt{font-size:13.5px;color:var(--muted);line-height:1.55}
.bp-product-detail{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px;margin:30px 0 40px;padding:26px 30px;background:var(--paper-2);border-radius:16px}
.bp-product-detail .row{font-size:15px}
.bp-product-detail .lbl{font-family:var(--display);font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--bronze);display:block;margin-bottom:4px}
.bp-product-detail ul{margin:4px 0 0 18px}
@media(max-width:900px){.bp-archive-grid{grid-template-columns:1fr 1fr}.bp-product-detail{grid-template-columns:1fr}}
@media(max-width:560px){.bp-archive-grid{grid-template-columns:1fr}}

/* ---------- SEO / semantic / a11y refinements ---------- */
.skip-link{position:absolute;left:-9999px;top:0;z-index:9999;background:var(--blue);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;font-weight:600;font-size:14px}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
.adv-grid{list-style:none;margin:0;padding:0}
.adv-card .idx{display:block}
.pcard{text-decoration:none;color:inherit}
.fcol address{font-style:normal}
.fcol address a,.fcol address p{display:block}

/* ---------- Catalogue: header band, filter, cards, single ---------- */
.bp-phead{background:var(--ink);color:#fff;padding:150px 0 64px;position:relative;overflow:hidden}
.bp-phead::after{content:"";position:absolute;inset:0;background:
   radial-gradient(50% 70% at 88% 60%,rgba(174,106,42,.55),transparent 60%),
   radial-gradient(46% 80% at 12% 120%,rgba(19,68,116,.7),transparent 60%);pointer-events:none}
.bp-phead .wrap{position:relative;z-index:2}
.bp-phead .kicker{color:var(--gold)}
.bp-phead .kicker::before{background:var(--gold)}
.bp-phead h1{font-family:var(--display);font-weight:600;font-size:clamp(32px,4.4vw,56px);letter-spacing:-2px;line-height:1.04;color:#fff;margin:0}
.bp-phead .wp-block-query-title{font-family:var(--display);font-weight:600;font-size:clamp(32px,4.4vw,56px);letter-spacing:-2px;color:#fff}
.bp-phead p.intro{margin-top:18px;max-width:620px;font-size:17px;line-height:1.6;color:rgba(255,255,255,.78);font-weight:300}

.bp-filterwrap{background:var(--paper);position:sticky;top:0;z-index:40;border-bottom:1px solid var(--line);padding:18px 0}
.bp-filter{display:flex;flex-wrap:wrap;gap:10px;max-width:1280px;margin:0 auto;padding:0 32px}
.bp-chip{font-family:var(--cond);font-weight:600;font-size:14px;padding:8px 16px;border-radius:100px;border:1px solid var(--line);color:var(--ink);background:#fff;transition:.22s;white-space:nowrap}
.bp-chip:hover{border-color:var(--blue);color:var(--blue)}
.bp-chip.is-active{background:var(--blue);color:#fff;border-color:var(--blue)}

.bp-catalog{padding:56px 0 110px}
.bp-archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:0}
.bp-archive-grid > li,.bp-archive-grid .wp-block-post{list-style:none;border:1px solid var(--line);border-radius:16px;padding:28px 26px;background:#fff;transition:all .3s;display:flex;flex-direction:column}
.bp-archive-grid .wp-block-post:hover{transform:translateY(-6px);box-shadow:0 24px 46px -22px rgba(19,68,116,.35);border-color:var(--blue)}
.bp-archive-grid .wp-block-post-terms{font-family:var(--display);font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--bronze);margin:0 0 14px}
.bp-archive-grid .wp-block-post-terms a{color:var(--bronze);text-decoration:none}
.bp-archive-grid .wp-block-post-title{font-family:var(--cond);font-weight:700;font-size:21px;line-height:1.12;margin:0 0 10px;letter-spacing:.2px}
.bp-archive-grid .wp-block-post-title a{color:var(--ink);text-decoration:none}
.bp-archive-grid .wp-block-post-title a:hover{color:var(--blue)}
.bp-archive-grid .wp-block-post-excerpt{font-size:13.5px;color:var(--muted);line-height:1.55;margin:0}
.bp-archive-grid .wp-block-post-excerpt__more-text{display:inline-block;margin-top:14px;font-family:var(--cond);font-weight:700;color:var(--vermilion);font-size:14px}

/* breadcrumb */
.bp-crumb{font-size:13px;color:var(--muted);margin-bottom:18px;font-family:var(--cond);font-weight:500}
.bp-crumb a{color:var(--bronze);text-decoration:none}
.bp-crumb a:hover{text-decoration:underline}
.bp-crumb [aria-current]{color:var(--ink)}

/* single product */
.bp-product{max-width:860px;margin:0 auto;padding:140px 32px 100px}
.bp-product .ptag{font-family:var(--display);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--bronze)}
.bp-product .ptag a{color:var(--bronze);text-decoration:none}
.bp-product h1{font-family:var(--display);font-weight:600;font-size:clamp(28px,4vw,46px);letter-spacing:-1.5px;line-height:1.06;margin:12px 0 8px}
.bp-product .lead{font-size:18px;line-height:1.7;color:#3a3228;font-weight:300;margin:20px 0}
.bp-product .wp-block-post-content p{font-size:17px;line-height:1.75;color:#3a3228;font-weight:300;margin-bottom:18px}
.bp-related{padding:0 0 110px}

@media(max-width:900px){.bp-archive-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.bp-archive-grid{grid-template-columns:1fr}.bp-phead{padding-top:130px}}

/* ---------- Footer polish ---------- */
.fcol{display:block}
.fcol .fcol-h{white-space:nowrap}
.fcol a{white-space:nowrap}
.foot-brand p{max-width:330px}
.fcol address a[href^="tel"]{white-space:nowrap}
@media(max-width:1024px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px 40px}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:560px){
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .fcol a{white-space:normal}
}

/* ====================================================================
   About & Contact pages + working mobile menu
   ==================================================================== */
.bp-section{padding:96px 0}
.bp-section.cream{background:var(--paper-2)}

/* About: story two-column */
.bp-story{display:grid;grid-template-columns:.8fr 1.2fr;gap:60px;align-items:start}
.bp-story h2{font-family:var(--display);font-weight:600;font-size:clamp(28px,3.4vw,42px);letter-spacing:-1.5px;line-height:1.08}
.bp-story .body p{font-size:17px;line-height:1.75;color:#3a3228;font-weight:300;margin-bottom:20px}
.bp-story .body p:last-child{margin-bottom:0}

/* Motto band */
.bp-motto-band{background:var(--blue);color:#fff;text-align:center;position:relative;overflow:hidden}
.bp-motto-band .deco{position:absolute;width:300px;height:300px;color:rgba(255,255,255,.07);right:-50px;top:-70px}
.bp-motto-band .deco.l{left:-60px;right:auto;top:auto;bottom:-90px}
.bp-motto-band .wrap{position:relative;z-index:2}
.bp-motto-band .big{font-family:var(--display);font-weight:600;font-size:clamp(30px,4.4vw,56px);letter-spacing:-2px;color:var(--butter);margin:0}
.bp-motto-band p{max-width:640px;margin:20px auto 0;font-size:18px;line-height:1.65;color:rgba(255,255,255,.85);font-weight:300}

/* Pillars */
.bp-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bp-pillar{border:1px solid var(--line);border-radius:16px;padding:34px 30px;background:#fff}
.bp-pillar .pf{width:40px;height:40px;color:var(--bronze);margin-bottom:22px}
.bp-pillar h3{font-family:var(--cond);font-weight:700;font-size:22px;margin-bottom:10px;letter-spacing:.2px}
.bp-pillar p{font-size:14.5px;color:var(--muted);line-height:1.6}

/* Contact */
.bp-contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.bp-cinfo .row{margin-bottom:26px}
.bp-cinfo .lbl{font-family:var(--display);font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--bronze);display:block;margin-bottom:7px}
.bp-cinfo .val{font-size:17px;color:var(--ink);line-height:1.5}
.bp-cinfo .val a{color:var(--ink);text-decoration:none}
.bp-cinfo .val a:hover{color:var(--blue)}
.bp-cinfo address{font-style:normal}
.bp-wa{display:inline-flex;align-items:center;gap:9px;margin-top:8px;background:#25d366;color:#fff;font-weight:600;font-size:14px;padding:11px 18px;border-radius:100px;text-decoration:none;transition:.2s}
.bp-wa:hover{filter:brightness(.93)}
.bp-form-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:38px 36px;box-shadow:0 30px 60px -34px rgba(19,68,116,.25)}
.bp-form-card h2{font-family:var(--cond);font-weight:700;font-size:24px;margin-bottom:8px}
.bp-form-card .hint{font-size:14px;color:var(--muted);margin-bottom:24px;line-height:1.55}

@media(max-width:900px){
  .bp-story{grid-template-columns:1fr;gap:24px}
  .bp-pillars{grid-template-columns:1fr}
  .bp-contact-grid{grid-template-columns:1fr;gap:36px}
  .bp-section{padding:70px 0}
}

/* ---------- Working mobile menu ---------- */
@media(max-width:820px){
  body.nav-open{overflow:hidden}
  body.nav-open header nav .links{
    display:flex;flex-direction:column;gap:4px;
    position:fixed;top:64px;left:0;right:0;
    background:var(--ink);padding:18px 28px 28px;
    border-bottom:1px solid rgba(255,255,255,.12);
    box-shadow:0 24px 40px -16px rgba(0,0,0,.5);
  }
  body.nav-open header nav .links a{color:#fff;font-size:17px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}
  header.scrolled.nav-open,body.nav-open header.scrolled nav .links{background:rgba(26,16,9,.98)}
  body.nav-open header.scrolled nav .links a{color:#fff}
  .menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .menu-toggle span{transition:.25s}
}

/* ---------- About + Contact pages ---------- */
.bp-section{padding:90px 0}
.bp-story{display:grid;grid-template-columns:.78fr 1.22fr;gap:50px;align-items:start}
.bp-story h2{font-family:var(--display);font-weight:600;font-size:clamp(26px,3vw,38px);letter-spacing:-1.5px;line-height:1.08}
.bp-story p{font-size:17px;line-height:1.75;color:#3a3228;font-weight:300;margin-bottom:18px}
.bp-story strong{color:var(--blue);font-weight:600}
.bp-statband{background:var(--blue);color:#fff;border-radius:22px;padding:48px;display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.bp-statband .n{font-family:var(--display);font-weight:600;font-size:clamp(28px,3vw,40px);letter-spacing:-1px;line-height:1}
.bp-statband .l{margin-top:10px;font-size:13.5px;color:rgba(255,255,255,.75)}
.bp-values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bp-value{border:1px solid var(--line);border-radius:16px;padding:30px 26px;background:#fff}
.bp-value .vi{width:40px;height:40px;color:var(--bronze);margin-bottom:18px;display:block}
.bp-value h3{font-family:var(--cond);font-weight:700;font-size:20px;margin-bottom:8px}
.bp-value p{font-size:14px;color:var(--muted);line-height:1.55}

.bp-contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.bp-cinfo .item{margin-bottom:24px}
.bp-cinfo .lbl{font-family:var(--display);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--bronze);display:block;margin-bottom:6px}
.bp-cinfo a,.bp-cinfo p{font-size:17px;color:var(--ink);text-decoration:none;line-height:1.55;margin:0}
.bp-cinfo a:hover{color:var(--blue)}
.bp-map{margin-top:8px;border:0;width:100%;height:240px;border-radius:14px}

/* Quote form */
.bp-form{display:flex;flex-direction:column;gap:16px;background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:30px}
.bp-form .bp-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bp-form label{display:flex;flex-direction:column;gap:7px;font-family:var(--cond);font-weight:600;font-size:14px;color:var(--ink)}
.bp-form input,.bp-form textarea{font-family:var(--body);font-size:15px;font-weight:400;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);width:100%}
.bp-form input:focus,.bp-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(19,68,116,.12)}
.bp-form textarea{resize:vertical}
.bp-form .btn{align-self:flex-start;margin-top:4px;cursor:pointer;border:none}
.bp-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.bp-note{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-weight:500;font-size:15px}
.bp-note.ok{background:#e7f3ea;color:#1f6b39;border:1px solid #bfe1c9}
.bp-note.err{background:#fdeceb;color:#a32114;border:1px solid #f3c4bf}

/* ---------- Mobile navigation panel ---------- */
@media(max-width:820px){
  header nav .links{position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--ink);padding:8px 22px 20px;gap:0;display:none;box-shadow:0 22px 44px -18px rgba(0,0,0,.55)}
  body.nav-open header nav .links{display:flex}
  header nav .links a{padding:15px 2px;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
  header nav .links a::after{display:none}
  header.scrolled nav .links{background:var(--paper)}
  header.scrolled nav .links a{color:var(--ink);border-color:var(--line)}
  .bp-story,.bp-contact-grid{grid-template-columns:1fr;gap:34px}
  .bp-statband{grid-template-columns:1fr 1fr;padding:34px;gap:24px}
  .bp-values{grid-template-columns:1fr}
  .bp-form .bp-row{grid-template-columns:1fr}
}

/* ---------- Advantages: 8th cell as a CTA card ---------- */
.adv-card.cta{background:var(--vermilion);color:#fff;display:flex;flex-direction:column;transition:background .3s,transform .3s}
.adv-card.cta .idx{color:#fff;opacity:.85;font-size:20px;margin-bottom:24px}
.adv-card.cta h3{color:#fff;margin-bottom:auto}
.adv-card.cta .adv-cta-link{display:inline-block;margin-top:20px;font-family:var(--cond);font-weight:700;font-size:15px;color:#fff;text-decoration:none}
.adv-card.cta:hover{background:#c5371b;transform:scale(1.02);z-index:2;box-shadow:0 24px 50px -20px rgba(225,69,37,.55);border-radius:14px}

/* ============================================================
   DENSITY PASS v1.4 — tighten vertical rhythm site-wide
   (placed last so it overrides earlier values)
   ============================================================ */

/* --- Sections & headings --- */
section{padding:46px 0}
.sec-head{margin-bottom:26px}
h2{font-size:clamp(25px,2.9vw,37px);line-height:1.05}

/* --- Hero (redesigned typographic rhythm) --- */
.hero{min-height:0;padding:116px 0 64px}
.hero-grid{grid-template-columns:1.22fr .78fr;gap:44px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--cond);font-weight:600;font-size:13px;letter-spacing:.4px;color:var(--butter);border:1px solid rgba(255,210,96,.4);padding:6px 15px;border-radius:100px;margin-bottom:24px}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--amber)}
.hero .eyebrow{font-size:11px;margin-bottom:20px}
h1.hero-title{font-size:clamp(36px,4.7vw,58px);line-height:1.1;letter-spacing:-2px;margin-bottom:24px}
.hero p.lede{font-size:17px;line-height:1.72;margin-bottom:32px;max-width:540px}
.hero-cta{margin-bottom:0}
.hero-stats{gap:46px;margin-top:36px;padding-top:30px;border-top:1px solid rgba(255,255,255,.15)}
.hero-stats .n{font-size:32px}
.hero-flower .big{width:min(360px,32vw);height:min(360px,32vw)}

/* --- Advantage cards --- */
.adv-card{padding:22px 24px}
.adv-card .idx{margin-bottom:16px}
.adv-card.feature p{margin-top:10px}
.adv-card.cta .idx{margin-bottom:16px}

/* --- Product cards --- */
.pcard{min-height:0;padding:22px 24px 22px}
.pcard .pf{margin-bottom:16px}
.pcard h3{margin:14px 0 6px}

/* --- Blog cards --- */
.bcard .thumb{height:148px}

/* --- Suppliers strip --- */
.suppliers{padding:38px 0}

/* --- CTA band --- */
.cta-band{padding:46px 52px}
.cta-band h2{font-size:clamp(24px,2.8vw,36px);line-height:1.05}

/* --- Footer --- */
footer{padding:56px 0 28px}
.foot-grid{padding-bottom:42px}

/* --- Inner page header band & sections --- */
.bp-phead{padding:122px 0 44px}
.bp-phead h1,.bp-phead .wp-block-query-title{font-size:clamp(28px,3.4vw,44px)}
.bp-section{padding:54px 0}
.bp-statband{padding:34px}
.bp-article{padding:116px 32px 64px}
.bp-product{padding:116px 32px 70px}
.bp-catalog{padding:40px 0 70px}
.bp-story h2{font-size:clamp(24px,2.8vw,36px)}

/* --- Mobile --- */
@media(max-width:820px){
  section{padding:40px 0}
  .hero{padding:104px 0 50px}
  .cta-band{padding:34px 26px}
  .bp-phead{padding:104px 0 36px}
  .bp-section{padding:42px 0}
  .bp-statband{padding:26px}
}

/* --- Footer: final tightening --- */
footer{padding:42px 0 18px}
.foot-grid{padding-bottom:30px}
.foot-bot{padding-top:20px}
.foot-brand .mark{margin-bottom:14px}
@media(max-width:820px){
  footer{padding:36px 0 16px}
}
