/*
Theme Name: Khalique Holdings
Theme URI: https://khaliqueholdings.com
Author: Khalique Holdings LLC
Author URI: https://khaliqueholdings.com
Description: Custom WordPress block theme for Khalique Holdings — a B2B multi-brand wholesale distribution marketing site. Fully editable in the Site Editor. Built to a locked design (paper/ink/green system, Bricolage Grotesque + Hanken Grotesk).
Requires at least: 6.5
Tested up to: 6.7
Requires PHP: 7.4
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: khalique-holdings
Tags: business, block-theme, full-site-editing, custom-colors, custom-menu, editor-style
*/

/* ==========================================================================
   1. DESIGN SYSTEM — ported verbatim from design-reference/style.css (LOCKED)
   ========================================================================== */
:root{
  --paper:#f4f0e8;--paper-2:#ece6da;--card:#faf7f0;
  --ink:#15120e;--ink-2:#544e45;--muted:#857d70;
  --line:rgba(21,18,14,.13);--green:#15604a;--green-soft:#1c7e60;
  --maxw:1140px;--display:'Bricolage Grotesque',sans-serif;--body:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--green);font-weight:700}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.02;letter-spacing:-.02em}
.accent{color:var(--green)}
header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.4s}
header.scrolled{background:rgba(244,240,232,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;transition:height .4s}
header.scrolled .nav{height:62px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--display);font-size:22px;font-weight:700;letter-spacing:-.02em}
.brand .sub{font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:5px;font-weight:600}
nav.links{display:flex;gap:28px;align-items:center}
nav.links a{font-size:14px;color:var(--ink-2);font-weight:600;transition:.2s;position:relative}
nav.links a:hover,nav.links a.active{color:var(--ink)}
nav.links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--green);transition:.25s}
nav.links a:hover::after,nav.links a.active::after{width:100%}
.nav-cta{display:flex;gap:11px;align-items:center}
.btn{font-family:var(--body);font-size:14px;font-weight:700;padding:12px 22px;border-radius:40px;cursor:pointer;transition:.22s ease;border:1.5px solid transparent;display:inline-block;white-space:nowrap}
.btn-primary{background:var(--green);color:var(--paper)}
.btn-primary:hover{background:var(--green-soft);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-light{background:var(--paper);color:var(--green)}
.btn-light:hover{background:#fff;transform:translateY(-2px)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px}
.menu-toggle span{width:26px;height:2px;background:var(--ink);display:block}
/* hero (home) */
.hero{position:relative;padding:172px 0 88px}
.hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:54px;align-items:end}
.hero h1{font-size:clamp(46px,7vw,92px);margin:22px 0 0;letter-spacing:-.03em}
.lede{font-size:18px;color:var(--ink-2);max-width:500px;margin-top:24px}
.hero-cta{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap}
.hero-aside{border-left:2px solid var(--green);padding-left:28px;padding-bottom:8px}
.hero-aside .tag{font-family:var(--display);font-size:20px;color:var(--ink);font-weight:600;letter-spacing:-.02em}
/* inner hero */
.ihero{padding:150px 0 56px;border-bottom:1px solid var(--line)}
.ihero .eyebrow{margin-bottom:18px;display:block}
.ihero h1{font-size:clamp(40px,5.6vw,76px);max-width:14ch}
.ihero p{font-size:18px;color:var(--ink-2);max-width:560px;margin-top:22px}
.ihero .hero-cta{margin-top:30px}
.marquee{background:var(--ink);overflow:hidden;white-space:nowrap}
.mq-track{display:inline-block;padding:14px 0;animation:scroll 32s linear infinite}
.mq-track span{font-family:var(--display);font-size:15px;font-weight:500;letter-spacing:.04em;margin:0 24px;color:var(--paper)}
.mq-track .dot{color:var(--green-soft)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.strip{background:var(--paper-2);border-bottom:1px solid var(--line)}
.strip .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:32px 24px;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--display);font-size:32px;font-weight:700;color:var(--green);line-height:1;letter-spacing:-.02em}
.stat .lbl{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:9px;font-weight:600}
section.block{padding:88px 0;position:relative}
.panel{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{max-width:680px;margin-bottom:44px}
.sec-head h2{font-size:clamp(30px,4vw,46px);margin-top:14px;letter-spacing:-.03em}
.sec-head p{font-size:16px;color:var(--ink-2);margin-top:16px;max-width:580px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.step{padding:34px 28px 38px;border-right:1px solid var(--line);transition:.3s}
.step:last-child{border-right:0}
.step:hover{background:var(--card)}
.step .n{font-family:var(--display);font-size:28px;color:var(--green);font-weight:700}
.step h3{font-size:20px;margin:13px 0 10px;letter-spacing:-.02em}
.step p{font-size:14.5px;color:var(--ink-2)}
.step .badge{display:inline-block;margin-top:13px;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--green);border:1px solid var(--green);padding:4px 9px;border-radius:30px;font-weight:700}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vcard{background:var(--card);border:1px solid var(--line);padding:32px 28px;border-radius:14px;transition:.3s}
.vcard:hover{border-color:var(--green);transform:translateY(-4px)}
.vcard .ic{width:40px;height:40px;background:var(--green);border-radius:11px;display:flex;align-items:center;justify-content:center;color:var(--paper);font-family:var(--display);font-weight:700;font-size:18px;margin-bottom:18px}
.vcard h3{font-size:19px;margin-bottom:9px;letter-spacing:-.02em}
.vcard p{font-size:14.5px;color:var(--ink-2)}
.dual{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.path{border:1px solid var(--line);border-radius:16px;padding:44px 40px;transition:.35s;background:var(--card)}
.path:hover{border-color:var(--green)}
.path.brand{background:var(--green);color:var(--paper)}
.path.brand .eyebrow,.path.brand h3{color:var(--paper)}
.path.brand p{color:rgba(244,240,232,.85)}
.path .eyebrow{margin-bottom:15px;display:block}
.path h3{font-size:27px;margin-bottom:12px;letter-spacing:-.02em}
.path p{color:var(--ink-2);font-size:15.5px;margin-bottom:24px;max-width:400px}
/* forms */
.formwrap{max-width:680px}
.formcard{border:1px solid var(--line);border-radius:16px;padding:40px 38px;background:var(--card)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:15px}
.field.full{grid-column:1/-1}
.field label{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);margin-bottom:7px;font-weight:600}
.field input,.field select,.field textarea{width:100%;background:var(--paper);border:1px solid var(--line);border-radius:8px;color:var(--ink);font-family:var(--body);font-size:14.5px;padding:12px 14px;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green)}
.field textarea{min-height:96px;resize:vertical}
.formcard .btn-primary{width:100%;text-align:center;margin-top:8px}
.note{font-size:12.5px;color:var(--muted);margin-top:14px}
footer{border-top:1px solid var(--line);padding:54px 0 34px;background:var(--paper-2)}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;align-items:start}
.foot .name{font-family:var(--display);font-size:23px;font-weight:700;letter-spacing:-.02em}
.foot p.tagline{color:var(--muted);font-size:14px;max-width:330px;margin-top:14px}
.foot h4{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--green);margin-bottom:15px;font-weight:700}
.foot a{display:block;color:var(--ink-2);font-size:14px;margin-bottom:11px;transition:.2s}
.foot a:hover{color:var(--green)}
.footcontact{margin-top:24px}
.footcontact a{display:block;color:var(--ink-2);font-size:14px;margin-bottom:6px;transition:.2s;word-break:break-word}
.footcontact a:hover{color:var(--green)}
.footcontact span{display:block;color:var(--muted);font-size:14px}
.copyright{border-top:1px solid var(--line);margin-top:40px;padding-top:22px;color:var(--muted);font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.reveal{opacity:0;transform:translateY(22px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(max-width:980px){
  .hero-grid,.dual,.foot,.frow{grid-template-columns:1fr;gap:30px}
  .hero-aside{border-left:0;border-top:2px solid var(--green);padding-left:0;padding-top:24px}
  .strip .wrap{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:0}.stat{border-bottom:1px solid var(--line)}
  .steps{grid-template-columns:1fr}.step{border-right:0;border-bottom:1px solid var(--line)}
  .vgrid{grid-template-columns:1fr}.frow{gap:0}
  nav.links,.nav-cta .btn{display:none}.menu-toggle{display:flex}
}
@media(max-width:560px){.wrap{padding:0 22px}.strip .wrap{grid-template-columns:1fr}.stat{border-right:0}section.block{padding:60px 0}}

/* ==========================================================================
   2. WORDPRESS ADAPTER LAYER
   Reconciles core-block wrapper markup with the locked design above, and
   neutralises default block-theme chrome so the ported CSS controls layout.
   ========================================================================== */

/* Let our own .wrap / section paddings drive layout — strip default root padding
   and block constraints that would double up margins. */
body{margin:0}
.wp-site-blocks{overflow:visible}
:where(.wp-site-blocks) > *{margin-block:0}
.is-layout-constrained > *{margin-block-start:0}

/* Group blocks used as structural wrappers should not impose their own width;
   the design's .wrap handles the 1140px max + gutters. */
.wp-block-group.wrap{max-width:var(--maxw);margin-inline:auto}

/* Headings/paragraphs inside our scoped sections inherit design typography via
   the element selectors above; reset core block default margins that fight it. */
.wp-block-heading{margin:0}
section.block p,.ihero p,.hero p{margin-top:0}

/* --- Buttons: map core button variants onto the locked .btn pills --------- */
.wp-block-button.btn-primary > .wp-block-button__link,
.wp-block-button.btn-ghost  > .wp-block-button__link,
.wp-block-button.btn-light  > .wp-block-button__link{
  font-family:var(--body);font-size:14px;font-weight:700;padding:12px 22px;border-radius:40px;
  border:1.5px solid transparent;transition:.22s ease;line-height:1.2;display:inline-block;white-space:nowrap;
}
.wp-block-button.btn-primary > .wp-block-button__link{background:var(--green);color:var(--paper)}
.wp-block-button.btn-primary > .wp-block-button__link:hover{background:var(--green-soft);transform:translateY(-2px)}
.wp-block-button.btn-ghost > .wp-block-button__link{background:transparent;border-color:var(--line);color:var(--ink)}
.wp-block-button.btn-ghost > .wp-block-button__link:hover{border-color:var(--green);color:var(--green)}
.wp-block-button.btn-light > .wp-block-button__link{background:var(--paper);color:var(--green)}
.wp-block-button.btn-light > .wp-block-button__link:hover{background:#fff;transform:translateY(-2px)}
.wp-block-buttons.hero-cta{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap}
.path .wp-block-buttons{margin-top:0}

/* --- Grid containers built from core groups: neutralise flow margins ----- */
.steps,.vgrid,.dual,.hero-grid,.foot,.strip .wrap{display:grid}
.steps > *,.vgrid > *,.dual > *,.hero-grid > *,.foot > *,.strip .wrap > *,
.step > *,.vcard > *,.path > *,.stat > *,.sec-head > *{margin-block:0}
/* Core group wrappers should not re-constrain width inside our sections. */
.step.wp-block-group,.vcard.wp-block-group,.path.wp-block-group,.stat.wp-block-group,
.steps.wp-block-group,.vgrid.wp-block-group,.dual.wp-block-group,.hero-grid.wp-block-group,
.sec-head.wp-block-group{max-width:none}

/* ==========================================================================
   3. FLUENT FORMS ADAPTER — styles plugin output to match .formcard design
   (Selectors are scoped to .ff-el / .frm-fluent-form which Fluent Forms emits.)
   ========================================================================== */
/* The form itself becomes the .formcard: bordered card, max 680px, centred. */
.frm-fluent-form{
  font-family:var(--body);max-width:680px;
  border:1px solid var(--line);border-radius:16px;padding:40px 38px;background:var(--card)
}
.frm-fluent-form .ff-t-container{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.frm-fluent-form .ff-el-input--label label{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);margin-bottom:7px;font-weight:600}
.frm-fluent-form .ff-el-group{margin-bottom:15px}
.frm-fluent-form input[type=text],
.frm-fluent-form input[type=email],
.frm-fluent-form input[type=url],
.frm-fluent-form select,
.frm-fluent-form textarea{
  width:100%;background:var(--paper);border:1px solid var(--line);border-radius:8px;color:var(--ink);
  font-family:var(--body);font-size:14.5px;padding:12px 14px;transition:.2s
}
.frm-fluent-form input:focus,
.frm-fluent-form select:focus,
.frm-fluent-form textarea:focus{outline:none;border-color:var(--green);box-shadow:none}
.frm-fluent-form textarea{min-height:96px;resize:vertical}
.frm-fluent-form .ff-btn-submit{
  width:100%;text-align:center;margin-top:8px;font-family:var(--body);font-size:14px;font-weight:700;
  padding:12px 22px;border-radius:40px;border:1.5px solid transparent;background:var(--green);color:var(--paper);
  cursor:pointer;transition:.22s ease
}
.frm-fluent-form .ff-btn-submit:hover{background:var(--green-soft);transform:translateY(-2px)}
@media(max-width:980px){.frm-fluent-form .ff-t-container{grid-template-columns:1fr;gap:0}}

/* Accessibility: visible focus ring for keyboard users on links/buttons */
a:focus-visible,button:focus-visible,.wp-block-button__link:focus-visible,
input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--green);outline-offset:2px
}

/* Honour reduced-motion preference: stop marquee + reveal animations */
@media(prefers-reduced-motion:reduce){
  .mq-track{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
