/* ============================================================================
 * Peniel Enterprises — styles
 * ----------------------------------------------------------------------------
 * Organised by section (see the `----------` dividers). All visual values that
 * repeat are defined once as custom properties in :root below. Responsive
 * rules are collected at the bottom. No base64 or layout hackery in here.
 * ==========================================================================*/

/* ---------- design tokens ------------------------------------------------- */
:root{
  --cream:#F5F2E4;
  --cream-soft:#FBF9F1;
  --paper:#FFFFFF;
  --charcoal:#1E1A14;
  --charcoal-soft:#322C22;
  --gold:#B1913C;
  --gold-dark:#8C6B22;
  --gold-bright:#C9A648;
  --concrete:#8C887C;
  --concrete-soft:#E7E4DA;
  --ink:#2A251D;
  --ink-soft:#6B6457;
  --line:#DCD6C4;
  --wa-green:#25D366;
  --radius:2px;
  --maxw:1200px;
}

/* ---------- base / reset -------------------------------------------------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
}

body{
  margin:0;
  font-family:'Work Sans', sans-serif;
  color:var(--ink);
  background:var(--cream-soft);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3{
  font-family:'Zilla Slab', serif;
  color:var(--charcoal);
  margin:0;
  line-height:1.1;
}

a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{margin:0;padding:0;list-style:none;}
button,input,select,textarea{font-family:inherit;font-size:inherit;}

:focus-visible{outline:2px solid var(--gold-dark); outline-offset:3px;}

/* ---------- layout utilities --------------------------------------------- */
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
.eyebrow{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--gold-dark);
  font-weight:600;
}
.section-head{max-width:640px; margin-bottom:42px;}
.section-head h2{font-size:clamp(1.6rem, 3vw, 2.3rem); margin-top:10px;}
.section-head p{color:var(--ink-soft); margin-top:14px; font-size:1.02rem;}

section{padding:78px 0;}

/* ---------- buttons ------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 24px;
  font-weight:600; font-size:0.95rem;
  border-radius:var(--radius);
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform 0.15s ease, background 0.15s ease, color 0.15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px);}
.btn-gold{background:var(--gold-dark); color:var(--cream-soft);}
.btn-gold:hover{background:#73561C;}
.btn-ghost{background:transparent; color:var(--cream-soft); border-color:rgba(245,242,228,0.45);}
.btn-ghost:hover{border-color:var(--gold-bright); color:var(--gold-bright);}
.btn-outline{background:transparent; color:var(--charcoal); border-color:var(--charcoal);}
.btn-outline:hover{background:var(--charcoal); color:var(--cream-soft);}
.btn-wa{background:var(--wa-green); color:#fff;}
.btn-wa:hover{background:#1FAE54;}
.btn-sm{padding:10px 18px; font-size:0.85rem;}
.btn svg{width:18px; height:18px; flex:none;}

/* ---------- header / nav -------------------------------------------------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,249,241,0.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
.header-row{display:flex; align-items:center; justify-content:space-between; padding:14px 0;}
.brand{display:flex; align-items:center; gap:11px;}
.brand img{height:42px; width:auto;}
.brand-text{font-family:'Zilla Slab', serif; font-weight:700; font-size:1.18rem; color:var(--charcoal); letter-spacing:0.01em;}
.brand-text span{display:block; font-family:'IBM Plex Mono', monospace; font-weight:500; font-size:0.62rem; letter-spacing:0.13em; color:var(--gold-dark); text-transform:uppercase; margin-top:2px;}

.main-nav{display:flex; align-items:center; gap:34px;}
.main-nav a{font-size:0.92rem; font-weight:500; color:var(--ink); position:relative; padding:4px 0;}
.main-nav a:hover{color:var(--gold-dark);}
.header-cta{display:flex; align-items:center; gap:14px;}
.call-btn svg{width:16px; height:16px;}

.nav-toggle{display:none; background:none; border:none; cursor:pointer; padding:6px;}
.nav-toggle span{display:block; width:24px; height:2px; background:var(--charcoal); margin:5px 0; transition:transform .2s ease, opacity .2s ease;}

/* ---------- hero ---------------------------------------------------------- */
.hero{
  background:var(--charcoal);
  position:relative;
  overflow:hidden;
  padding:0;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  align-items:stretch;
  min-height:560px;
}
.hero-content{
  padding:88px 28px 64px clamp(28px, 6vw, 80px);
  display:flex; flex-direction:column; justify-content:center;
  max-width:640px;
}
.hero-content .eyebrow{color:var(--gold-bright);}
.hero-content h1{
  color:var(--cream-soft);
  font-size:clamp(2.1rem, 4.4vw, 3.4rem);
  margin-top:16px;
}
.hero-content p{
  color:#D8D2C2;
  font-size:1.08rem;
  margin-top:20px;
  max-width:520px;
}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px; margin-top:34px;}

