/* ============================================================
   MICHEL — Service & Contact page styles (shared)
   loaded after styles.css
   ============================================================ */

/* ---------- page hero ---------- */
.phero{ padding-top:clamp(150px,18vh,210px); padding-bottom:clamp(40px,6vw,70px); position:relative; overflow:hidden; }
.phero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.phero-bg .blob{ position:absolute; border-radius:50%; filter:blur(90px); }
.phero-bg .b1{ width:42vw; height:42vw; background:var(--red); top:-14vw; right:-10vw; opacity:.28; }
.phero-bg .b2{ width:26vw; height:26vw; background:var(--gold); bottom:-12vw; left:-8vw; opacity:.12; }
.phero .wrap{ position:relative; z-index:2; }
.phero h1{ font-size:clamp(44px,9.5vw,146px); margin:0 0 clamp(30px,4vw,52px); }
.phero-title{ display:flex; flex-direction:column; gap:.04em; }
.phero-title .main{ display:block; }
.phero-title .sub2{ display:block; font-size:.6em; line-height:.9; }
.phero-crumb{ display:flex; align-items:center; gap:10px; color:var(--muted-2); font-size:13px;
  letter-spacing:.16em; text-transform:uppercase; font-weight:600; margin-bottom:30px; }
.phero-crumb a:hover{ color:var(--red); }
.phero-crumb .sep{ opacity:.5; }
.phero-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:50px; align-items:end; }
.phero h1{ margin:0 0 clamp(30px,4vw,52px); }
.phero-lead{ color:var(--muted); font-size:clamp(17px,1.5vw,21px); max-width:46ch; }
.phero-lead strong{ color:var(--cream); font-weight:600; }
.phero-meta{ display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.phero-foot{ display:flex; align-items:center; gap:20px; flex-wrap:wrap; margin-top:42px; }
.phero-price{ font-family:var(--display); font-size:clamp(30px,3.4vw,50px); color:var(--gold); line-height:.9; }
.phero-price small{ display:block; font-family:var(--sans); font-weight:600; font-size:12px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); margin-bottom:4px; }
@media(max-width:860px){ .phero-grid{ grid-template-columns:1fr; gap:26px; } }

/* full-bleed thin marquee under hero */
.subband{ border-block:1px solid var(--line); padding-block:16px; background:var(--ink-2); overflow:hidden; }
.subband .marquee__item{ font-size:clamp(15px,1.6vw,19px); font-family:var(--sans); font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.subband .marquee__item.r{ color:var(--red); }

/* ---------- problem / value section ---------- */
.value{ padding-block:clamp(80px,12vw,150px); }
.value-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.value-q{ font-family:var(--display); text-transform:uppercase; line-height:.92;
  font-size:clamp(30px,4.6vw,68px); }
.value-body p{ color:var(--muted); font-size:clamp(16px,1.4vw,19px); margin-bottom:20px; }
.value-body p strong{ color:var(--cream); }
.value-checks{ display:flex; flex-direction:column; gap:14px; margin-top:30px; }
.value-check{ display:flex; gap:14px; align-items:flex-start; font-size:16px; }
.value-check .ic{ flex:none; width:26px; height:26px; border-radius:50%; background:var(--red); color:#fff;
  display:grid; place-items:center; font-size:14px; margin-top:1px; }
@media(max-width:860px){ .value-grid{ grid-template-columns:1fr; gap:34px; } }

/* ---------- deliverables grid ---------- */
.deliv{ padding-block:clamp(70px,10vw,130px); border-top:1px solid var(--line); }
.deliv-head{ margin-bottom:54px; }
.deliv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:20px; overflow:hidden; }
.dcard{ background:var(--ink); padding:38px 34px; min-height:230px; display:flex; flex-direction:column;
  transition:background .4s var(--ease); position:relative; }
.dcard:hover{ background:var(--ink-3); }
.dcard .dn{ font-family:var(--display); font-size:30px; color:var(--red); line-height:1; }
.dcard h4{ font-size:21px; font-weight:700; margin:auto 0 10px; }
.dcard p{ color:var(--muted); font-size:15px; }
@media(max-width:880px){ .deliv-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .deliv-grid{ grid-template-columns:1fr; } }

