/* =========================================================
   AS INSPECTION — Home page specific styles
   Extends styles.css
   ========================================================= */

/* ========== Hero ========== */
.hero{
  position:relative;min-height:100vh;overflow:hidden;
  background:var(--marine);color:var(--white);
  padding-top:calc(var(--header-h) + 56px);
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;
  min-height:calc(100vh - var(--header-h) - 56px);padding-bottom:120px;
}
.hero-copy .eyebrow{color:var(--sky-soft)}
.hero-copy .eyebrow::before{background:var(--sky-soft)}
.hero h1{
  color:var(--white);font-weight:bold;
  font-size:clamp(34px,4.4vw,56px);line-height:1.06;letter-spacing:-.015em;
  margin:18px 0 24px;max-width:18ch;
}
.hero h1 em{
  font-style:normal;color:var(--sky-soft);
  border-bottom:2px solid var(--sky);
  padding-bottom:4px;
}
.hero-sub{font-size:clamp(15px,1.2vw,18px);color:#D8E2EC;max-width:54ch;line-height:1.6;margin:0 0 32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}

.hero-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid rgba(255,255,255,.18);padding-top:28px;max-width:560px;
}
.hero-strip > div{position:relative;padding-right:18px}
.hero-strip > div + div{padding-left:22px;border-left:1px solid rgba(255,255,255,.18)}
.hero-strip .k{font-size:clamp(24px,2.6vw,32px);font-weight:bold;color:var(--white);line-height:1}
.hero-strip .l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--sky-soft);margin-top:8px}

.hero-visual{position:relative;align-self:stretch;display:flex;align-items:center;justify-content:center;padding-right:32px}
.hero-frame{
  position:relative;width:100%;aspect-ratio:4/5;max-width:520px;
  background:#0F2A45;overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.06);
}
.hero-frame img{display:block;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-frame::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,42,69,0) 55%, rgba(15,42,69,.55) 100%);
  pointer-events:none;
}
.hero-frame::after{
  content:"";position:absolute;inset:0;
  border:1px solid rgba(255,255,255,.18);pointer-events:none;
}

/* Live tag — anchored to the bottom-left corner of the frame, slightly overlapping */
.hero-tag{
  position:absolute;left:-12px;bottom:18px;z-index:3;
  background:var(--white);color:var(--marine);
  padding:14px 22px;
  display:flex;align-items:center;gap:14px;
  box-shadow:0 14px 30px -10px rgba(0,0,0,.45);
}
.hero-tag .dot{
  width:10px;height:10px;border-radius:50%;background:#22C55E;
  box-shadow:0 0 0 4px rgba(34,197,94,.18);flex:none;
  animation:pulse 2s infinite var(--ease);
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(34,197,94,.18)}
  50%{box-shadow:0 0 0 8px rgba(34,197,94,.05)}
}
.hero-tag .t{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--silver);font-weight:bold;line-height:1}
.hero-tag .v{font-size:14px;font-weight:bold;color:var(--marine);margin-top:4px;line-height:1.2;white-space:nowrap}

/* Road perspective motif */
.road-motif{
  position:absolute;left:50%;bottom:-2px;transform:translateX(-50%);
  width:140%;height:140px;opacity:.18;pointer-events:none;
  background:
    linear-gradient(to top, var(--marine-deep), transparent),
    repeating-linear-gradient(to top, transparent 0, transparent 18px, rgba(255,255,255,.55) 18px, rgba(255,255,255,.55) 30px);
  clip-path:polygon(40% 100%, 60% 100%, 55% 0, 45% 0);
}

.cred-rail{
  position:absolute;left:var(--gutter);top:70%;transform:translateY(-50%) rotate(-90deg);
  transform-origin:left center;display:flex;gap:28px;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.55);white-space:nowrap;
}
.cred-rail span{display:inline-flex;align-items:center;gap:8px}
.cred-rail span::before{content:"";width:6px;height:6px;background:var(--sky);display:inline-block}

