/* ==========================================================================
   INSPIRARE MEDIA AGENCY — design tokens
   ========================================================================== */

:root{
  --ink:        #171B12;   /* near-black, olive undertone */
  --ink-soft:   #232A1B;
  --bone:       #EDE7D6;   /* warm paper / khaki-cream */
  --bone-dim:   #DFD8C1;
  --lime:       #91C502;   /* brand signature accent */
  --lime-dim:   #6F9702;
  --clay:       #A85327;   /* terracotta accent */
  --clay-soft:  #C97A4F;
  --forest:     #1F3324;   /* deep alt-section green */
  --line:       rgba(237,231,214,0.14);
  --line-dark:  rgba(23,27,18,0.12);

  --display: "Fraunces", "Georgia", serif;
  --body:    "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;
  --mono:    "IBM Plex Mono", "Courier New", monospace;

  --radius: 2px;
  --container: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--bone);
  font-family:var(--body);
  font-size:16px;
  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; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; margin:0; line-height:1.05; }
p{ margin:0; }
button{ font-family:inherit; cursor:pointer; }

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

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--lime);
  display:flex;
  align-items:center;
  gap:.6em;
}
.eyebrow::before{
  content:"";
  width:18px;
  height:1px;
  background:var(--lime);
  display:inline-block;
}

.wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

.italic{ font-style:italic; color:var(--lime); }
.clay-italic{ font-style:italic; color:var(--clay-soft); }

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(23,27,18,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:76px;
}
.logo{
  font-family:var(--display);
  font-weight:600;
  font-size:22px;
  letter-spacing:.01em;
  display:flex; align-items:baseline; gap:8px;
}
.logo em{ color:var(--lime); font-style:italic; }
.logo span{
  font-family:var(--mono);
  font-size:10px;
  color:var(--bone-dim);
  letter-spacing:.12em;
  text-transform:uppercase;
}

.main-nav{ display:flex; align-items:center; gap:34px; }
.main-nav a{
  font-size:14px;
  letter-spacing:.02em;
  position:relative;
  padding:6px 0;
  color:var(--bone-dim);
  transition:color .2s ease;
}
.main-nav a:hover, .main-nav a.active{ color:var(--bone); }
.main-nav a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:2px; background:var(--lime);
}
.has-sub{ position:relative; }
.sub-nav{
  position:absolute; top:100%; left:-16px; margin-top:14px;
  background:var(--ink-soft);
  border:1px solid var(--line);
  min-width:230px;
  padding:8px;
  opacity:0; visibility:hidden; transform:translateY(6px);
  transition:all .18s ease;
}
.has-sub:hover .sub-nav, .has-sub:focus-within .sub-nav{
  opacity:1; visibility:visible; transform:translateY(0);
}
.sub-nav a{
  display:block; padding:10px 12px; font-size:13px;
  border-radius:2px;
}
.sub-nav a:hover{ background:rgba(145,197,2,0.1); color:var(--lime); }

.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:13px 22px;
  border:1px solid var(--bone);
  transition:all .2s ease;
  white-space:nowrap;
}
.btn:hover{ background:var(--bone); color:var(--ink); }
.btn-lime{ background:var(--lime); border-color:var(--lime); color:var(--ink); }
.btn-lime:hover{ background:transparent; color:var(--lime); }
.btn-ghost{ border-color:var(--line); }
.btn-ghost:hover{ background:var(--bone); border-color:var(--bone); color:var(--ink); }