/* ---------- pricing ---------- */
.pricing{ padding-block:clamp(80px,12vw,150px); }
.pricing-head{ text-align:center; max-width:640px; margin:0 auto 60px; }
.pricing-head p{ color:var(--muted); margin-top:18px; font-size:18px; }
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.tier{ border:1px solid var(--line); border-radius:20px; padding:38px 32px; display:flex; flex-direction:column;
  background:var(--ink-2); transition:transform .5s var(--ease), border-color .4s; position:relative; }
.tier:hover{ transform:translateY(-8px); border-color:rgba(243,235,221,.3); }
.tier.feat{ background:var(--red); border-color:var(--red); }
.tier.feat *{ color:#fff; }
.tier-badge{ position:absolute; top:-12px; left:32px; background:var(--gold); color:var(--ink);
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:6px 14px; border-radius:999px; }
.tier h3{ font-family:var(--display); text-transform:uppercase; font-size:30px; line-height:1; }
.tier .ptag{ font-size:14px; color:var(--muted); margin-top:8px; min-height:40px; }
.tier.feat .ptag{ color:rgba(255,255,255,.8); }
.tier-price{ font-family:var(--display); font-size:clamp(40px,4.5vw,60px); line-height:1; margin:22px 0 6px; }
.tier-price small{ font-family:var(--sans); font-size:14px; font-weight:600; color:var(--muted); letter-spacing:.04em; }
.tier.feat .tier-price small{ color:rgba(255,255,255,.8); }
.tier ul{ list-style:none; display:flex; flex-direction:column; gap:13px; margin:26px 0 30px; }
.tier li{ display:flex; gap:11px; font-size:15px; color:var(--muted); align-items:flex-start; }
.tier.feat li{ color:rgba(255,255,255,.92); }
.tier li::before{ content:"✓"; color:var(--red); font-weight:700; flex:none; }
.tier.feat li::before{ color:#fff; }
.tier .btn{ margin-top:auto; justify-content:center; }
.tier.feat .btn{ background:#fff; color:var(--red); }
.tier.feat .btn:hover{ background:var(--ink); color:#fff; }
@media(max-width:880px){ .tiers{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } }
.pricing-note{ text-align:center; margin-top:34px; color:var(--muted-2); font-size:14.5px; }

/* ---------- FAQ ---------- */
.faq{ padding-block:clamp(70px,10vw,130px); border-top:1px solid var(--line); }
.faq-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:50px; align-items:start; }
.acc{ border-top:1px solid var(--line); }
.acc-item{ border-bottom:1px solid var(--line); }
.acc-q{ width:100%; background:none; border:none; color:var(--cream); text-align:left;
  font-family:var(--sans); font-size:clamp(17px,1.6vw,21px); font-weight:600; padding:26px 50px 26px 0;
  position:relative; display:flex; }
.acc-q::after{ content:"+"; position:absolute; right:6px; top:50%; transform:translateY(-50%);
  font-size:28px; font-weight:300; color:var(--red); transition:transform .35s var(--ease); }
.acc-item.open .acc-q::after{ transform:translateY(-50%) rotate(45deg); }
.acc-a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.acc-item.open .acc-a{ max-height:340px; }
.acc-a p{ color:var(--muted); font-size:16px; padding-bottom:26px; max-width:60ch; }
html.no-anim .acc-a{ transition:none; }
@media(max-width:860px){ .faq-grid{ grid-template-columns:1fr; gap:24px; } }

/* ---------- big CTA strip ---------- */
.ctastrip{ padding-block:clamp(80px,13vw,170px); text-align:center; position:relative; overflow:hidden; }
.ctastrip.cream{ background:var(--paper); color:var(--ink); }
.ctastrip h2{ margin:0 auto; max-width:16ch; }
.ctastrip .sub{ margin:30px auto 38px; max-width:44ch; font-size:clamp(17px,1.5vw,20px); }
.ctastrip.cream .sub{ color:rgba(12,10,9,.6); }
.ctastrip:not(.cream) .sub{ color:var(--muted); }

/* ---------- related work strip ---------- */
.relwork{ padding-block:clamp(70px,10vw,130px); border-top:1px solid var(--line); }
.relwork-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:50px; }
.rwcard{ border-radius:16px; overflow:hidden; position:relative; aspect-ratio:4/3.3; background:var(--ink-3);
  display:flex; align-items:flex-end; }
.rwcard-img{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .8s var(--ease); }
.rwcard:hover .rwcard-img{ transform:scale(1.06); }
.rwcard::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(8,7,6,.85),rgba(8,7,6,0) 55%); }
.rwcard-body{ position:relative; z-index:2; padding:24px; }
.rwcard-body .n{ font-family:var(--display); text-transform:uppercase; font-size:26px; line-height:.9; }
.rwcard-body .t{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); font-weight:600; margin-top:6px; }
@media(max-width:760px){ .relwork-grid{ grid-template-columns:1fr; } }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ padding-top:clamp(150px,18vh,210px); padding-bottom:clamp(70px,10vw,120px); position:relative; overflow:hidden; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:start; }
.contact-left h1{ margin:0 0 26px; }
.contact-left h1{ font-size:clamp(38px,7.5vw,104px); margin:0 0 26px; }
.contact-left .lead{ color:var(--muted); font-size:clamp(17px,1.5vw,20px); max-width:40ch; margin-bottom:40px; }
.contact-left .lead strong{ color:var(--cream); }
.cinfo{ display:flex; flex-direction:column; gap:2px; margin-top:40px; border-top:1px solid var(--line); }
.cinfo a, .cinfo div{ display:flex; align-items:center; gap:18px; padding:20px 0; border-bottom:1px solid var(--line);
  transition:padding .4s var(--ease); }