/* ========== About ========== */
.about-grid{
  display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:start;
}
.about-pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:48px}
.pillar{border-top:2px solid var(--marine);padding-top:18px}
.pillar .num{font-size:11px;letter-spacing:.22em;color:var(--silver);font-weight:bold}
.pillar h4{font-size:16px;color:var(--marine);font-weight:bold;margin:8px 0 6px;letter-spacing:.02em}
.pillar p{font-size:14px;color:var(--anthracite);margin:0;line-height:1.55}

/* ========== Services grid ========== */
.services{background:var(--marine);color:var(--white);position:relative;overflow:hidden}
.services::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(800px 400px at 90% -10%, rgba(107,158,192,.22), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(107,158,192,.14), transparent 60%);
}
.services .container{position:relative}
.services .h2{color:var(--white)}
.services .lede{color:#D8E2EC}
.services-head{
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;margin-bottom:64px;
}
.services-head .eyebrow{color:var(--sky-soft)}
.services-head .eyebrow::before{background:var(--sky-soft)}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid rgba(255,255,255,.12);
}
.svc{
  padding:36px 32px 40px;
  border-right:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
  position:relative;color:inherit;
  transition:background .35s var(--ease);
  display:flex;flex-direction:column;
}
.svc:nth-child(3n){border-right:none}
.svc:hover{background:rgba(255,255,255,.04)}
.svc-icon{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--sky);margin-bottom:24px;
}
.svc-icon svg{width:24px;height:24px;stroke:var(--sky);fill:none;stroke-width:1.6}
.svc-num{
  position:absolute;top:36px;right:32px;
  font-size:11px;letter-spacing:.16em;color:rgba(255,255,255,.45);
}
.svc h3{color:var(--white);font-size:18px;margin:0 0 12px;font-weight:bold;letter-spacing:.01em}
.svc p{color:#C8D2DD;font-size:14px;line-height:1.6;margin:0 0 18px;flex:1}
.svc .meta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:.14em;color:var(--sky-soft);text-transform:uppercase;font-weight:bold;
}
.svc .meta::after{content:"→";color:var(--sky);transition:transform .25s var(--ease)}
.svc:hover{color:#fff}
.svc:hover .meta{color:var(--white)}
.svc:hover .meta::after{transform:translateX(4px)}

/* ========== Timeline ========== */
.process{background:var(--paper)}
.process-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
.timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
.timeline::before{
  content:"";position:absolute;left:0;right:0;top:40px;height:1px;background:var(--hairline);
}
.step{padding:0 20px 0 0;position:relative}
.step:last-child{padding-right:0}
.step .ring{
  width:80px;height:80px;border-radius:50%;
  background:var(--white);border:1px solid var(--hairline);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:bold;color:var(--marine);
  position:relative;z-index:1;margin-bottom:22px;
  transition:border-color .3s var(--ease), color .3s var(--ease);
}
.step:hover .ring{border-color:var(--sky);color:var(--sky)}
.step h4{font-size:15px;color:var(--marine);font-weight:bold;margin:0 0 6px;letter-spacing:.02em}
.step p{font-size:13px;color:var(--anthracite);margin:0;line-height:1.5;max-width:25ch}
.step .tag{
  display:inline-block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--sky);font-weight:bold;margin-top:10px;
}

/* ========== KPIs ========== */
.kpis{background:var(--white)}
.kpis-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
}
.kpi{padding:48px 32px;border-right:1px solid var(--hairline);position:relative}
.kpi:last-child{border-right:none}
.kpi .v{
  font-size:clamp(42px,5vw,64px);font-weight:bold;color:var(--marine);line-height:1;
  letter-spacing:-.02em;
}
.kpi .v sup{font-size:.5em;vertical-align:top;color:var(--sky);margin-left:4px;font-weight:bold}
.kpi .l{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--silver);
  font-weight:bold;margin-top:14px;
}

