/*
Theme Name: TwinCraft
Theme URI: https://twincraftstudio.com
Author: Hira Wahidi & Meena Wahidi
Author URI: https://twincraftstudio.com
Description: A minimal, professional theme built for TwinCraft Studio — SEO, web design, graphic & packaging design, book design, and content publishing services.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: twincraft
*/

/* ==========================================================================
   1. TOKENS — derived from the TwinCraft logo
   ========================================================================== */
:root{
  /* Brand */
  --ink:        #15131F; /* near-black, warm undertone — text, dark surfaces */
  --ink-soft:   #292540; /* lighter dark surface, footer/cta gradients */
  --paper:      #FFFFFF; /* crisp white — main background */
  --mist:       #ECE8F8; /* soft indigo-tinted band — the "colored" sections */
  --indigo:     #5050B4; /* Twin Indigo — primary brand color, from logo */
  --indigo-deep:#3D3D8C;
  --indigo-tint:#E7E5F7;
  --teal:       #3F9D79; /* Craft Teal — secondary brand color, from logo */
  --teal-deep:  #2F7A5E;
  --teal-tint:  #E1F1EA;
  --slate:      #5B5868; /* muted secondary text */
  --line:       #E4E0EE; /* hairline borders */
  --white:      #FFFFFF;

  /* Type */
  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Inter', -apple-system, Segoe UI, sans-serif;
  --font-mono: 'IBM Plex Mono', 'Courier New', monospace;

  /* Spacing scale */
  --sp-1: 0.5rem;
  --sp-2: 0.875rem;
  --sp-3: 1.5rem;
  --sp-4: 2.25rem;
  --sp-5: 3.5rem;
  --sp-6: 5.5rem;
  --sp-6b: 4rem;
  --sp-7: 8rem;

  /* Layout */
  --container: 1180px;
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ==========================================================================
   2. RESET
   ========================================================================== */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
input,textarea,select{ font-family:inherit; font-size:1rem; }
h1,h2,h3,h4,p,figure{ margin:0; }

::selection{ background:var(--indigo); color:var(--white); }

:focus-visible{
  outline:2px solid var(--indigo);
  outline-offset:3px;
  border-radius:4px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* ==========================================================================
   3. TYPOGRAPHY
   ========================================================================== */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--font-mono);
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--indigo-deep);
}
.eyebrow::before{
  content:"";
  width:7px; height:7px;
  border-radius:50%;
  background:var(--teal);
  flex-shrink:0;
}

h1,.h1{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-0.01em;
  font-size:clamp(2.6rem, 5.4vw, 4.6rem);
}
h2,.h2{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.1;
  letter-spacing:-0.01em;
  font-size:clamp(2rem, 3.6vw, 2.85rem);
}
h3,.h3{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.2;
  font-size:1.4rem;
}
.lede{
  font-size:1.2rem;
  color:var(--slate);
  line-height:1.6;
  max-width:42em;
}
.muted{ color:var(--slate); }
em{ font-style:italic; color:var(--indigo); }

/* ==========================================================================
   4. LAYOUT HELPERS
   ========================================================================== */
.wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--sp-3);
}
.section{ padding:var(--sp-6) 0; }
.section--tight{ padding:var(--sp-6b) 0; }
.section--dark{ background:var(--ink); color:var(--paper); }
.section--dark .muted{ color:#B9B4C9; }
.section--mist{ background:var(--mist); }

.section-head{
  max-width:46em;
  margin-bottom:var(--sp-5);
}
.section-head .eyebrow{ margin-bottom:var(--sp-1); }
.section-head h2{ margin-top:.3em; }

.grid{ display:grid; gap:var(--sp-4); }
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* ==========================================================================
   5. BUTTONS
   ========================================================================== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.96rem;
  padding:.85em 1.6em;
  border-radius:999px;
  border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s, border-color .25s, color .25s;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--indigo); color:var(--white); }