.hero-visual{
  position:relative;
  background:linear-gradient(155deg, #2B2519 0%, var(--charcoal) 60%);
  display:flex; align-items:center; justify-content:center;
  border-left:1px solid rgba(177,145,60,0.25);
}
.hero-visual::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(177,145,60,0.07) 0, rgba(177,145,60,0.07) 1px, transparent 1px, transparent 64px),
    repeating-linear-gradient(90deg, rgba(177,145,60,0.07) 0, rgba(177,145,60,0.07) 1px, transparent 1px, transparent 64px);
}
.photo-stack{
  position:relative;
  width:min(320px, 72vw);
  aspect-ratio:1/1;
}
.stack-photo{
  position:absolute;
  width:68%;
  aspect-ratio:1/1;
  object-fit:contain;
  background:var(--cream-soft);
  border-radius:var(--radius);
  box-shadow:0 18px 34px rgba(0,0,0,0.4);
  padding:14px;
  box-sizing:border-box;
}
.stack-photo--back{top:0; left:0; transform:rotate(-7deg); z-index:1;}
.stack-photo--front{bottom:0; right:0; transform:rotate(5deg); z-index:2;}

/* spec strip */
.spec-strip{background:var(--gold-dark);}
.spec-strip ul{
  display:flex; flex-wrap:wrap;
  max-width:var(--maxw); margin:0 auto; padding:0 28px;
}
.spec-strip li{
  flex:1 1 auto;
  padding:15px 22px;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.74rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--cream-soft);
  font-weight:600;
  border-right:1px solid rgba(245,242,228,0.22);
  text-align:center;
}
.spec-strip li:last-child{border-right:none;}

/* ---------- intro (lead paragraph under hero) ---------------------------- */
.intro{padding:70px 0 10px;}
.intro p.lead{
  font-size:1.18rem;
  color:var(--charcoal-soft);
  max-width:780px;
  font-family:'Zilla Slab', serif;
  line-height:1.5;
}

/* ---------- products ----------------------------------------------------- */
.products{background:var(--cream-soft);}
.product-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
}
.product-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:38px 34px;
  display:flex; flex-direction:column;
  border-top:4px solid var(--gold-dark);
}
.product-card.aac{border-top-color:var(--concrete);}

/* card header row: eyebrow + brand logo */
.card-header{
  display:flex; align-items:center; justify-content:space-between;
  flex-direction: column-reverse;
  gap:12px;
}
.card-header .eyebrow{ margin:0; }
.card-brand-logo{
  height:36px; width:auto;
  object-fit:contain;
  flex:none;
  opacity:0.88;
}
/* Separate height adjustments per product */
.product-card:not(.aac) .card-brand-logo {
  height: 40px; /* Peejay Max logo height */
}
.product-card.aac .card-brand-logo {
  height: 60px; /* G-Vectors logo height */
}