.nav-toggle{
  display:none; background:none; border:none; color:var(--bone);
  width:32px; height:22px; position:relative;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after{
  content:""; position:absolute; left:0; right:0; height:2px; background:var(--bone);
}
.nav-toggle span{ top:10px; }
.nav-toggle span::before{ top:-8px; }
.nav-toggle span::after{ top:8px; }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  padding:110px 0 70px;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-grid{
  display:grid; grid-template-columns:1.3fr .7fr; gap:60px; align-items:end;
}
.hero h1{
  font-size:clamp(42px,6vw,78px);
  letter-spacing:-.01em;
  margin:18px 0 26px;
}
.hero .lede{
  font-size:18px; color:var(--bone-dim); max-width:44ch; margin-bottom:36px;
}
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-side{
  border-left:1px solid var(--line); padding-left:32px;
}
.hero-side p{ color:var(--bone-dim); font-size:15px; margin-bottom:18px; }
.hero-side .file-no{
  font-family:var(--mono); font-size:12px; color:var(--clay-soft);
  letter-spacing:.1em; margin-bottom:8px; display:block;
}

/* marquee */
.marquee-band{
  background:var(--lime); color:var(--ink); overflow:hidden;
  border-bottom:1px solid var(--line-dark);
}
.marquee{
  display:flex; white-space:nowrap;
  animation:marquee 32s linear infinite;
}
.marquee span{
  font-family:var(--mono); font-size:13px; letter-spacing:.14em;
  text-transform:uppercase; padding:12px 26px;
  border-right:1px solid rgba(23,27,18,0.25);
}
@keyframes marquee{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@media (prefers-reduced-motion: reduce){ .marquee{ animation:none; } }

/* ==========================================================================
   Sections generic
   ========================================================================== */
section{ padding:96px 0; }
.section-alt{ background:var(--ink-soft); }
.section-bone{ background:var(--bone); color:var(--ink); }
.section-forest{ background:var(--forest); }
.section-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:40px; margin-bottom:56px; flex-wrap:wrap;
}
.section-head h2{ font-size:clamp(30px,4vw,46px); margin-top:14px; max-width:16ch; }
.section-head .desc{ max-width:38ch; color:var(--bone-dim); font-size:15px; }
.section-bone .section-head .desc{ color:#4A4A3E; }
.section-bone .eyebrow{ color:var(--clay); }
.section-bone .eyebrow::before{ background:var(--clay); }

/* stats */
.stats{
  display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line);
}
.stat{ padding:34px 28px; border-right:1px solid var(--line); }
.stat:last-child{ border-right:none; }
.stat .num{ font-family:var(--display); font-size:44px; color:var(--lime); }
.stat .lab{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--bone-dim); margin-top:8px; }

/* service cards */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.card{
  background:var(--ink); padding:38px 32px; position:relative;
  transition:background .25s ease;
}
.card:hover{ background:var(--ink-soft); }
.card .idx{ font-family:var(--mono); font-size:12px; color:var(--clay-soft); letter-spacing:.1em; }
.card h3{ font-size:24px; margin:20px 0 14px; }
.card p{ color:var(--bone-dim); font-size:14.5px; margin-bottom:20px; }
.card .go{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--lime); text-transform:uppercase; }
.section-bone .card{ background:var(--bone); }
.section-bone .card:hover{ background:#E4DEC8; }
.section-bone .card p{ color:#565646; }
.section-bone .card h3{ color:var(--ink); }

/* portfolio */
.case-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.case-card{ background:var(--ink); padding:40px; }
.case-top{ display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:26px; }
.case-tag{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--clay-soft); border:1px solid var(--clay-soft); padding:4px 10px; }
.case-no{ font-family:var(--mono); font-size:12px; color:var(--bone-dim); }
.case-card h3{ font-size:26px; margin-bottom:10px; }
.case-card p{ color:var(--bone-dim); font-size:14.5px; margin-bottom:18px; }
.case-meta{ display:flex; gap:22px; font-family:var(--mono); font-size:11px; color:var(--bone-dim); text-transform:uppercase; letter-spacing:.06em; }
.case-meta b{ color:var(--lime); display:block; font-family:var(--body); font-size:14px; font-weight:600; }

/* testimonial / story */
.story{ display:grid; grid-template-columns:.85fr 1.15fr; gap:70px; align-items:center; }
.story blockquote{ font-family:var(--display); font-style:italic; font-size:26px; line-height:1.4; margin:0 0 24px; }
.story cite{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; font-style:normal; color:var(--clay-soft); }
.signature-block{
  border:1px solid var(--line); padding:36px; font-family:var(--mono); font-size:13px; color:var(--bone-dim);
}
.signature-block .num{ font-size:80px; font-family:var(--display); color:var(--lime); font-style:italic; line-height:1; margin-bottom:12px; }

/* CTA band */
.cta-band{
  background:var(--lime); color:var(--ink);
  padding:80px 0;
  text-align:center;
}
.cta-band h2{ font-size:clamp(30px,5vw,52px); margin-bottom:24px; }
.cta-band .btn{ border-color:var(--ink); }
.cta-band .btn:hover{ background:var(--ink); color:var(--lime); }

/* form */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:22px; }
.field.full{ grid-column:1/-1; }
.field label{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--bone-dim); }
.field input, .field select, .field textarea{
  background:transparent; border:none; border-bottom:1px solid var(--line);
  padding:10px 2px; color:var(--bone); font-family:var(--body); font-size:15px;
}
.section-bone .field input, .section-bone .field select, .section-bone .field textarea{
  color:var(--ink); border-bottom:1px solid rgba(23,27,18,0.25);
}
.field input:focus, .field select:focus, .field textarea:focus{ border-bottom-color:var(--lime); }
.field textarea{ resize:vertical; min-height:110px; }
.form-note{ font-size:12px; color:var(--bone-dim); margin-top:10px; }
.form-status{ font-family:var(--mono); font-size:13px; margin-top:16px; display:none; }
.form-status.show{ display:block; }