.cinfo a:hover{ padding-left:10px; }
.cinfo .ic{ width:44px; height:44px; border-radius:50%; border:1px solid var(--line); flex:none;
  display:grid; place-items:center; font-size:18px; color:var(--red); }
.cinfo .lab{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); font-weight:600; }
.cinfo .val{ font-size:17px; font-weight:500; }
.cwhy{ display:flex; flex-direction:column; gap:14px; margin-top:36px; }
.cwhy-item{ display:flex; gap:12px; align-items:flex-start; font-size:15.5px; color:var(--muted); }
.cwhy-item .ic{ color:var(--red); flex:none; font-weight:700; }

/* form */
.cform{ background:var(--ink-2); border:1px solid var(--line); border-radius:24px; padding:clamp(28px,3vw,44px); }
.cform h3{ font-family:var(--display); text-transform:uppercase; font-size:30px; line-height:.95; margin-bottom:8px; }
.cform .fsub{ color:var(--muted); font-size:15px; margin-bottom:28px; }
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--muted); margin-bottom:9px; }
.field input, .field select, .field textarea{
  width:100%; background:var(--ink); border:1px solid var(--line); border-radius:12px;
  padding:15px 16px; color:var(--cream); font-family:var(--sans); font-size:16px; transition:border-color .3s; cursor:none; }
@media(hover:none){ .field input,.field select,.field textarea{ cursor:auto; } }
.field textarea{ min-height:130px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--red); }
.field input::placeholder, .field textarea::placeholder{ color:var(--muted-2); }
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{ display:inline-flex; align-items:center; gap:8px; padding:11px 16px; border:1px solid var(--line);
  border-radius:999px; font-size:14px; font-weight:500; color:var(--muted); cursor:none; transition:.3s; user-select:none; }
@media(hover:none){ .chip{ cursor:pointer; } }
.chip:hover{ border-color:var(--cream); color:var(--cream); }
.chip input{ display:none; }
.chip.on{ background:var(--red); border-color:var(--red); color:#fff; }
.cform .btn{ width:100%; justify-content:center; margin-top:8px; }
.cform .sent-msg{ display:none; text-align:center; padding:30px 0; }
.cform.sent .sent-msg{ display:block; }
.cform.sent .form-inner{ display:none; }
.sent-msg .big{ font-family:var(--display); text-transform:uppercase; font-size:38px; color:var(--red); line-height:.95; margin-bottom:12px; }
.sent-msg p{ color:var(--muted); }
@media(max-width:860px){ .contact-grid{ grid-template-columns:1fr; } .frow{ grid-template-columns:1fr; } }