.product-photo{
  aspect-ratio:1/1;
  background:var(--cream-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  padding:22px;
  margin-top:18px;
}
.product-photo img{width:100%; height:100%; object-fit:contain;}
.product-card h3{font-size:1.55rem; margin-top:18px;}
.product-card .desc{color:var(--ink-soft); margin-top:12px; font-size:0.98rem;}

.spec-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:14px 18px;
  margin:26px 0 8px;
  padding:20px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.spec-grid dt{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.66rem; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--ink-soft); margin:0;
}
.spec-grid dd{
  margin:4px 0 0; font-weight:600; color:var(--charcoal); font-size:0.92rem;
}

.adv-list{margin:22px 0 28px; display:grid; gap:10px;}
.adv-list li{
  display:flex; align-items:flex-start; gap:10px;
  font-size:0.93rem; color:var(--ink);
}
.adv-list svg{flex:none; width:16px; height:16px; margin-top:3px; color:var(--gold-dark);}
.product-card.aac .adv-list svg{color:var(--concrete);}

.product-card .btn{margin-top:auto; align-self:flex-start;}

/* ---------- why us ------------------------------------------------------- */
.why-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.why-card{
  background:var(--cream-soft);
  padding:32px 28px;
}
.why-card h3{font-size:1.05rem; font-family:'Work Sans', sans-serif; font-weight:600;}
.why-card p{color:var(--ink-soft); font-size:0.91rem; margin-top:10px;}
.why-card .mark{
  font-family:'IBM Plex Mono', monospace;
  color:var(--gold-dark); font-size:0.78rem; font-weight:600;
  letter-spacing:0.06em;
}

/* ---------- service area ------------------------------------------------- */
.service-area{background:var(--charcoal);}
.service-area .section-head h2, .service-area .eyebrow{color:var(--cream-soft);}
.service-area .eyebrow{color:var(--gold-bright);}
.service-area .section-head p{color:#C9C3B2;}
.district-cloud{display:flex; flex-wrap:wrap; gap:12px;}
.district-cloud li{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.78rem; letter-spacing:0.04em;
  color:var(--cream-soft);
  border:1px solid rgba(245,242,228,0.3);
  padding:9px 17px;
  border-radius:999px;
}
.district-cloud li.home{border-color:var(--gold-bright); color:var(--gold-bright);}

/* ---------- contact ------------------------------------------------------ */
.contact{background:var(--cream-soft);}
.contact-grid{
  display:grid; grid-template-columns:0.85fr 1.15fr; gap:50px;
  align-items:start;
}
.contact-info h2{font-size:clamp(1.5rem,3vw,2.1rem);}
.contact-info p.lead{color:var(--ink-soft); margin-top:12px; max-width:420px;}

.info-list{margin-top:30px; display:grid; gap:20px;}
.info-list li{display:flex; gap:14px;}
.info-list .ic{
  flex:none; width:38px; height:38px; border-radius:50%;
  background:var(--charcoal); color:var(--gold-bright);
  display:flex; align-items:center; justify-content:center;
}
.info-list .ic svg{width:18px; height:18px;}
.info-list .label{font-family:'IBM Plex Mono', monospace; font-size:0.66rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--ink-soft);}
.info-list .val{font-weight:600; color:var(--charcoal); margin-top:2px; font-size:0.95rem;}
.info-list a.val:hover{color:var(--gold-dark);}

.map-embed{margin-top:30px; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;}
.map-embed iframe{width:100%; height:240px; border:0; display:block; filter:grayscale(0.15);}

.contact-form{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:36px;
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.field{margin-bottom:18px;}
.field label{
  display:block; font-family:'IBM Plex Mono', monospace; font-size:0.68rem;
  text-transform:uppercase; letter-spacing:0.07em; color:var(--ink-soft); margin-bottom:7px;
}
.field input, .field select, .field textarea{
  width:100%; padding:11px 13px;
  border:1px solid var(--line); border-radius:var(--radius);
  background:var(--cream-soft); color:var(--ink);
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--gold-dark); background:var(--paper);
}
.field textarea{resize:vertical; min-height:90px;}
.form-note{font-size:0.8rem; color:var(--ink-soft); margin-top:14px;}
.form-note a{color:var(--gold-dark); font-weight:600;}