.btn-primary:hover{ background:var(--indigo-deep); }
.btn-whatsapp{ background:var(--teal); color:var(--white); }
.btn-whatsapp:hover{ background:var(--teal-deep); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); }
.section--dark .btn-ghost,
.cta-band .btn-ghost{ color:var(--paper); border-color:#48425E; }
.section--dark .btn-ghost:hover,
.cta-band .btn-ghost:hover{ border-color:var(--paper); }
.btn svg{ width:1.1em; height:1.1em; }

/* ==========================================================================
   6. HEADER
   ========================================================================== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  max-height:76px;
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:var(--sp-2); padding-bottom:var(--sp-2);
  min-height:76px; gap:var(--sp-2); flex-wrap:nowrap;
}
.site-logo{ display:flex; align-items:center; max-height:40px; flex-shrink:1; min-width:0; overflow:hidden; }
.site-logo img,
img.custom-logo{
  height:36px !important;
  max-height:36px !important;
  width:auto !important;
  max-width:100%;
}
.site-logo-text{
  font-family:var(--font-display); font-weight:600; font-size:1.3rem; color:var(--ink);
  white-space:nowrap;
}
.site-logo-text span{ color:var(--indigo); }

.main-nav ul{ display:flex; align-items:center; gap:var(--sp-4); }
.main-nav a{
  font-size:.96rem; font-weight:500; color:var(--ink);
  position:relative; padding:.3em 0;
}
.main-nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--teal); transition:width .25s var(--ease);
}
.main-nav a:hover::after{ width:100%; }

.header-actions{ display:flex; align-items:center; gap:var(--sp-3); flex-shrink:0; }
.nav-toggle{
  display:none;
  position:relative; width:32px; height:32px;
  background:none; border:none; padding:0; flex-shrink:0;
}
.nav-toggle span{
  position:absolute; left:4px; width:24px; height:2px; background:var(--ink);
  border-radius:2px; transition:transform .3s var(--ease), opacity .3s var(--ease), top .3s var(--ease);
}
.nav-toggle span:nth-child(1){ top:11px; }
.nav-toggle span:nth-child(2){ top:19px; }
.nav-toggle span:nth-child(3){ top:27px; }
.nav-toggle.is-open span:nth-child(1){ top:19px; transform:rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity:0; }
.nav-toggle.is-open span:nth-child(3){ top:19px; transform:rotate(-45deg); }

.nav-backdrop{
  display:none;
  position:fixed; inset:0; z-index:39;
  background:rgba(15,14,22,.5);
  opacity:0; transition:opacity .35s var(--ease);
  pointer-events:none;
}

@media (max-width: 880px){
  .main-nav{
    position:fixed; top:0; right:0; bottom:0;
    width:78vw; max-width:320px;
    background:var(--ink);
    transform:translateX(100%); transition:transform .35s var(--ease);
    padding:96px var(--sp-3) var(--sp-4); z-index:40; overflow-y:auto;
    box-shadow:-24px 0 48px -24px rgba(0,0,0,.4);
  }
  .main-nav.is-open{ transform:translateX(0); }
  .main-nav ul{ flex-direction:column; align-items:stretch; gap:0; height:auto !important; }
  .main-nav li{
    border-bottom:1px solid rgba(255,255,255,.1);
    flex:none !important; height:auto !important; min-height:0 !important;
  }
  .main-nav li:first-child{ border-top:1px solid rgba(255,255,255,.1); }
  .main-nav a{
    display:block; padding:1.05em .2em; font-size:1.05rem; line-height:1.3; color:var(--paper);
    height:auto !important; min-height:0 !important;
  }
  .main-nav a::after{ display:none; }
  .main-nav a:active{ color:var(--teal); }

  .nav-backdrop{ display:block; }
  .nav-backdrop.is-open{ opacity:1; pointer-events:auto; }

  .nav-toggle{ display:flex; position:relative; z-index:41; }
  .header-actions .btn-ghost{ display:none; }
  .site-logo{ max-width:42vw; }
}

@media (max-width:480px){
  .header-actions .btn-whatsapp{
    padding:0; width:42px; height:42px; border-radius:50%;
    justify-content:center;
  }
  .header-actions .btn-whatsapp .btn-label{ display:none; }
}

/* ==========================================================================
   7. HERO — overlapping circles motif (the logo, enacted at scale)
   ========================================================================== */
.hero{
  position:relative;
  padding:var(--sp-7) 0 var(--sp-6);
  overflow:hidden;
  background:var(--mist);
}
.hero-orbs{
  position:absolute; inset:0; z-index:0; pointer-events:none;
}
.hero-ring{
  position:absolute; width:460px; height:460px;
  top:-60px; right:6%;
  filter:drop-shadow(0 18px 32px rgba(21,19,31,.16));
}
.hero-ring-indigo{ animation:hero-ring-part-left 7s ease-in-out infinite; }
.hero-ring-teal{ animation:hero-ring-part-right 7s ease-in-out infinite; }
@keyframes hero-ring-part-left{
  0%,18%,82%,100%{ transform:translateX(0); }
  50%{ transform:translateX(-70px); }
}
@keyframes hero-ring-part-right{
  0%,18%,82%,100%{ transform:translateX(0); }
  50%{ transform:translateX(70px); }
}
@media (max-width:980px){
  .hero-ring{ width:340px; height:340px; right:-2%; top:-40px; }
}
@media (max-width:640px){
  .hero-ring{ width:250px; height:250px; right:-10%; top:-30px; opacity:.75; }
}
@media (prefers-reduced-motion: reduce){
  .hero-ring-indigo,.hero-ring-teal{ animation:none; }
}

/* Shared sphere orbs — used as decoration in CTA bands across multiple
   pages (front-page, about, services, service-detail). Not used in the
   hero anymore (see .hero-ring above), kept here for those other sections. */
.orb{
  position:absolute; border-radius:50%;
  box-shadow:
    inset -14px -14px 36px rgba(0,0,0,.28),
    inset 12px 12px 28px rgba(255,255,255,.22);
}
.orb-indigo{
  background:radial-gradient(circle at 32% 26%, #9A98E6 0%, var(--indigo) 45%, var(--indigo-deep) 100%);
}
.orb-teal{
  background:radial-gradient(circle at 32% 26%, #82D4AE 0%, var(--teal) 45%, var(--teal-deep) 100%);
}

.hero-inner{ position:relative; z-index:1; max-width:38em; }
.hero h1{ margin-top:var(--sp-2); }
.hero h1 em{ font-style:normal; }
.hero .lede{ margin-top:var(--sp-3); }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:var(--sp-2); margin-top:var(--sp-4); }

.hero-proof{
  position:relative; z-index:1;
  margin-top:var(--sp-6);
  display:flex; flex-wrap:wrap; gap:var(--sp-4);
  align-items:center;
}
.proof-badge{
  display:flex; align-items:center; gap:.6em;
  font-family:var(--font-mono); font-size:.82rem; letter-spacing:.02em;
  color:var(--slate); background:var(--white); border:1px solid var(--line);
  padding:.6em 1em; border-radius:999px;
}
.proof-badge svg{ width:16px; height:16px; flex-shrink:0; }

/* ==========================================================================
   8. SERVICES
   ========================================================================== */
.services-grid{
  grid-template-columns:repeat(3, 1fr);
}
@media (max-width:980px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .services-grid{ grid-template-columns:1fr; } }

.service-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:var(--sp-4);
  transition:transform .35s var(--ease), border-color .35s, box-shadow .35s;
}
.service-card:hover{
  transform:translateY(-5px);
  border-color:transparent;
  box-shadow:0 24px 48px -24px rgba(21,19,31,.18);
}
.service-card.is-featured{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
  grid-row: span 1;
}
.service-card.is-featured .muted{ color:#B9B4C9; }
.service-card.is-featured .service-icon{ background:var(--teal); }

.service-icon{
  width:46px; height:46px; border-radius:12px;
  background:var(--mist);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--sp-3);
}
.service-icon svg{ width:22px; height:22px; color:var(--indigo); }
.is-featured .service-icon svg{ color:var(--white); }

.service-card h3{ margin-bottom:.5em; }
.service-card .who{
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.08em;
  text-transform:uppercase; color:var(--teal-deep); display:block; margin-bottom:.8em;
}
.is-featured .who{ color:var(--teal); }
.service-list{ margin-top:var(--sp-2); display:flex; flex-direction:column; gap:.55em; }
.service-list li{
  font-size:.93rem; color:var(--slate); padding-left:1.3em; position:relative;
}
.is-featured .service-list li{ color:#D8D4E6; }
.service-list li::before{
  content:""; position:absolute; left:0; top:.5em;
  width:7px; height:7px; border-radius:50%; background:var(--teal);
}
.service-card .quote-link{
  margin-top:var(--sp-3); display:inline-flex; align-items:center; gap:.4em;
  font-weight:600; font-size:.92rem; color:var(--indigo);
}
.is-featured .quote-link{ color:var(--white); }
.service-card .quote-link svg{ width:15px; height:15px; transition:transform .25s var(--ease); }
.service-card:hover .quote-link svg{ transform:translate(3px,-3px); }

.card-btn{
  display:inline-flex; align-items:center; gap:.45em;
  margin-top:var(--sp-3); padding:.6em 1.15em;
  border:1.5px solid var(--line); border-radius:999px;
  font-weight:600; font-size:.86rem; color:var(--ink);
  transition:border-color .25s var(--ease), background .25s, color .25s;
}
.card-btn svg{ width:13px; height:13px; transition:transform .25s var(--ease); }
.card-btn:hover{ border-color:var(--indigo); background:var(--indigo-tint); color:var(--indigo-deep); }
.card-btn:hover svg{ transform:translate(2px,-2px); }
.is-featured .card-btn{ border-color:#48425E; color:var(--paper); }
.is-featured .card-btn:hover{ border-color:var(--teal); background:rgba(63,157,121,.18); color:var(--paper); }

/* ==========================================================================
   9. TWO OF US — editorial profile cards
   ========================================================================== */
.twins-grid{
  position:relative;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-5);
  align-items:stretch;
}
@media (max-width:880px){ .twins-grid{ grid-template-columns:1fr; gap:var(--sp-5); } }

.twin-card{
  position:relative;
  display:flex; flex-direction:column;
  text-align:left;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:28px;
  padding:var(--sp-4) var(--sp-4) var(--sp-3);
  overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.twin-card:hover{ transform:translateY(-6px); box-shadow:0 28px 52px -28px rgba(21,19,31,.22); }
.twin-card[data-twin="hira"]{ border-top:4px solid var(--teal); }
.twin-card[data-twin="meena"]{ border-top:4px solid var(--indigo); }

.twin-index{
  position:absolute; top:var(--sp-2); right:var(--sp-3);
  font-family:var(--font-display); font-weight:600; font-size:3.6rem; line-height:1;
  color:var(--line); z-index:0; user-select:none;
}

.twin-card-header{
  position:relative; z-index:1;
  display:flex; align-items:center; gap:var(--sp-3);
  margin-bottom:var(--sp-3);
}
.twin-avatar-wrap{
  position:relative; width:104px; height:104px; margin-bottom:0; flex-shrink:0;
  overflow:hidden;
}
.twin-avatar-wrap svg{ width:100%; height:100%; }
.twin-avatar-wrap img{
  width:100%; height:100%; object-fit:cover; border-radius:50%; display:block;
  -webkit-user-drag:none; user-select:none; -webkit-touch-callout:none;
}
.twin-card[data-twin="hira"] .twin-avatar-wrap{ background:var(--teal-tint); border-radius:50%; box-shadow:0 0 0 3px var(--teal); }
.twin-card[data-twin="meena"] .twin-avatar-wrap{ background:var(--indigo-tint); border-radius:50%; box-shadow:0 0 0 3px var(--indigo); }

/* Badge-style avatars: square artwork with its own ring graphic baked in —
   shown in full rather than cropped into the plain circular frame above. */
.twin-avatar-wrap.is-badge,
.twin-card[data-twin="hira"] .twin-avatar-wrap.is-badge,
.twin-card[data-twin="meena"] .twin-avatar-wrap.is-badge{
  background:transparent; box-shadow:none; border-radius:0; overflow:visible;
}
.twin-avatar-wrap.is-badge img{
  border-radius:0; object-fit:contain;
}

.twin-card h3{ font-size:1.35rem; line-height:1.2; }
.twin-role{
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--teal-deep); display:block; margin-top:.45em;
}
.twin-card[data-twin="meena"] .twin-role{ color:var(--indigo-deep); }
.twin-bio{ position:relative; z-index:1; color:var(--slate); }
.twin-tags{ position:relative; z-index:1; display:flex; flex-wrap:wrap; gap:.5em; margin-top:var(--sp-2); }
.twin-tag{
  font-size:.8rem; padding:.35em .85em; border-radius:999px;
  background:transparent; border:1px solid var(--line); color:var(--ink-soft);
}
.twin-card[data-twin="hira"] .twin-tag{ border-color:var(--teal); color:var(--teal-deep); }
.twin-card[data-twin="meena"] .twin-tag{ border-color:var(--indigo); color:var(--indigo-deep); }

.twin-upwork{
  position:relative; z-index:1;
  margin-top:var(--sp-4); justify-content:center;
  display:flex; align-items:center; gap:.5em;
  font-weight:700; font-size:.92rem; padding:.75em 1.1em;
  border:none; border-radius:999px; color:var(--paper);
  background:var(--indigo-deep);
  transition:background .25s, transform .25s var(--ease);
}
.twin-upwork:hover{ background:var(--indigo); transform:translateY(-2px); }
.twin-upwork.is-hira{ background:var(--teal-deep); }
.twin-upwork.is-hira:hover{ background:var(--teal); }
.twin-upwork.is-meena{ background:var(--indigo-deep); }
.twin-upwork.is-meena:hover{ background:var(--indigo); }
.twin-card[data-twin="hira"] .twin-upwork{ background:var(--teal-deep); }
.twin-card[data-twin="hira"] .twin-upwork:hover{ background:var(--teal); }
.twin-card[data-twin="meena"] .twin-upwork{ background:var(--indigo-deep); }
.twin-card[data-twin="meena"] .twin-upwork:hover{ background:var(--indigo); }
.twin-upwork svg{ width:16px; height:16px; }
.proof-callout-links{ display:flex; flex-wrap:wrap; gap:var(--sp-2); margin-top:var(--sp-4); }
.proof-callout-links .twin-upwork{ margin-top:0; }

/* connecting "&" mark between the two cards, desktop only */
.twins-amp{
  display:none;
}
@media (min-width:881px){
  .twins-amp{
    display:flex; align-items:center; justify-content:center;
    position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
    width:54px; height:54px; border-radius:50%;
    background:var(--paper); border:1.5px solid var(--line);
    font-family:var(--font-display); font-style:italic; font-size:1.4rem; color:var(--ink-soft);
    box-shadow:0 10px 24px -10px rgba(21,19,31,.18);
    z-index:2;
  }
}

/* ==========================================================================
   10. TRUST / UPWORK STRIP
   ========================================================================== */
.trust-strip{
  display:flex; flex-wrap:wrap; gap:var(--sp-3); align-items:center; justify-content:space-between;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:var(--sp-4) var(--sp-4);
}
.trust-copy{ max-width:30em; }
.trust-copy h3{ margin-bottom:.3em; }
.trust-actions{ display:flex; flex-wrap:wrap; gap:var(--sp-2); }

/* ==========================================================================
   11. PRICING PHILOSOPHY
   ========================================================================== */
.pricing-band{
  background:var(--mist); border-radius:var(--radius-lg);
  padding:var(--sp-5); display:grid; grid-template-columns:1.1fr .9fr; gap:var(--sp-5);
  align-items:center;
}
@media (max-width:880px){ .pricing-band{ grid-template-columns:1fr; } }
.pricing-points{ display:flex; flex-direction:column; gap:var(--sp-3); }
.pricing-point{ display:flex; gap:var(--sp-2); }
.pricing-point .num{
  font-family:var(--font-mono); font-size:.85rem; color:var(--teal-deep);
  flex-shrink:0; padding-top:.2em;
}
.pricing-point p{ margin:0; color:var(--ink-soft); }
.pricing-point strong{ display:block; color:var(--ink); margin-bottom:.15em; }

/* ==========================================================================
   12. CTA BAND
   ========================================================================== */
.cta-band{
  background:linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%);
  color:var(--paper);
  padding:var(--sp-6) 0;
  text-align:center;
  position:relative; overflow:hidden;
}
.cta-band .orb{ mix-blend-mode:screen; opacity:.5; }
.cta-band .cta-inner{ position:relative; z-index:1; }
.cta-band h2{ position:relative; z-index:1; }
.cta-band .lede{ margin:var(--sp-2) auto 0; color:#C7C2D9; position:relative; z-index:1; }
.cta-band .hero-ctas{ justify-content:center; position:relative; z-index:1; margin-top:var(--sp-4); }

/* ==========================================================================
   13. FOOTER
   ========================================================================== */
.site-footer{
  background:#0F0E16; color:#C7C2D9; padding:var(--sp-6) 0 var(--sp-3);
  border-top:1px solid rgba(255,255,255,.08);
  box-shadow:0 -24px 40px -32px rgba(0,0,0,.35) inset;
}
.footer-top{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:var(--sp-4);
  padding-bottom:var(--sp-5); border-bottom:1px solid #332E4A;
}
@media (max-width:880px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer-top{ grid-template-columns:1fr; } }
.footer-brand{ max-width:26em; }
.footer-logo-chip{
  display:inline-flex; align-items:center;
  background:var(--white);
  padding:.65em 1.1em;
  border-radius:var(--radius-md);
  margin-bottom:var(--sp-2);
}
.footer-logo-chip img,
.footer-logo-chip img.custom-logo{
  height:28px !important;
  max-height:28px !important;
  width:auto !important;
  display:block;
}
.footer-logo-chip .site-logo-text{ font-size:1.1rem; }
.footer-brand p{ max-width:24em; color:#9A93B3; font-size:.92rem; }
.footer-col h4{
  font-family:var(--font-mono); font-size:.76rem; letter-spacing:.1em; text-transform:uppercase;
  color:#9A93B3; margin-bottom:var(--sp-2); font-weight:500;
}
.footer-col ul{ display:flex; flex-direction:column; gap:.7em; }
.footer-col a{ font-size:.93rem; color:#D8D4E6; transition:color .2s; }
.footer-col a:hover{ color:var(--teal); }
.footer-bottom{
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:var(--sp-2);
  padding-top:var(--sp-3); font-size:.85rem; color:#8A82A6;
}
.footer-bottom a{ color:#8A82A6; }
.footer-bottom a:hover{ color:var(--paper); }
.footer-col a.icon-link{ display:inline-flex; align-items:center; gap:.55em; }
.footer-col a.icon-link svg{ flex-shrink:0; opacity:.85; }
.footer-col a.icon-link:hover svg{ opacity:1; }

/* floating WhatsApp button */
.whatsapp-float{
  position:fixed; bottom:24px; right:24px; z-index:60;
  width:58px; height:58px; border-radius:50%;
  background:var(--teal); color:var(--white);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 28px -10px rgba(63,157,121,.55);
  transition:transform .25s var(--ease);
}
.whatsapp-float:hover{ transform:scale(1.08); }
.whatsapp-float svg{ width:28px; height:28px; }

/* ==========================================================================
   14. BLOG — listing & single
   ========================================================================== */
.page-title-band{ padding:var(--sp-6) 0 var(--sp-4); }
.page-title-band .eyebrow{ margin-bottom:var(--sp-1); }

.post-grid{ grid-template-columns:repeat(3,1fr); }
@media (max-width:980px){ .post-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .post-grid{ grid-template-columns:1fr; } }

.post-card{ display:flex; flex-direction:column; }
.post-card .thumb{
  border-radius:var(--radius-md); overflow:hidden; aspect-ratio:4/3; background:var(--mist);
  margin-bottom:var(--sp-2);
}
.post-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.post-meta{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--slate); margin-bottom:.5em; }
.post-card h3{ font-size:1.25rem; }
.post-card h3 a:hover{ color:var(--indigo); }
.post-card p{ color:var(--slate); margin-top:.5em; font-size:.95rem; }
.pagination{ display:flex; gap:var(--sp-2); margin-top:var(--sp-5); justify-content:center; }
.pagination a,.pagination span{
  padding:.6em 1.1em; border:1px solid var(--line); border-radius:999px; font-size:.9rem;
}

.single-post-head{ max-width:38em; margin:0 auto; text-align:center; }
.single-post-head h1{ font-size:clamp(2rem,4vw,3rem); }
.single-thumb{ border-radius:var(--radius-lg); overflow:hidden; margin:var(--sp-5) 0; aspect-ratio:16/9; }
.single-thumb img{ width:100%; height:100%; object-fit:cover; }
.entry-content{ max-width:38em; margin:0 auto; }
.entry-content p,.entry-content ul,.entry-content ol{ margin-bottom:1.4em; color:var(--ink-soft); }
.entry-content h2{ font-size:1.7rem; margin:1.6em 0 .6em; }
.entry-content h3{ margin:1.4em 0 .5em; }
.entry-content img{ border-radius:var(--radius-md); margin:1.5em 0; }
.entry-content a{ color:var(--indigo); text-decoration:underline; text-decoration-color:var(--teal); }
.entry-content blockquote{
  border-left:3px solid var(--teal); padding-left:1.2em; font-style:italic; color:var(--ink-soft);
  margin:1.6em 0;
}
.author-box{
  max-width:38em; margin:var(--sp-5) auto 0; padding:var(--sp-3);
  background:var(--mist); border-radius:var(--radius-md);
  display:flex; gap:var(--sp-2); align-items:center;
}
.author-box .twin-avatar-wrap{ width:56px; height:56px; flex-shrink:0; margin-bottom:0; }
.author-box strong{ display:block; }
.author-box span{ font-size:.88rem; color:var(--slate); }

/* ==========================================================================
   15. GENERIC PAGE + ABOUT + CONTACT
   ========================================================================== */
.page-content{ max-width:42em; }
.page-content p{ margin-bottom:1.3em; color:var(--ink-soft); }

.values-grid{ grid-template-columns:repeat(3,1fr); }
@media (max-width:880px){ .values-grid{ grid-template-columns:1fr; } }
.value-card{ padding:var(--sp-3) 0; border-top:1px solid var(--line); }
.value-card h3{ font-size:1.15rem; margin-bottom:.4em; }
.value-card p{ color:var(--slate); font-size:.95rem; }

.contact-grid{ grid-template-columns:1fr 1fr; align-items:start; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }

.contact-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:var(--sp-4); display:flex; align-items:flex-start; gap:var(--sp-3); margin-bottom:var(--sp-2);
}
.contact-card .service-icon{ margin-bottom:0; flex-shrink:0; }
.contact-card h3{ font-size:1.1rem; margin-bottom:.3em; }
.contact-card p,.contact-card a{ color:var(--slate); font-size:.95rem; }
.contact-card a:hover{ color:var(--indigo); }

.form-field{ margin-bottom:var(--sp-2); }
.form-honeypot{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.form-field label{ display:block; font-size:.88rem; font-weight:600; margin-bottom:.4em; }
.form-field input,.form-field select,.form-field textarea{
  width:100%; padding:.85em 1em; border:1px solid var(--line); border-radius:var(--radius-sm);
  background:var(--white); transition:border-color .2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  border-color:var(--indigo); outline:none;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-2); }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr; } }
.form-note{ font-size:.85rem; color:var(--slate); margin-top:var(--sp-2); }

.form-conditional{
  padding:var(--sp-3); margin-bottom:var(--sp-3);
  background:var(--mist); border-radius:var(--radius-lg);
  border:1px solid var(--line);
}
.form-conditional[hidden]{ display:none; }
.form-conditional .form-field:last-child{ margin-bottom:0; }
.checkbox-group{ display:flex; flex-direction:column; gap:.6em; }
.checkbox-option{
  display:flex; align-items:center; gap:.6em;
  font-size:.92rem; font-weight:400; color:var(--ink-soft);
  cursor:pointer;
}
.checkbox-option input{
  width:auto; padding:0; border:none; background:none;
  accent-color:var(--indigo); flex-shrink:0;
}
.form-success{
  background:var(--teal-tint); border:1px solid var(--teal); color:var(--teal-deep);
  padding:var(--sp-2) var(--sp-3); border-radius:var(--radius-sm); margin-bottom:var(--sp-3); font-size:.92rem;
}
.form-error{
  background:#FBE9E9; border:1px solid #D9534F; color:#A33; 
  padding:var(--sp-2) var(--sp-3); border-radius:var(--radius-sm); margin-bottom:var(--sp-3); font-size:.92rem;
}

/* ==========================================================================
   15b. FAQ
   ========================================================================== */
.faq-list{ max-width:46em; margin:0 auto; display:flex; flex-direction:column; gap:.85rem; }
.faq-item{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-md);
  padding:1.1rem 1.4rem;
}
.faq-item summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3);
  font-family:var(--font-display); font-weight:600; font-size:1.05rem; color:var(--ink);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-icon{
  position:relative; flex-shrink:0; width:28px; height:28px; border-radius:50%;
  background:var(--mist); transition:background .25s var(--ease);
}
.faq-icon::before,.faq-icon::after{
  content:""; position:absolute; top:50%; left:50%; background:var(--indigo);
  transform:translate(-50%,-50%); transition:transform .3s var(--ease), background .25s;
}
.faq-icon::before{ width:12px; height:2px; }
.faq-icon::after{ width:2px; height:12px; }
.faq-item[open] .faq-icon{ background:var(--indigo); }
.faq-item[open] .faq-icon::before,
.faq-item[open] .faq-icon::after{ background:var(--white); }
.faq-item[open] .faq-icon::after{ transform:translate(-50%,-50%) rotate(90deg) scaleY(0); }
.faq-answer{ padding-top:.7rem; max-width:40em; }
.faq-answer p{ color:var(--slate); font-size:.96rem; line-height:1.65; margin:0; }