/* ========== Compliance ========== */
.compliance{background:var(--marine);color:var(--white);position:relative;overflow:hidden}
.compliance .container{position:relative;z-index:1}
.compliance::before{
  content:"";position:absolute;right:-100px;top:-100px;width:520px;height:520px;
  border:1px solid rgba(107,158,192,.25);border-radius:50%;
}
.compliance::after{
  content:"";position:absolute;right:-50px;top:-50px;width:420px;height:420px;
  border:1px solid rgba(107,158,192,.18);border-radius:50%;
}
.compliance-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.compliance .h2{color:var(--white)}
.compliance .lede{color:#D8E2EC}
.compliance .eyebrow{color:var(--sky-soft)}
.compliance .eyebrow::before{background:var(--sky-soft)}
.std-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid rgba(255,255,255,.18)}
.std{padding:24px 6px;border-bottom:1px solid rgba(255,255,255,.18);display:flex;align-items:flex-start;gap:18px}
.std .code{font-size:11px;letter-spacing:.16em;color:var(--sky-soft);font-weight:bold;min-width:96px;padding-top:4px}
.std .desc{font-size:14px;color:#E6EDF3;line-height:1.55}
.std .desc strong{color:var(--white);display:block;font-weight:bold;margin-bottom:2px;font-size:15px}

/* ========== Showcase ========== */
.showcase{padding:0;background:var(--white)}
.showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.tile{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--marine);display:block}
.tile img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease);filter:saturate(.95);
}
.tile:hover img{transform:scale(1.04)}
.tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,42,69,0) 40%, rgba(15,42,69,.85) 100%);
  pointer-events:none;
}
.tile .cap{position:absolute;left:32px;right:32px;bottom:28px;z-index:1;color:var(--white)}
.tile .cap .e{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--sky-soft);font-weight:bold}
.tile .cap .t{font-size:20px;font-weight:bold;margin-top:8px;letter-spacing:.01em}
.tile .cap::before{content:"";display:block;width:32px;height:2px;background:var(--sky);margin-bottom:14px}

/* ========== Agencies ========== */
.agencies{background:var(--paper);padding:clamp(72px,9vw,128px) 0}
.agencies-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.agencies-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.agency-card{
  background:#fff;padding:40px;border:1px solid var(--hairline);
  position:relative;transition:border-color .35s var(--ease), transform .35s var(--ease);
}
.agency-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--marine);transition:background .3s var(--ease)}
.agency-card:hover{border-color:var(--sky);transform:translateY(-2px)}
.agency-card:hover::before{background:var(--sky)}
.agency-card .city{
  font-size:11px;letter-spacing:.22em;color:var(--sky);font-weight:bold;text-transform:uppercase;
}
.agency-card h3{font-size:24px;margin:6px 0 18px;letter-spacing:.01em}
.agency-card .info{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:13px}
.agency-card .info dt{color:var(--silver);font-weight:bold;text-transform:uppercase;font-size:10px;letter-spacing:.18em;padding-top:3px}
.agency-card .info dd{margin:0;color:var(--anthracite);line-height:1.55}
.agency-card .agency-cta{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}

/* ========== Booking ========== */
.book{background:var(--paper-deep)}
.book-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start}
.book-side .lede{margin-top:0}
.book-list{margin:32px 0 0;padding:0;list-style:none}
.book-list li{
  display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--hairline);align-items:flex-start;
}
.book-list li:last-child{border-bottom:none}
.book-list .ix{font-size:12px;letter-spacing:.14em;color:var(--sky);font-weight:bold;min-width:36px;padding-top:3px}
.book-list .tx strong{display:block;color:var(--marine);font-size:15px;margin-bottom:3px}
.book-list .tx span{font-size:13px;color:var(--anthracite);line-height:1.5}