/* ---------- footer ------------------------------------------------------- */
footer{background:var(--charcoal); color:#C9C3B2; padding:50px 0 26px;}
.footer-grid{display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:40px;}
.footer-brand{display:flex; align-items:center; gap:10px; margin-bottom:14px;}
.footer-brand img{height:36px;}
.footer-brand span{font-family:'Zilla Slab', serif; font-weight:700; color:var(--cream-soft); font-size:1.05rem;}
footer p{font-size:0.88rem; line-height:1.6;}
footer h4{font-family:'IBM Plex Mono', monospace; font-size:0.7rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--gold-bright); margin-bottom:14px;}
footer ul{display:grid; gap:10px;}
footer a{font-size:0.88rem;}
footer a:hover{color:var(--gold-bright);}
.footer-bottom{
  margin-top:42px; padding-top:22px; border-top:1px solid rgba(245,242,228,0.14);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:0.78rem; color:#9C9684;
}

/* ---------- floating whatsapp -------------------------------------------- */
.float-wa{
  position:fixed; right:22px; bottom:22px; z-index:60;
  display:flex; align-items:center; gap:10px;
}
.float-wa a{
  width:58px; height:58px; border-radius:50%;
  background:var(--wa-green); color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 26px rgba(0,0,0,0.28);
  position:relative;
}
.float-wa a svg{width:28px; height:28px;}
.float-wa a::after{
  content:""; position:absolute; inset:0; border-radius:50%;
  box-shadow:0 0 0 0 rgba(37,211,102,0.55);
  animation:wa-pulse 2.4s ease-out infinite;
}
@keyframes wa-pulse{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,0.5);}
  80%{box-shadow:0 0 0 18px rgba(37,211,102,0);}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0);}
}

/* ---------- scroll reveal ------------------------------------------------ */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease;}
.reveal.in{opacity:1; transform:none;}

/* ---------- responsive --------------------------------------------------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr; min-height:0;}
  .hero-visual{min-height:280px; padding:40px 0;}
  .hero-content{padding:54px 24px 40px;}
  .product-grid{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr 1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:760px){
  .main-nav{
    position:absolute; top:100%; left:0; right:0; background:var(--cream-soft);
    flex-direction:column; align-items:flex-start; gap:0;
    padding:10px 28px; transform:translateY(-8px); opacity:0; pointer-events:none;
    transition:transform .25s ease, opacity .25s ease; border-top:1px solid var(--line);
    box-shadow:0 16px 26px -16px rgba(0,0,0,0.25);
  }
  .main-nav.open{transform:translateY(0); opacity:1; pointer-events:auto;}
  .main-nav a{width:100%; padding:14px 0; border-bottom:1px solid var(--line);}
  .nav-toggle{display:block;}
  .header-cta{gap:10px;}
  .call-btn{padding:10px; }
  .call-btn .call-text{display:none;}
  .why-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr; gap:30px;}
  .spec-strip ul{flex-direction:column;}
  .spec-strip li{border-right:none; border-bottom:1px solid rgba(245,242,228,0.22); text-align:left;}
  .spec-strip li:last-child{border-bottom:none;}
  section{padding:58px 0;}
  .float-wa a{width:52px; height:52px;}
}
@media (max-width:480px){
  .wrap{padding:0 18px;}
  .brand-text span{display:none;}
  .brand img{height:34px;}
  .header-row{padding:11px 0;}
  .hero-content{padding:40px 18px 32px;}
  .hero-content p{font-size:1rem;}
  .hero-actions .btn{flex:1 1 auto; justify-content:center;}
  .product-card{padding:26px 20px;}
  .why-card{padding:24px 20px;}
  .contact-form{padding:24px 20px;}
  .spec-grid{grid-template-columns:1fr 1fr; gap:12px 14px;}
  section{padding:46px 0;}
  .section-head{margin-bottom:30px;}
}