/* contact info list */
.info-list{ display:flex; flex-direction:column; gap:26px; }
.info-list .row{ border-top:1px solid var(--line); padding-top:18px; }
.info-list .k{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--clay-soft); margin-bottom:8px; display:block; }
.info-list .v{ font-size:18px; }

/* process list */
.process{ counter-reset:step; }
.p-step{ display:grid; grid-template-columns:90px 1fr; gap:26px; padding:30px 0; border-top:1px solid var(--line); }
.p-step:last-child{ border-bottom:1px solid var(--line); }
.p-step .p-num{ font-family:var(--display); font-style:italic; font-size:36px; color:var(--clay-soft); }
.p-step h4{ font-size:20px; margin-bottom:8px; }
.p-step p{ color:var(--bone-dim); font-size:14.5px; max-width:60ch; }

/* team / value list */
.value-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:40px; }
.value-list .v-item{ border-left:2px solid var(--lime); padding-left:20px; }
.value-list h4{ font-size:19px; margin-bottom:8px; }
.value-list p{ color:var(--bone-dim); font-size:14.5px; }

/* footer */
.site-footer{ background:var(--ink-soft); border-top:1px solid var(--line); padding:70px 0 26px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:60px; }
.foot-grid h5{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--clay-soft); margin-bottom:18px; }
.foot-grid li{ margin-bottom:10px; font-size:14px; color:var(--bone-dim); }
.foot-grid a:hover{ color:var(--lime); }
.foot-bottom{
  border-top:1px solid var(--line); padding-top:22px;
  display:flex; justify-content:space-between; font-family:var(--mono); font-size:12px; color:var(--bone-dim);
  flex-wrap:wrap; gap:10px;
}

/* page header (inner pages) */
.page-head{ padding:150px 0 70px; border-bottom:1px solid var(--line); }
.page-head h1{ font-size:clamp(38px,5.5vw,64px); margin-top:16px; }
.page-head .lede{ max-width:60ch; color:var(--bone-dim); font-size:17px; margin-top:20px; }
.breadcrumb{ font-family:var(--mono); font-size:12px; color:var(--bone-dim); text-transform:uppercase; letter-spacing:.06em; margin-bottom:10px; }
.breadcrumb a:hover{ color:var(--lime); }

/* service detail page */
.service-hero{ display:grid; grid-template-columns:1fr 1fr; gap:60px; }
.service-list{ margin-top:20px; }
.service-list li{ padding:14px 0; border-top:1px solid var(--line); font-size:15px; display:flex; gap:14px; }
.service-list li:last-child{ border-bottom:1px solid var(--line); }
.service-list li::before{ content:"—"; color:var(--lime); }

/* responsive */
@media (max-width:980px){
  .hero-grid, .story, .service-hero{ grid-template-columns:1fr; }
  .hero-side{ border-left:none; border-top:1px solid var(--line); padding-left:0; padding-top:26px; }
  .grid-3{ grid-template-columns:1fr 1fr; }
  .grid-2, .case-grid, .value-list, .form-grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .stat:nth-child(2){ border-right:none; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:720px){
  .main-nav{
    position:fixed; inset:76px 0 0 0; background:var(--ink);
    flex-direction:column; align-items:flex-start; padding:30px 28px;
    gap:6px; transform:translateX(100%); transition:transform .25s ease;
    overflow-y:auto;
  }
  .main-nav.open{ transform:translateX(0); }
  .main-nav a{ padding:14px 0; width:100%; border-bottom:1px solid var(--line); font-size:16px; }
  .has-sub .sub-nav{
    position:static; opacity:1; visibility:visible; transform:none;
    display:none; border:none; background:none; margin-top:0; padding:0 0 0 14px;
  }
  .has-sub.open .sub-nav{ display:block; }
  .nav-toggle{ display:block; }
  .grid-3{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .foot-grid{ grid-template-columns:1fr; gap:30px; }
  .p-step{ grid-template-columns:1fr; gap:8px; }
}