.book-side .wa-cta-box{
  margin-top:32px;background:#fff;border:1px solid var(--hairline);padding:24px;
  display:flex;align-items:center;gap:18px;
}
.book-side .wa-cta-box .wa-icon-bg{
  width:48px;height:48px;background:var(--whatsapp);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex:none;
}
.book-side .wa-cta-box svg{width:24px;height:24px;fill:#fff}
.book-side .wa-cta-box .wa-txt{flex:1}
.book-side .wa-cta-box strong{display:block;color:var(--marine);font-size:14px;margin-bottom:3px}
.book-side .wa-cta-box span{font-size:12px;color:var(--silver);letter-spacing:.04em}

.form-card{
  background:var(--white);padding:40px;border:1px solid var(--hairline);position:relative;
}
.form-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--marine)}
.form-card::after{content:"";position:absolute;left:0;top:4px;width:80px;height:2px;background:var(--sky)}
.form-card h3{font-size:22px;margin-bottom:6px}
.form-card p.sub{font-size:13px;color:var(--silver);margin:0 0 28px}

/* FIX: properly aligned form grid */
.fields{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:24px 20px;
}
.field{
  display:flex;flex-direction:column;gap:8px;min-width:0;
}
.field.full{grid-column:1 / -1}
.field label{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver);font-weight:bold;
  display:flex;align-items:center;gap:4px;
}
.field label .req{color:var(--sky)}
.field input, .field select, .field textarea{
  font-family:var(--font-brand);font-size:14px;color:var(--anthracite);
  border:none;border-bottom:1.5px solid var(--hairline);
  background:transparent;padding:8px 0;outline:none;width:100%;
  transition:border-color .25s var(--ease);
  -webkit-appearance:none;appearance:none;
  border-radius:0;
}
.field select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%23173B5D' stroke-width='1.5'/></svg>");
  background-repeat:no-repeat;background-position:right 4px center;padding-right:24px;
  cursor:pointer;
}
.field input:focus, .field select:focus, .field textarea:focus{border-bottom-color:var(--marine)}
.field input:invalid:not(:placeholder-shown){border-bottom-color:#C0392B}
.field textarea{resize:vertical;min-height:64px}
.form-submit{margin-top:32px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.form-submit .note{font-size:11px;color:var(--silver);letter-spacing:.04em;max-width:32ch;line-height:1.4}

/* ========== Responsive ========== */
@media (max-width: 1024px){
  .hero-grid{grid-template-columns:1fr;gap:48px;padding-top:24px;padding-bottom:80px}
  .hero-visual{order:-1;max-width:420px;padding-right:0}
  .hero-tag{transform:translateX(0)}
  .about-grid, .services-head, .process-head, .compliance-grid, .agencies-head, .book-grid{grid-template-columns:1fr;gap:40px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .svc:nth-child(3n){border-right:1px solid rgba(255,255,255,.12)}
  .svc:nth-child(2n){border-right:none}
  .timeline{grid-template-columns:repeat(3,1fr);row-gap:48px}
  .timeline::before{display:none}
  .kpis-grid{grid-template-columns:repeat(2,1fr)}
  .kpi:nth-child(2n){border-right:none}
  .kpi:nth-child(-n+2){border-bottom:1px solid var(--hairline)}
  .agencies-grid{grid-template-columns:1fr}
  .cred-rail{display:none}
}
@media (max-width: 720px){
  .services-grid{grid-template-columns:1fr}
  .svc, .svc:nth-child(n){border-right:none}
  .showcase-grid{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr 1fr}
  .kpis-grid{grid-template-columns:1fr 1fr}
  .fields{grid-template-columns:1fr}
  .field.full{grid-column:1 / -1}
  .form-card{padding:28px 22px}
  .hero-strip{grid-template-columns:1fr 1fr;max-width:none}
  .hero-strip > div:nth-child(3){grid-column:span 2;padding-left:0;border-left:none;border-top:1px solid rgba(255,255,255,.18);padding-top:18px;margin-top:6px}
  .hero-tag{position:relative;left:auto;bottom:auto;margin-top:16px}
  .agency-card{padding:28px}
}