/* ==========================================================================
   16. 404
   ========================================================================== */
.error-404{ text-align:center; padding:var(--sp-7) 0; }
.error-404 .code{
  font-family:var(--font-mono); font-size:.9rem; letter-spacing:.1em; color:var(--teal-deep);
}
.error-404 h1{ margin-top:.3em; }
.error-404 .btn{ margin-top:var(--sp-4); }

/* ==========================================================================
   17. SERVICE DETAIL PAGE
   ========================================================================== */
.service-detail-block{ margin-top:var(--sp-6); max-width:48em; }
.service-detail-block h2{ font-size:1.5rem; margin-bottom:var(--sp-3); }

.deliverable-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-3) var(--sp-4);
}
@media (max-width:640px){ .deliverable-grid{ grid-template-columns:1fr; } }
.deliverable-item{
  display:flex; align-items:flex-start; gap:.7em;
  font-size:.96rem; color:var(--ink-soft); line-height:1.5;
}
.deliverable-item svg{ flex-shrink:0; margin-top:.2em; color:var(--teal-deep); width:18px; height:18px; }

.process-steps{
  display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-4);
}
@media (max-width:980px){ .process-steps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .process-steps{ grid-template-columns:1fr; } }
.process-step{ padding-top:var(--sp-2); border-top:2px solid var(--line); }
.process-step .step-num{
  display:block; font-family:var(--font-display); font-size:1.8rem; font-weight:600;
  color:var(--indigo); line-height:1; margin-bottom:.5em; opacity:.5;
}
.process-step h3{ font-size:1.05rem; margin-bottom:.35em; }
.process-step p{ font-size:.9rem; color:var(--slate); line-height:1.5; }

.proof-callout{
  margin-top:var(--sp-5); padding-top:var(--sp-5); border-top:1px solid var(--line);
  max-width:42em;
}
.proof-callout p{ color:var(--slate); font-size:.95rem; margin-bottom:var(--sp-2); }

.portfolio-block{ margin-top:var(--sp-6); }
.portfolio-block h2{ font-size:1.5rem; margin-bottom:var(--sp-3); }
.portfolio-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-2);
}
@media (max-width:768px){ .portfolio-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .portfolio-grid{ grid-template-columns:1fr; } }
.portfolio-item{
  display:block; aspect-ratio:4/3; border-radius:var(--radius-lg);
  overflow:hidden; background:var(--mist); border:1px solid var(--line);
}
.portfolio-item img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .4s var(--ease);
}
.portfolio-item:hover img{ transform:scale(1.05); }
