:root{
  --pa-font:"Inter", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --pa-bg:#f1f5f9;
  --pa-surface:#ffffff;
  --pa-surface-soft:#f8fafc;
  --pa-text:#0f172a;
  --pa-muted:#64748b;
  --pa-faint:#94a3b8;
  --pa-border:#cbd5e1;
  --pa-border-soft:#e2e8f0;
  --pa-primary:#0f172a;
  --pa-primary-hover:#1e293b;
  --pa-primary-soft:#e2e8f0;
  --pa-success:#0f766e;
  --pa-success-soft:#ecfdf5;
  --pa-warning:#b45309;
  --pa-warning-soft:#fffbeb;
  --pa-danger:#b91c1c;
  --pa-danger-soft:#fef2f2;
  --pa-info:#1d4ed8;
  --pa-info-soft:#eff6ff;
  --pa-radius-sm:10px;
  --pa-radius-md:14px;
  --pa-radius-lg:18px;
  --pa-radius-xl:24px;
  --pa-shadow-soft:0 12px 30px rgba(15, 23, 42, 0.06);
  --pa-shadow-modal:0 24px 80px rgba(15, 23, 42, 0.18);
  --font-sans:var(--pa-font);
  --color-bg:var(--pa-bg);
  --color-surface:var(--pa-surface);
  --color-text:var(--pa-text);
  --color-muted:var(--pa-muted);
  --color-border:var(--pa-border-soft);
  --color-primary:var(--pa-primary);
  --radius-card:var(--pa-radius-lg);
  --radius-input:var(--pa-radius-md);
  --shadow-soft:var(--pa-shadow-soft);
  --bg:var(--pa-surface);
  --bg-soft:var(--pa-surface-soft);
  --text:var(--pa-text);
  --muted:var(--pa-muted);
  --navy:var(--pa-primary);
  --navy-2:var(--pa-primary-hover);
  --accent:#d8c3a5;
  --card:var(--pa-surface);
  --border:var(--pa-border);
  --border-soft:var(--pa-border-soft);
  --radius:var(--pa-radius-lg);
  --radius-sm:var(--pa-radius-md);
  --ring:0 0 0 4px rgba(15, 118, 110, .16);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-sans);
  line-height:1.45;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--border-soft);text-align:left;vertical-align:top;font-size:13px}
.table th{font-size:11px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted);font-weight:750;background:var(--bg)}
.table tr:last-child td{border-bottom:0}
.table strong{color:var(--navy)}

.container{max-width:1120px;margin:0 auto;padding:0 20px}

.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--border-soft);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo-only{gap:0;flex:0 0 auto}
.logo{
  width:38px;height:38px;border-radius:12px;
  background:radial-gradient(120% 120% at 30% 20%,#ffffff 0%,#f7f0e6 28%,#d8c3a5 60%,#b79c74 100%);
  border:1px solid rgba(183,156,116,.22);
}
.logo-image{
  object-fit:contain;
  background:#fff;
  padding:4px;
}
.public-logo{
  display:block;
  width:auto;
  height:48px;
  max-width:min(240px, 42vw);
  object-fit:contain;
}
.top-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.top-actions .btn{white-space:nowrap}
.top-actions .btn-icon{gap:9px}
.top-actions .btn-icon-mark{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 18px;
  line-height:0;
}
.top-actions .btn-icon-mark svg{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  display:block;
}
.top-actions .btn-label-short{display:none}

.pa-icon{
  width:var(--pa-icon-size, 18px);
  height:var(--pa-icon-size, 18px);
  display:block;
  flex-shrink:0;
  color:inherit;
}

.btn{
  appearance:none;border:1px solid transparent;
  border-radius:999px;
  padding:10px 14px;
  font-weight:600;
  font-size:13px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;
  transition:transform .12s ease, background .12s ease, border-color .12s ease, color .12s ease;
  user-select:none;
}
.public-btn,
.icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-2)}
.btn-green{background:#25D366;color:#fff}
.btn-green:hover{background:#1fb85a}
.btn-outline{background:#fff;border-color:var(--border-soft);color:var(--navy)}
.btn-outline:hover{border-color:var(--border)}
.btn-soft{background:rgba(216,195,165,.18);border-color:rgba(216,195,165,.35);color:var(--navy)}
.btn-soft:hover{background:rgba(216,195,165,.25)}
.btn-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:0;
}
.btn-icon .pa-icon{display:block}

.btn-block{width:100%}
.btn-lg{padding:12px 16px;font-size:14px}

.section{padding:34px 0}
.section-head{margin-bottom:16px}
.kicker{display:inline-flex;align-items:center;gap:10px;padding:7px 10px;border-radius:999px;background:rgba(216,195,165,.16);border:1px solid rgba(216,195,165,.30);color:var(--navy);font-weight:750;font-size:11px;letter-spacing:.10em;text-transform:uppercase}
h1{font-size:34px;line-height:1.05;margin:14px 0 10px;letter-spacing:-.02em;color:var(--navy)}
h2{font-size:22px;line-height:1.18;margin:0 0 10px;color:var(--navy);letter-spacing:-.01em}
p{margin:0 0 12px;color:var(--muted)}

.hero-slider{
  position:relative;
  width:100%;
  overflow:hidden;
  background:#0b1b2b;
}
.hero-track{
  display:flex;
  overflow:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
}
.hero-track::-webkit-scrollbar{display:none}
.hero-slide{
  position:relative;
  min-width:100%;
  height:520px;
  scroll-snap-align:start;
  display:flex;
  align-items:center;
  --hero-bg-current: var(--hero-bg-desktop, var(--hero-bg, none));
  background-color:#0b1b2b;
  background-image:var(--hero-bg-current);
  background-size:cover;
  background-position:center;
}
.hero-slide::before{
  content:none;
}
.hero-inner{position:relative;z-index:1}
.hero-inner{width:100%;padding:42px 20px;display:flex;justify-content:center}
.hero-copy{max-width:720px;text-align:center;margin:0 auto}
.hero-kicker{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.28);
  color:rgba(255,255,255,.82);
  font-weight:800;
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.hero-title{
  margin-top:14px;
  font-size:30px;
  line-height:1.06;
  letter-spacing:-.02em;
  font-weight:850;
  color:#fff;
}
.hero-subtitle{
  margin-top:10px;
  font-size:16px;
  line-height:1.5;
  color:rgba(255,255,255,.82);
  max-width:56ch;
  margin-left:auto;
  margin-right:auto;
}
.hero-actions{margin-top:16px;display:flex;justify-content:center}
.hero-actions .btn-lg{font-size:18px}
.hero-dots{
  position:absolute;
  left:0;
  right:0;
  bottom:16px;
  display:flex;
  gap:8px;
  justify-content:center;
  pointer-events:none;
}
.hero-dot{
  pointer-events:auto;
  width:8px;
  height:8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.22);
  padding:0;
  cursor:pointer;
  appearance:none;
}
.hero-dot.is-active{background:rgba(255,255,255,.78);border-color:rgba(255,255,255,.35)}
.hero-dot:focus{outline:none;box-shadow:0 0 0 4px rgba(216,195,165,.28)}

@media (min-width: 970px){
  .hero-slide{height:1790px}
  .hero-inner{padding:56px 20px}
  .hero-title{font-size:56px}
}

@media (min-width: 1024px){
  .hero-slide{height:1790px}
  .hero-title{font-size:56px}
}

@media (max-width: 767px){
  .hero-slide{height:690px;--hero-bg-current: var(--hero-bg-mobile, var(--hero-bg-desktop, var(--hero-bg, none)))}
  .hero-inner{padding:36px 18px}
  .hero-title{font-size:30px}
  .topbar-inner{align-items:center;flex-wrap:nowrap}
  .brand{flex:1 1 auto;min-width:0}
  .top-actions{flex:0 0 auto;justify-content:flex-end;gap:8px}
  .top-actions .btn{padding:9px 12px;font-size:12px}
  .public-logo{height:40px;max-width:min(200px, 46vw)}
}

@media (max-width: 480px){
  .logo{width:34px;height:34px;border-radius:10px}
  .public-logo{height:36px;max-width:min(168px, 44vw)}
  .top-actions .btn{padding:9px 10px;min-width:0;gap:7px}
  .top-actions .btn-label{display:none}
  .top-actions .btn-label-short{display:inline}
  .top-actions .btn-icon-mark{width:16px;height:16px;flex-basis:16px}
  .top-actions .btn-icon-mark svg{width:16px;height:16px}
}

.hero-align-left .hero-inner{justify-content:flex-start}
.hero-align-right .hero-inner{justify-content:flex-end}
.hero-align-left .hero-copy{text-align:left;margin-left:0;margin-right:auto}
.hero-align-right .hero-copy{text-align:right;margin-right:0;margin-left:auto}
.hero-align-left .hero-subtitle{margin-left:0;margin-right:auto}
.hero-align-right .hero-subtitle{margin-right:0;margin-left:auto}
.hero-align-left .hero-actions{justify-content:flex-start}
.hero-align-right .hero-actions{justify-content:flex-end}

.hero-v-top{align-items:flex-start}
.hero-v-middle{align-items:center}
.hero-v-lower{align-items:flex-end}
.hero-v-bottom{align-items:flex-end}
.hero-v-lower .hero-inner{padding-top:28px;padding-bottom:120px}
.hero-v-bottom .hero-inner{padding-top:28px;padding-bottom:92px}

@media (max-width: 767px){
  .hero-v-lower{align-items:flex-end}
  .hero-v-lower .hero-inner{padding-top:24px;padding-bottom:120px}
  .hero-v-bottom .hero-inner{padding-top:24px;padding-bottom:84px}
}

.hero-text-dark .hero-kicker{
  border-color:rgba(11,27,43,.14);
  background:rgba(255,255,255,.72);
  color:rgba(11,27,43,.78);
}
.hero-text-dark .hero-title{color:var(--navy)}
.hero-text-dark .hero-subtitle{color:rgba(11,27,43,.76)}
.hero-text-dark .hero-dot{border-color:rgba(11,27,43,.18);background:rgba(255,255,255,.55)}
.hero-text-dark .hero-dot.is-active{background:rgba(255,255,255,.92);border-color:rgba(11,27,43,.24)}

.grid{display:grid;gap:14px}
.grid.services{grid-template-columns:1fr}
#services .section-head{margin-bottom:22px}
#services .section-head .kicker{margin-bottom:10px}
.service-actions{justify-content:flex-end;margin-top:18px}
.card{
  background:var(--card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius);
  overflow:hidden;
}
.card-pad{padding:16px}
.service-media{
  height:148px;
  background:
    linear-gradient(90deg, rgba(216,195,165,.22) 0%, rgba(216,195,165,0) 45%),
    linear-gradient(180deg,#ffffff 0%,var(--bg-soft) 100%);
}
.service-media img{width:100%;height:100%;object-fit:cover;display:block}
.service-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.price-pill{
  white-space:nowrap;
  font-weight:750;
  font-size:12px;
  color:var(--navy);
  background:rgba(216,195,165,.16);
  border:1px solid rgba(216,195,165,.30);
  padding:7px 10px;
  border-radius:999px;
}
.service-title h3{margin:0;font-size:16px;letter-spacing:-.01em;color:var(--navy)}
.service-desc{font-size:13px;margin-top:8px}
.card-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}

.split{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.mini-card{
  border-radius:var(--radius);
  border:1px solid var(--border-soft);
  background:var(--card);
  padding:16px;
}
.mini-card h3{margin:0 0 8px;font-size:15px;color:var(--navy)}
.mini-card p{margin:0;color:var(--muted);font-size:13px}

.steps{display:grid;gap:12px}
.step{
  display:flex;gap:12px;align-items:flex-start;
  border-radius:var(--radius);
  border:1px solid var(--border-soft);
  background:var(--card);
  padding:14px;
}
.step-badge{
  width:34px;height:34px;border-radius:12px;
  background:rgba(11,27,43,.06);
  border:1px solid rgba(11,27,43,.08);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:var(--navy);
}
.step strong{display:block;color:var(--navy);font-size:14px}
.step span{display:block;color:var(--muted);font-size:13px;margin-top:4px}

.faq{display:grid;gap:10px}
.faq details{
  border-radius:var(--radius);
  border:1px solid var(--border-soft);
  background:var(--card);
  padding:14px 14px;
}
.faq summary{cursor:pointer;font-weight:800;color:var(--navy)}
.faq p{margin-top:10px}

.before-after-section{
  padding:34px 0 18px;
  background:
    radial-gradient(100% 85% at 10% 10%, rgba(59,130,246,.08) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(248,250,252,.92) 0%, rgba(255,255,255,1) 100%);
}
.before-after-section .container{
  max-width:1240px;
  margin-left:auto;
  margin-right:auto;
  padding-left:clamp(16px, 3vw, 32px);
  padding-right:clamp(16px, 3vw, 32px);
}
.before-after-shell{
  width:100%;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  padding:clamp(28px, 4vw, 52px);
  border-radius:32px;
  border:1px solid rgba(11,27,43,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(247,250,253,.98) 100%);
  overflow:hidden;
}
.before-after-head{display:flex;flex-direction:column;gap:12px}
.before-after-section-head{
  max-width:680px;
  margin:0 auto 34px;
  text-align:center;
}
.before-after-section-head .kicker{
  margin:0 auto;
}
.before-after-section-head h2{
  max-width:620px;
  margin:14px auto 0;
  font-size:clamp(30px, 3.5vw, 46px);
  line-height:1.04;
  letter-spacing:-.04em;
}
.before-after-section-head p{
  max-width:620px;
  margin:16px auto 0;
  font-size:15px;
  line-height:1.7;
  color:var(--muted);
}
.before-after-picker{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.before-after-pill{
  width:34px;
  height:34px;
  border:1px solid rgba(11,27,43,.10);
  background:rgba(255,255,255,.96);
  color:rgba(11,27,43,.72);
  border-radius:999px;
  padding:0;
  font:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.before-after-pill:hover{transform:translateY(-1px);border-color:rgba(59,130,246,.18)}
.before-after-pill.is-active{
  background:linear-gradient(135deg, #0f3f78 0%, #0f79cf 100%);
  border-color:transparent;
  color:#fff;
}
.before-after-stack{
  display:grid;
  gap:20px;
  margin-top:8px;
  width:100%;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  justify-items:stretch;
}
.before-after-card{
  display:block;
  width:100%;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  margin-bottom:0;
}
.ba-stage{
  width:100%;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  border-radius:28px;
  border:1px solid rgba(11,27,43,.08);
  background:#07111d;
  padding:0;
  overflow:hidden;
}
.ba-comparison{
  --ba-position:50%;
  position:relative;
  width:100%;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  display:block;
  height:auto;
  overflow:hidden;
  border-radius:28px;
  background:#000;
  border:0;
  touch-action:none;
  user-select:none;
}
.ba-comparison.ba-full{
  width:100%;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  height:clamp(460px, 56vw, 720px);
  min-height:0;
  aspect-ratio:auto;
}
.ba-image{
  position:absolute;
  inset:0;
  width:100%;
}
.ba-before,
.ba-after{width:100%}
.ba-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.ba-after{
  clip-path:inset(0 calc(100% - var(--ba-position)) 0 0);
}
.ba-comparison.is-auto-moving .ba-after{
  transition:clip-path var(--ba-motion-duration, 2200ms) cubic-bezier(.22, .61, .36, 1);
}
.ba-divider{
  position:absolute;
  top:0;
  bottom:0;
  left:var(--ba-position);
  width:2px;
  transform:translateX(-50%);
  background:rgba(255,255,255,.94);
  box-shadow:0 0 0 1px rgba(11,27,43,.08), 0 0 24px rgba(15,121,207,.28);
  pointer-events:none;
}
.ba-comparison.is-auto-moving .ba-divider{
  transition:left var(--ba-motion-duration, 2200ms) cubic-bezier(.22, .61, .36, 1);
}
.ba-handle{
  position:absolute;
  left:var(--ba-position);
  top:50%;
  transform:translate(-50%, -50%);
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.34);
  background:linear-gradient(135deg, rgba(15,63,120,.96) 0%, rgba(15,121,207,.96) 100%);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 14px 30px rgba(11,27,43,.18), 0 0 24px rgba(59,130,246,.22);
  cursor:ew-resize;
}
.ba-comparison.is-auto-moving .ba-handle{
  transition:left var(--ba-motion-duration, 2200ms) cubic-bezier(.22, .61, .36, 1), transform 180ms ease;
}
.ba-handle svg{
  width:24px;
  height:24px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.ba-handle:focus{
  outline:none;
  box-shadow:0 0 0 4px rgba(191,219,254,.60), 0 14px 30px rgba(11,27,43,.18);
}
.ba-label{
  position:absolute;
  top:16px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(11,27,43,.58);
  color:#fff;
  font-size:11px;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  backdrop-filter:blur(10px);
  z-index:2;
}
.ba-label-before{left:16px}
.ba-label-after{right:16px;background:rgba(15,121,207,.74)}
.ba-comparison.is-dragging .ba-handle{transform:translate(-50%, -50%) scale(1.03)}
.before-after-card .ba-actions{display:none}

.section-premium{padding:52px 0}
.section-head-wide{max-width:720px}
.section-head-wide .kicker{margin-bottom:12px}
.section-head-wide h2{font-size:30px;letter-spacing:-.03em;margin-bottom:12px}
.section-head-wide p{font-size:15px;line-height:1.65;color:var(--muted)}

.section-how{
  background:
    radial-gradient(100% 80% at 10% 10%, rgba(216,195,165,.10) 0%, rgba(216,195,165,0) 55%),
    linear-gradient(180deg, rgba(251,251,251,.96) 0%, rgba(255,255,255,1) 100%);
}
.flow-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:24px}
.flow-card{
  position:relative;
  min-height:100%;
  padding:22px;
  border-radius:24px;
  border:1px solid rgba(11,27,43,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(248,250,252,.96) 100%);
  box-shadow:0 12px 34px rgba(11,27,43,.06);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow:hidden;
}
.flow-card:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(11,27,43,.10);border-color:rgba(11,27,43,.12)}
.flow-card::before{
  content:"";
  position:absolute;
  inset:auto -28px -40px auto;
  width:110px;
  height:110px;
  border-radius:999px;
  opacity:.18;
  filter:blur(8px);
  pointer-events:none;
}
.flow-card-services::before{background:radial-gradient(circle, rgba(59,130,246,.9) 0%, rgba(59,130,246,0) 72%)}
.flow-card-upload::before{background:radial-gradient(circle, rgba(16,185,129,.9) 0%, rgba(16,185,129,0) 72%)}
.flow-card-review::before{background:radial-gradient(circle, rgba(168,85,247,.9) 0%, rgba(168,85,247,0) 72%)}
.flow-card-result::before{background:radial-gradient(circle, rgba(245,158,11,.9) 0%, rgba(245,158,11,0) 72%)}
.flow-number{
  display:inline-flex;
  margin-bottom:14px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(11,27,43,.46);
}
.flow-icon{
  width:64px;height:64px;border-radius:22px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  color:#fff;
  box-shadow:0 16px 28px rgba(11,27,43,.14);
}
.flow-icon::before{
  content:"";
  position:absolute;
  inset:5px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,.03) 100%);
  pointer-events:none;
}
.flow-icon-services{
  background:linear-gradient(135deg, #2563eb 0%, #0f3f9d 100%);
}
.flow-icon-upload{
  background:linear-gradient(135deg, #10b981 0%, #0f766e 100%);
}
.flow-icon-review{
  background:linear-gradient(135deg, #8b5cf6 0%, #5b21b6 100%);
}
.flow-icon-result{
  background:linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}
.flow-icon svg{
  position:relative;
  z-index:1;
  width:28px;height:28px;
  stroke:currentColor;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}
.flow-title-row{margin-top:18px}
.flow-title-row h3{margin:0;font-size:20px;letter-spacing:-.02em;color:var(--navy)}
.flow-card p{margin:10px 0 0;font-size:14px;line-height:1.7;color:var(--muted)}
.flow-connector{
  display:none;
  position:absolute;
  top:50%;
  right:-24px;
  width:32px;
  height:2px;
  background:linear-gradient(90deg, rgba(11,27,43,.18) 0%, rgba(216,195,165,.55) 100%);
}
.flow-connector::after{
  content:"";
  position:absolute;
  right:0;
  top:50%;
  width:8px;height:8px;
  border-top:2px solid rgba(216,195,165,.68);
  border-right:2px solid rgba(216,195,165,.68);
  transform:translateY(-50%) rotate(45deg);
}

.section-faq{padding-top:20px}
.faq-shell{
  border-radius:28px;
  border:1px solid rgba(11,27,43,.08);
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(216,195,165,.10) 0%, rgba(216,195,165,0) 52%),
    linear-gradient(180deg, rgba(251,251,251,.98) 0%, rgba(255,255,255,1) 100%);
  padding:24px;
}
.faq-head{margin-bottom:20px}
.faq-list{display:grid;gap:12px}
.faq-item{
  border-radius:20px;
  border:1px solid rgba(11,27,43,.08);
  background:#fff;
  box-shadow:0 10px 28px rgba(11,27,43,.04);
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.faq-item:hover{border-color:rgba(11,27,43,.12);box-shadow:0 14px 32px rgba(11,27,43,.08)}
.faq-item.is-open{border-color:rgba(17,43,68,.16);box-shadow:0 16px 36px rgba(11,27,43,.10)}
.faq-question{
  width:100%;
  border:0;
  background:transparent;
  padding:18px 18px;
  display:flex;
  align-items:center;
  gap:14px;
  justify-content:space-between;
  cursor:pointer;
  text-align:left;
  color:var(--navy);
  font:inherit;
}
.faq-question-text{
  font-size:16px;
  line-height:1.5;
  font-weight:780;
  letter-spacing:-.01em;
}
.faq-icon{
  width:36px;height:36px;flex:0 0 36px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;
  border:1px solid rgba(11,27,43,.08);
  background:rgba(11,27,43,.03);
  color:var(--navy);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.faq-icon svg{
  width:16px;height:16px;
  stroke:currentColor;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}
.faq-item.is-open .faq-icon{
  transform:rotate(180deg);
  background:rgba(216,195,165,.20);
  border-color:rgba(216,195,165,.34);
}
.faq-answer-wrap{
  overflow:hidden;
  height:auto;
}
.faq-answer{padding:0 18px 18px}
.faq-answer p{
  margin:0;
  font-size:14px;
  line-height:1.72;
  color:var(--muted);
}

.section-contact{padding-top:22px}
.contact-cta{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  align-items:stretch;
  padding:24px;
  border-radius:28px;
  border:1px solid rgba(56,189,248,.20);
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(70% 90% at 14% 16%, rgba(96,165,250,.34) 0%, rgba(96,165,250,0) 52%),
    radial-gradient(48% 60% at 78% 18%, rgba(56,189,248,.28) 0%, rgba(56,189,248,0) 58%),
    radial-gradient(42% 56% at 86% 82%, rgba(59,130,246,.22) 0%, rgba(59,130,246,0) 64%),
    linear-gradient(135deg, #0b2d58 0%, #114d88 34%, #0f79cf 64%, #0a3f78 100%);
  color:#fff;
  box-shadow:
    0 22px 44px rgba(11,27,43,.18),
    0 0 0 1px rgba(147,197,253,.10) inset,
    0 0 48px rgba(59,130,246,.16);
}
.contact-cta::before{
  content:"";
  position:absolute;
  inset:-20% auto auto -10%;
  width:280px;
  height:280px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(125,211,252,.24) 0%, rgba(125,211,252,0) 70%);
  pointer-events:none;
}
.contact-cta::after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-110px;
  width:320px;
  height:320px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(96,165,250,.18) 0%, rgba(96,165,250,0) 72%);
  pointer-events:none;
}
.contact-cta .section-head h2,
.contact-cta .section-head p{color:#fff}
.contact-cta .section-head p{color:rgba(255,255,255,.76)}
.contact-cta .kicker{
  background:rgba(255,255,255,.10);
  border-color:rgba(147,197,253,.22);
  color:rgba(255,255,255,.92);
}
.contact-highlights{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.contact-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px 7px 8px;
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.26);
  color:rgba(255,255,255,.96);
  box-shadow:0 8px 18px rgba(3,18,36,.10);
}
.contact-badge-icon{
  width:20px;
  height:20px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 20px;
  background:rgba(255,255,255,.20);
  color:#fff;
}
.contact-badge-icon svg{
  width:12px;
  height:12px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.contact-badge-label{
  color:inherit;
  line-height:1;
}
.contact-panel{display:flex}
.contact-panel-card{
  width:100%;
  padding:20px;
  border-radius:24px;
  border:1px solid rgba(147,197,253,.24);
  background:linear-gradient(180deg, rgba(255,255,255,.14) 0%, rgba(255,255,255,.08) 100%);
  backdrop-filter:blur(10px);
  box-shadow:
    0 16px 32px rgba(3,18,36,.16),
    0 0 0 1px rgba(255,255,255,.05) inset;
}
.contact-panel-title{
  font-size:18px;
  font-weight:800;
  letter-spacing:-.02em;
}
.contact-panel-note{
  margin-top:6px;
  font-size:13px;
  color:rgba(255,255,255,.70);
}
.contact-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:18px;
}
.contact-btn-primary,
.contact-btn-secondary{
  justify-content:center;
  min-height:54px;
  gap:10px;
  font-weight:800;
}
.contact-btn-primary{
  background:linear-gradient(135deg, #07182c 0%, #0e2a4c 100%);
  border-color:rgba(255,255,255,.10);
  color:#fff;
  box-shadow:
    0 14px 28px rgba(2,10,20,.26),
    0 0 24px rgba(34,197,94,.10);
}
.contact-btn-secondary{
  background:rgba(255,255,255,.96);
  border-color:rgba(255,255,255,.96);
  color:#0b2b4f;
  box-shadow:0 12px 24px rgba(3,18,36,.12);
}
.contact-btn-primary:hover{background:linear-gradient(135deg, #081d35 0%, #11345d 100%)}
.contact-btn-secondary:hover{
  background:#fff;
  border-color:#fff;
  color:#092746;
}
.contact-btn-icon{
  width:20px;
  height:20px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 20px;
}
.contact-btn-primary .btn-icon svg,
.contact-btn-secondary .btn-icon svg,
.contact-btn-email .btn-icon svg{
  width:20px;height:20px;
  stroke:currentColor;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}
.contact-mini-points{
  display:grid;
  gap:12px;
  margin-top:18px;
}
.contact-mini-item{
  padding-top:12px;
  border-top:1px solid rgba(191,219,254,.18);
}
.contact-mini-item strong{
  display:block;
  font-size:14px;
  color:#fff;
}
.contact-mini-item span{
  display:block;
  margin-top:4px;
  font-size:13px;
  line-height:1.6;
  color:rgba(255,255,255,.70);
}

.form{
  display:grid;
  gap:12px;
}
.form-row{display:grid;gap:10px}
.field{display:grid;gap:6px}
.label{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.input, .select, .textarea{
  width:100%;
  border-radius:14px;
  border:1px solid var(--border-soft);
  padding:12px 12px;
  font-size:15px;
  outline:none;
  background:#fff;
  transition:box-shadow .12s ease, border-color .12s ease;
}
.textarea{min-height:120px;resize:vertical}
.textarea-md{min-height:96px;resize:vertical}
.input:focus, .select:focus, .textarea:focus{box-shadow:var(--ring);border-color:rgba(216,195,165,.65)}

.input-group{position:relative}
.input-group .field-ico{
  position:absolute;
  left:12px;
  top:50%;
  transform:translateY(-50%);
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(11,27,43,.70);
  pointer-events:none;
}
.input-group .field-ico svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.input-group .input{padding-left:42px}
.input-group-sm{max-width:220px}

.hint{font-size:12px;color:var(--muted)}
.error{
  border:1px solid rgba(200, 48, 48, .22);
  background:rgba(200, 48, 48, .06);
  color:#7a1d1d;
  border-radius:var(--radius);
  padding:12px 14px;
  font-weight:650;
}
.success{
  border:1px solid rgba(20, 120, 68, .22);
  background:rgba(20, 120, 68, .06);
  color:#0b4b2b;
  border-radius:var(--radius);
  padding:12px 14px;
  font-weight:650;
}
.badge{
  display:inline-flex;align-items:center;
  padding:7px 10px;border-radius:999px;
  border:1px solid var(--border-soft);
  background:#fff;
  font-weight:800;font-size:12px;color:var(--navy)
}
.badge.soft{background:rgba(216,195,165,.18);border-color:rgba(216,195,165,.35)}
.divider{height:1px;background:var(--border-soft);margin:10px 0}

.timeline{display:grid;gap:10px;margin-top:12px}
.t-item{
  display:flex;gap:12px;align-items:flex-start;
  border-radius:var(--radius);
  border:1px solid var(--border-soft);
  background:var(--card);
  padding:14px;
  position:relative;
}
.t-dot{
  width:12px;height:12px;border-radius:999px;
  margin-top:3px;
  border:2px solid rgba(11,27,43,.22);
  background:#fff;
}
.t-item.is-done .t-dot{background:var(--navy);border-color:var(--navy)}
.t-item.is-active{border-color:rgba(11,27,43,.20)}
.t-item.is-active .t-dot{background:rgba(216,195,165,.95);border-color:rgba(216,195,165,.95)}
.t-text strong{display:block;color:var(--navy);font-size:14px}
.t-text span{display:block;color:var(--muted);font-size:13px;margin-top:4px}

.choices{display:grid;gap:10px}
.choice-grid{display:grid;grid-template-columns:1fr;gap:10px}
.choice{
  position:relative;
  border-radius:var(--radius);
  border:1px solid var(--border-soft);
  background:var(--card);
  padding:14px;
  display:flex;
  gap:12px;
  align-items:flex-start;
  cursor:pointer;
  transition:border-color .12s ease, background .12s ease;
}
.choice:hover{border-color:rgba(11,27,43,.18)}
.choice input{position:absolute;opacity:0;pointer-events:none}
.choice.is-selected{border-color:rgba(216,195,165,.65);background:rgba(216,195,165,.08)}
.choice-icon{
  width:34px;height:34px;border-radius:12px;
  border:1px solid rgba(11,27,43,.08);
  background:rgba(11,27,43,.04);
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
  color:var(--navy);
}
.choice-text strong{display:block;color:var(--navy);font-size:14px}
.choice-text span{display:block;color:var(--muted);font-size:13px;margin-top:4px}

.product-choice{
  padding:0;
  overflow:hidden;
  flex-direction:column;
  gap:0;
}
.product-choice .product-choice-media{
  width:100%;
  aspect-ratio:4 / 3;
  position:relative;
  background:rgba(11,27,43,.06);
}
.product-choice .product-choice-media img{width:100%;height:100%;object-fit:cover;display:block}
.product-choice .product-choice-media.is-missing img{display:none}
.product-choice .product-choice-fallback{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:12px;
  background:
    radial-gradient(420px 220px at 14% 0%, rgba(216,195,165,.28) 0%, rgba(216,195,165,0) 62%),
    radial-gradient(420px 220px at 92% 22%, rgba(44,111,255,.14) 0%, rgba(44,111,255,0) 60%),
    linear-gradient(180deg, rgba(11,27,43,.90) 0%, rgba(11,27,43,.72) 100%);
}
.product-choice .product-choice-media:not(.is-missing) .product-choice-fallback{display:none}
.product-choice .product-choice-mark{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;
  font-size:11px;
  letter-spacing:.12em;
}
.product-choice .product-choice-body{
  padding:14px;
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.upload-box{
  border-radius:var(--radius);
  border:2px dashed rgba(44,111,255,.34);
  background:
    radial-gradient(620px 260px at 14% 0%, rgba(44,111,255,.16) 0%, rgba(44,111,255,0) 58%),
    radial-gradient(620px 260px at 92% 20%, rgba(37,211,102,.10) 0%, rgba(37,211,102,0) 55%),
    linear-gradient(180deg, rgba(246,250,255,1) 0%, rgba(244,251,246,1) 100%);
  padding:16px 16px;
  display:flex;
  gap:12px;
  align-items:flex-start;
  cursor:pointer;
}
.upload-box:hover{border-color:rgba(44,111,255,.48)}
.upload-box .choice-icon{width:44px;height:44px;border-radius:18px}
.upload-box .choice-icon svg{width:22px;height:22px}
.upload-meta strong{display:block;color:var(--navy);font-size:14px}
.upload-meta span{display:block;color:var(--muted);font-size:13px;margin-top:6px}
.upload-files{margin-top:10px;display:grid;gap:8px}
.file-pill{
  border-radius:999px;
  border:1px solid var(--border-soft);
  background:#fff;
  padding:8px 10px;
  font-size:12px;
  color:var(--navy);
  display:flex;
  justify-content:space-between;
  gap:12px;
}
.thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.thumb{
  width:64px;height:64px;border-radius:16px;
  border:1px solid var(--border-soft);
  background:#fff;
  overflow:hidden;
}
.thumb img{width:100%;height:100%;object-fit:cover}

.modal-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(11,27,43,.46);
  z-index:70;
}
.modal-overlay.is-open{display:block}

.modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:16px;
  z-index:75;
}
.modal.is-open{display:flex}

.modal-card{
  width:100%;
  max-width:960px;
  max-height:calc(100vh - 32px);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  border-radius:24px;
  border:1px solid var(--border-soft);
  background:#fff;
}
.modal-hero{
  position:relative;
  border-bottom:1px solid var(--border-soft);
}
.modal-hero-media{
  width:100%;
  aspect-ratio:16 / 9;
  background:rgba(11,27,43,.06);
  position:relative;
  overflow:hidden;
}
.modal-hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.modal-hero-media.is-placeholder{
  background:
    radial-gradient(620px 260px at 14% 0%, rgba(216,195,165,.30) 0%, rgba(216,195,165,0) 60%),
    radial-gradient(620px 260px at 92% 20%, rgba(44,111,255,.16) 0%, rgba(44,111,255,0) 55%),
    linear-gradient(180deg, rgba(11,27,43,.92) 0%, rgba(11,27,43,.74) 100%);
}
.modal-hero-fallback{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding:16px;
}
.modal-hero-media:not(.is-placeholder) .modal-hero-fallback{display:none}
.modal-hero-mark{
  width:48px;
  height:48px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:900;
  letter-spacing:.12em;
  font-size:12px;
}
.modal-hero-shade{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(11,27,43,.10) 0%, rgba(11,27,43,.55) 72%, rgba(11,27,43,.68) 100%);
}
.modal-hero-copy{
  position:absolute;
  left:16px;
  right:68px;
  bottom:14px;
  display:grid;
  gap:8px;
}
.modal-hero-badge{
  display:inline-flex;
  width:max-content;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;
  font-size:11px;
  letter-spacing:.14em;
}
.modal-hero-title{
  margin:0;
  color:#fff;
  font-size:22px;
  letter-spacing:-.02em;
}
.modal-hero-sub{color:rgba(255,255,255,.88);font-size:13px}

.modal-head{
  padding:16px 16px 14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid var(--border-soft);
}
.modal-title .kicker{margin:0}
.modal-close{
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid var(--border-soft);
  background:rgba(255,255,255,.9);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  flex:0 0 auto;
  cursor:pointer;
}
.modal-hero .modal-close{
  position:absolute;
  top:12px;
  right:12px;
  z-index:2;
  border-color:rgba(255,255,255,.24);
  background:rgba(255,255,255,.14);
}
.modal-hero .modal-close svg{stroke:rgba(255,255,255,.95)}
.modal-close svg{width:18px;height:18px;stroke:rgba(11,27,43,.85);fill:none;stroke-width:2;stroke-linecap:round}
.modal-body{padding:16px;overflow:auto}

.order-summary{
  border-radius:22px;
  border:1px solid rgba(11,27,43,.10);
  background:#fff;
  padding:14px 14px;
}
.invoice-head{display:flex;align-items:center;justify-content:space-between}
.invoice-head strong{color:var(--navy);font-size:14px}
.invoice-lines{margin-top:12px;border-top:1px solid rgba(11,27,43,.08);border-bottom:1px solid rgba(11,27,43,.08)}
.inv-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:10px 2px;border-top:1px dashed rgba(11,27,43,.10)}
.inv-row:first-child{border-top:0}
.inv-row .k{font-size:12px;color:rgba(11,27,43,.72);font-weight:800}
.inv-row .v{font-size:13px;color:var(--navy);font-weight:850;text-align:right}
.invoice-hint{margin-top:10px;font-size:12px;color:var(--muted)}
.invoice-hint:empty{display:none}
.invoice-total{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(11,27,43,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.invoice-total .k{font-size:12px;color:rgba(11,27,43,.72);font-weight:850}
.invoice-total .v{font-size:14px;color:var(--navy);font-weight:900}
.invoice-note{margin-top:10px;font-size:12px;color:var(--muted)}

.btn-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-weight:850;
}
.btn-cta .btn-icon{display:inline-flex;align-items:center;justify-content:center}
.btn-cta .btn-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

body.modal-open{overflow:hidden}

@media (max-width: 560px){
  .modal{padding:0}
  .modal-card{
    max-height:100vh;
    height:100vh;
    border-radius:0;
    border-left:0;
    border-right:0;
  }
  .modal-body{padding:14px}
  .modal-hero-media{aspect-ratio:16 / 10}
  .modal-hero-title{font-size:18px}
  .order-summary-grid{grid-template-columns:1fr}
  .input-group-sm{max-width:100%}
}

.footer{
  padding:26px 0 34px;
  border-top:1px solid var(--border);
  color:var(--muted);
  font-size:12px;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.footer-admin-link{
  color:rgba(11,27,43,.68);
  text-decoration:none;
  width:34px;
  height:34px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(11,27,43,.08);
  background:rgba(255,255,255,.72);
}
.footer-admin-link svg{
  width:17px;
  height:17px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.footer-admin-link:hover{color:var(--navy);border-color:rgba(11,27,43,.14);background:#fff}
.footer-admin-link:focus{
  outline:none;
  color:var(--navy);
  box-shadow:0 0 0 4px rgba(191,219,254,.45);
}

@media (max-width: 640px){
  .footer-inner{justify-content:center;text-align:center}
}

@media (min-width: 860px){
  h1{font-size:46px}
  .hero-grid{grid-template-columns:1.1fr .9fr;align-items:center}
  .grid.services{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split{grid-template-columns:repeat(3,minmax(0,1fr))}
  .form-row.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .choice-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .section-premium{padding:64px 0}
  .section-head-wide h2{font-size:38px}
  .flow-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
  .faq-shell{padding:30px}
  .contact-cta{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);padding:30px}
  .contact-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (min-width: 1100px){
  .flow-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .flow-connector{display:block}
}

@media (max-width: 767px){
  .before-after-section{padding:22px 0 12px}
  .before-after-shell{padding:24px 18px;border-radius:24px}
  .before-after-section-head{
    max-width:100%;
    margin:0 auto 24px;
    text-align:center;
  }
  .before-after-section-head h2{
    max-width:none;
    font-size:clamp(28px, 8vw, 36px);
  }
  .before-after-section-head p{
    max-width:none;
    font-size:14px;
    line-height:1.65;
  }
  .ba-comparison{border-radius:20px}
  .ba-comparison.ba-full{
    height:360px;
    min-height:0;
    aspect-ratio:auto;
  }
  .ba-label{top:12px;padding:7px 10px;font-size:10px}
  .ba-label-before{left:12px}
  .ba-label-after{right:12px}
  .ba-handle{width:48px;height:48px}
  .section-premium{padding:40px 0}
  .section-head-wide h2{font-size:27px}
  .section-head-wide p{font-size:14px}
  .flow-card{padding:18px}
  .flow-title-row h3{font-size:18px}
  .faq-shell{padding:18px}
  .faq-question{padding:16px}
  .faq-question-text{font-size:15px}
  .faq-answer{padding:0 16px 16px}
  .contact-cta{padding:18px}
  .contact-panel-card{padding:18px}
}

/* Prime Art UI polish layer */
html{font-family:var(--font-sans)}
body{
  background:var(--color-bg);
  color:var(--color-text);
  font-family:var(--font-sans);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
button,
input,
select,
textarea{font-family:inherit}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(7,24,39,.14);
}
.container{max-width:1180px}
.topbar{
  background:rgba(255,255,255,.92);
  border-bottom:1px solid var(--color-border);
}
.topbar-inner{min-height:72px}
.public-logo{max-height:52px}
.btn{
  min-height:42px;
  border-radius:999px;
  font-weight:750;
  letter-spacing:0;
}
.btn-primary{
  background:var(--color-primary);
  color:#fff;
  border-color:var(--color-primary);
}
.btn-primary:hover{background:#0b1f33;border-color:#0b1f33}
.btn-outline{
  background:#fff;
  border-color:var(--color-border);
  color:var(--color-text);
}
.btn-outline:hover{background:#f8fafc;border-color:#cbd5e1}
.btn-green{
  background:#15803d;
  border-color:#15803d;
  color:#fff;
}
.btn-green:hover{background:#166534;border-color:#166534}
.btn-icon,
.btn-icon-mark{
  flex:0 0 auto;
  line-height:0;
}
.btn svg{stroke-width:2}
.section{padding:44px 0}
.section-head{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  margin-bottom:18px;
}
.section-head h2{
  font-size:clamp(22px, 2.3vw, 30px);
  line-height:1.16;
  letter-spacing:0;
  margin:0;
}
.section-head p{
  max-width:68ch;
  font-size:14px;
  line-height:1.65;
}
.kicker,
.label{
  letter-spacing:.08em;
  font-weight:800;
}
.card,
.mini-card,
.step,
.faq details,
.order-summary{
  border-color:var(--color-border);
  border-radius:var(--radius-card);
  box-shadow:none;
}
.card{
  background:var(--color-surface);
  transition:border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}
.grid.services{gap:18px}
@media (min-width: 1024px){
  .grid.services{grid-template-columns:repeat(3,minmax(0,1fr))}
}
.service-media{
  height:auto;
  aspect-ratio:16 / 10;
  background:#f1f5f9;
}
.service-title{align-items:flex-start}
.service-title h3{
  font-size:16px;
  line-height:1.3;
}
.price-pill{
  border-color:#dbe3ea;
  background:#f8fafc;
  color:var(--color-text);
}
.service-desc{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:38px;
}
.card-actions{
  align-items:center;
  justify-content:flex-end;
}
.input,
.select{
  min-height:46px;
}
.input,
.select,
.textarea{
  border-color:var(--color-border);
  border-radius:var(--radius-input);
  color:var(--color-text);
}
.input:focus,
.select:focus,
.textarea:focus{
  box-shadow:0 0 0 4px rgba(7,24,39,.12);
  border-color:#94a3b8;
}
.badge{
  border-color:var(--color-border);
  color:var(--color-text);
  line-height:1.2;
  max-width:100%;
}
.badge.soft{
  background:#f8fafc;
  border-color:#e2e8f0;
}
.table{
  min-width:720px;
}
.table th,
.table td{
  color:var(--color-text);
}
.modal-overlay{
  background:rgba(15,23,42,.48);
  backdrop-filter:blur(4px);
}
.modal{padding:18px}
.modal-card{
  border-color:var(--color-border);
  border-radius:24px;
  box-shadow:0 24px 80px rgba(15,23,42,.18);
}
.modal-head{
  padding:18px 20px;
  border-color:var(--color-border);
}
.modal-body{padding:20px}
.modal-close{
  width:40px;
  height:40px;
  border-radius:14px;
}
.hero-slide{
  min-height:520px;
  height:min(720px, calc(100svh - 72px));
}
.hero-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(7,24,39,.16) 0%, rgba(7,24,39,var(--hero-ov-2, .52)) 100%);
  pointer-events:none;
}
.hero-inner{z-index:1}
.hero-title{
  font-size:clamp(32px, 5vw, 58px);
  letter-spacing:0;
}
.hero-subtitle{font-size:clamp(14px, 1.4vw, 17px)}
.hero-actions .btn-lg{
  min-height:52px;
  font-size:15px;
  padding-inline:20px;
}
.before-after-section{
  background:#fff;
}
.before-after-shell{
  border-radius:28px;
  background:#fff;
  border-color:var(--color-border);
  box-shadow:var(--shadow-soft);
}
.ba-comparison{
  height:auto;
}
.ba-comparison.ba-full{
  height:clamp(460px, 56vw, 720px);
  min-height:0;
  aspect-ratio:auto;
}
.section-how,
.faq-shell{
  background:#fff;
}
.flow-card,
.faq-item{
  border-color:var(--color-border);
  box-shadow:none;
}
.flow-card::before{content:none}
.flow-icon-services,
.flow-icon-upload,
.flow-icon-review,
.flow-icon-result{
  background:var(--color-primary);
}
.contact-cta{
  border-color:#dbeafe;
  background:#0b1f33;
  box-shadow:var(--shadow-soft);
}
.contact-cta::before,
.contact-cta::after{content:none}
.footer{
  background:#fff;
  border-top:1px solid var(--color-border);
}
@media (max-width: 767px){
  .section{padding:44px 0}
  .container{padding:0 16px}
  .topbar-inner{
    min-height:64px;
    gap:10px;
  }
  .top-actions{gap:6px}
  .top-actions .btn{min-height:40px}
  .hero-slide{
    min-height:560px;
    height:min(640px, calc(100svh - 64px));
  }
  .hero-copy{text-align:center}
  .hero-title{font-size:34px}
  .modal{padding:0}
  .modal-card{
    height:100svh;
    max-height:100svh;
    border-radius:0;
  }
  .modal-body{padding:16px}
  .card-actions .btn,
  .service-actions .btn{width:100%}
  .contact-cta{
    grid-template-columns:1fr;
    padding:20px;
    gap:18px;
  }
  .contact-actions,
  .contact-mini-points{
    grid-template-columns:1fr;
  }
  .footer-inner{
    grid-template-columns:1fr;
    text-align:center;
  }
  .footer-links{
    justify-content:center;
  }
  .footer-copy{
    text-align:center;
  }
}
@media (max-width: 430px){
  .public-logo{height:34px;max-width:min(150px, 42vw)}
  .top-actions .btn{padding-inline:9px}
  .hero-slide{min-height:540px}
  .hero-title{font-size:31px}
  .ba-comparison.ba-full{min-height:360px}
  .contact-actions{gap:10px}
}

/* Prime Art public Touchjet/Yayasan refactor */
body{
  background:var(--pa-bg);
  color:var(--pa-text);
  font-family:var(--pa-font);
  font-size:15px;
}

body{
  background:#f8fafc;
}

.container{
  max-width:1240px;
}

.topbar{
  background:rgba(255,255,255,.94);
  border-bottom:1px solid var(--pa-border-soft);
  box-shadow:none;
}

.topbar-inner{
  min-height:72px;
}

.btn{
  min-height:40px;
  padding:9px 14px;
  border-radius:var(--pa-radius-sm);
  font-size:13px;
  font-weight:700;
  line-height:1.2;
  box-shadow:none;
}

.btn-lg{
  min-height:48px;
  padding:12px 18px;
  font-size:14px;
}

.btn-primary{
  background:var(--pa-primary);
  border-color:var(--pa-primary);
}

.btn-primary:hover{
  background:var(--pa-primary-hover);
  border-color:var(--pa-primary-hover);
}

.btn-outline{
  background:var(--pa-surface);
  border-color:var(--pa-border);
  color:var(--pa-text);
}

.btn-outline:hover{
  background:var(--pa-surface-soft);
  border-color:var(--pa-border);
}

.btn-soft,
.badge.soft,
.price-pill{
  background:var(--pa-surface-soft);
  border-color:var(--pa-border-soft);
  color:var(--pa-text);
}

.btn-green{
  background:var(--pa-success);
  border-color:var(--pa-success);
}

.btn-green:hover{
  background:#115e59;
  border-color:#115e59;
}

.section{
  padding:72px 0;
}

.section-head{
  gap:8px;
  margin-bottom:26px;
}

h1,
h2,
h3,
.service-title h3,
.mini-card h3,
.step strong,
.faq summary{
  color:var(--pa-text);
  letter-spacing:0;
}

h1{
  font-size:clamp(34px, 4.4vw, 56px);
}

h2,
.section-head h2{
  font-size:clamp(28px, 3.2vw, 44px);
  line-height:1.08;
  font-weight:780;
}

p,
.hint,
.service-desc,
.mini-card p,
.step span{
  color:var(--pa-muted);
}

.kicker,
.label{
  font-size:11px;
  letter-spacing:.08em;
  font-weight:750;
}

.section-soft{
  background:#fbfbfb;
}

.section-head-wide{
  max-width:640px;
}

.services-modern{
  gap:22px;
}

.service-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
  border-radius:28px;
  border:1px solid #e5e7eb;
  box-shadow:0 10px 30px rgba(15,23,42,.04);
  overflow:hidden;
}

.service-card:hover{
  transform:translateY(-2px);
  border-color:#d9e1ea;
  box-shadow:0 18px 40px rgba(15,23,42,.06);
}

.service-media{
  aspect-ratio:16 / 10;
  background:#e2e8f0;
}

.service-card-body{
  display:flex;
  flex:1 1 auto;
  flex-direction:column;
  padding:22px 22px 20px;
}

.service-title{
  gap:14px;
}

.service-title h3{
  font-size:18px;
  font-weight:700;
  line-height:1.34;
}

.price-pill{
  padding:6px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:750;
  white-space:nowrap;
}

.service-desc{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:44px;
  margin-top:12px;
  font-size:14px;
  line-height:1.7;
}

.service-actions{
  margin-top:auto;
  padding-top:20px;
}

.service-actions .btn{
  width:100%;
  min-height:48px;
  justify-content:center;
}

.steps-modern{
  gap:18px;
}

.step-card{
  border-radius:28px;
  padding:24px;
  background:#fff;
  border:1px solid #e5e7eb;
  box-shadow:0 10px 30px rgba(15,23,42,.04);
}

.flow-number{
  margin-bottom:16px;
  font-size:12px;
  color:#64748b;
}

.flow-icon{
  width:56px;
  height:56px;
  border-radius:18px;
  box-shadow:none;
  background:#0f172a;
  color:#fff;
}

.flow-icon::before{
  content:none;
}

.flow-title-row{
  margin-top:18px;
}

.flow-title-row h3{
  font-size:20px;
  font-weight:700;
}

.flow-card p{
  margin-top:10px;
  font-size:14px;
  line-height:1.72;
}

.faq-modern{
  max-width:900px;
  margin:0 auto;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
}

.faq-head{
  margin:0 auto 24px;
}

.faq-list{
  gap:14px;
}

.faq-item{
  border-radius:22px;
  border:1px solid #e5e7eb;
  box-shadow:none;
}

.faq-item:hover,
.faq-item.is-open{
  transform:none;
  box-shadow:none;
  border-color:#d7dee7;
}

.faq-question{
  padding:18px 20px;
}

.faq-question-text{
  font-size:16px;
  font-weight:700;
  line-height:1.55;
}

.faq-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
}

.faq-answer{
  padding:0 20px 20px;
}

.faq-answer p{
  font-size:14px;
  line-height:1.78;
}

.section-contact{
  background:#f8fafc;
}

.contact-cta{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(320px, .8fr);
  gap:24px;
  padding:32px;
  border-radius:32px;
  border:1px solid #e5e7eb;
  background:#fff;
  box-shadow:0 14px 38px rgba(15,23,42,.05);
  color:var(--pa-text);
}

.contact-cta::before,
.contact-cta::after{
  content:none;
}

.contact-cta .section-head h2,
.contact-cta .section-head p{
  color:var(--pa-text);
}

.contact-cta .section-head p{
  color:var(--pa-muted);
}

.contact-cta .kicker{
  background:#f8fafc;
  border-color:#e5e7eb;
  color:var(--pa-text);
}

.contact-panel-card{
  padding:24px;
  border-radius:24px;
  border:1px solid #e5e7eb;
  background:#fbfbfb;
  box-shadow:none;
}

.contact-panel-title{
  font-size:18px;
  font-weight:700;
  color:var(--pa-text);
}

.contact-panel-note{
  color:var(--pa-muted);
}

.contact-actions{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:18px;
}

.contact-btn-primary,
.contact-btn-secondary{
  min-height:50px;
  justify-content:center;
}

.contact-btn-primary{
  background:#0f172a;
  border-color:#0f172a;
}

.contact-btn-primary:hover{
  background:#111827;
  border-color:#111827;
}

.contact-btn-secondary{
  background:#fff;
  border-color:#e5e7eb;
  color:var(--pa-text);
}

.contact-btn-secondary:hover{
  background:#f8fafc;
  border-color:#d7dee7;
}

.contact-mini-points{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin-top:20px;
}

.contact-mini-item{
  padding:14px 14px 12px;
  border-radius:18px;
  background:#fff;
  border:1px solid #e5e7eb;
}

.contact-mini-item strong{
  display:block;
  margin-bottom:6px;
  font-size:14px;
  color:var(--pa-text);
}

.contact-mini-item span{
  font-size:13px;
  line-height:1.65;
  color:var(--pa-muted);
}

.footer-modern{
  background:#ffffff;
  border-top:1px solid #e5e7eb;
  padding:28px 0 34px;
}

.footer-inner{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  grid-template-areas:
    "brand contact"
    "copy contact";
  align-items:start;
  gap:10px 22px;
}

.footer-brand{
  grid-area:brand;
  display:flex;
  align-items:center;
  gap:8px;
  min-height:36px;
}

.footer-contact{
  grid-area:contact;
}

.footer-copy{
  grid-area:copy;
}

.footer-brand strong{
  display:block;
  margin-bottom:0;
  font-size:15px;
  color:var(--pa-text);
}

.footer-contact{
  display:grid;
  gap:8px;
  max-width:520px;
}

.footer-contact-row{
  display:flex;
  align-items:flex-start;
  gap:10px;
}

.footer-contact-row strong,
.footer-contact-row a{
  color:var(--pa-text);
  font-size:13px;
  line-height:1.65;
  font-weight:600;
}

.footer-contact-icon{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 18px;
  margin-top:2px;
  color:var(--pa-faint);
}

.footer-contact-icon svg{
  width:16px;
  height:16px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  display:block;
}

.footer-contact-row a:hover{
  color:var(--pa-primary);
}

.footer-admin-icon-link{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid var(--pa-border-soft);
  background:var(--pa-surface-soft);
  color:var(--pa-primary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}

.footer-admin-icon-link:hover{
  border-color:var(--pa-border);
  background:#fff;
  color:var(--pa-primary);
}

.footer-admin-icon-inline{
  flex:0 0 auto;
}

.footer-admin-icon-mark{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:0;
}

.footer-admin-icon-mark .pa-icon{
  width:18px;
  height:18px;
  color:currentColor;
  display:block;
}

.footer-copy{
  font-size:12px;
  color:var(--pa-muted);
  text-align:left;
  justify-self:start;
  white-space:nowrap;
  align-self:end;
}

.faq-contact-section{
  background:#f8fafc;
  padding:72px 0;
}

.faq-contact-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(360px, .8fr);
  gap:28px;
  align-items:start;
}

.faq-panel,
.contact-panel{
  min-width:0;
}

.faq-panel .faq-modern{
  max-width:none;
  margin:0;
  padding:28px 30px;
  border:1px solid #e5e7eb;
  border-radius:28px;
  background:#fff;
  box-shadow:0 10px 30px rgba(15,23,42,.04);
}

.faq-panel .faq-head{
  margin-bottom:18px;
}

.faq-panel .section-head{
  margin-bottom:18px;
}

.faq-panel .section-head h2{
  font-size:clamp(28px, 2.7vw, 38px);
}

.faq-panel .section-head p{
  max-width:52ch;
}

.faq-panel .faq-list{
  gap:10px;
}

.faq-panel .faq-item{
  border-radius:18px;
}

.faq-panel .faq-question{
  padding:15px 17px;
}

.faq-panel .faq-question-text{
  font-size:14px;
  font-weight:700;
}

.faq-panel .faq-icon{
  width:30px;
  height:30px;
  flex:0 0 30px;
}

.faq-panel .faq-icon svg{
  width:14px;
  height:14px;
}

.faq-panel .faq-answer{
  padding:0 17px 17px;
}

.faq-panel .faq-answer p{
  font-size:13px;
  line-height:1.72;
}

.contact-panel .contact-cta{
  display:flex;
  flex-direction:column;
  gap:18px;
  padding:30px;
  min-height:100%;
  border-radius:28px;
  border:1px solid rgba(15,23,42,.08);
  background:#0f172a;
  color:#fff;
  box-shadow:0 16px 36px rgba(15,23,42,.12);
}

.contact-panel .contact-cta .section-head{
  margin-bottom:0;
}

.contact-panel .contact-cta .kicker{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.10);
  color:#fff;
}

.contact-panel .contact-cta .section-head h2{
  color:#fff;
  font-size:clamp(26px, 2.3vw, 34px);
}

.contact-panel .contact-cta .section-head p{
  color:rgba(255,255,255,.72);
  max-width:34ch;
}

.contact-meta{
  display:grid;
  gap:10px;
}

.contact-meta-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:8px 14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}

.contact-meta-label{
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.58);
}

.contact-meta-row strong{
  color:#fff;
  font-size:14px;
  line-height:1.4;
}

.contact-panel .contact-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:0;
}

.contact-panel .contact-btn-primary,
.contact-panel .contact-btn-secondary,
.contact-panel .contact-btn-email{
  width:100%;
  min-height:50px;
  justify-content:center;
}

.contact-panel .contact-btn-primary{
  background:#16a34a;
  border-color:#16a34a;
  color:#fff;
  gap:12px;
}

.contact-panel .contact-btn-primary:hover{
  background:#15803d;
  border-color:#15803d;
}

.contact-panel .contact-btn-secondary{
  background:#fff;
  border-color:#fff;
  color:#0f172a;
}

.contact-panel .contact-btn-email{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.14);
  color:#fff;
}

.contact-panel .contact-btn-email:hover{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.22);
}

.contact-panel .contact-btn-secondary:hover{
  background:#f8fafc;
  border-color:#f8fafc;
}

.contact-panel .contact-btn-primary .contact-btn-icon svg{
  width:20px;
  height:20px;
  stroke:#fff;
}

.footer-modern{
  padding:32px 0 38px;
}

.card,
.mini-card,
.step,
.faq details,
.faq-item,
.flow-card,
.order-summary,
.before-after-shell,
.contact-panel-card{
  background:var(--pa-surface);
  border:1px solid var(--pa-border-soft);
  border-radius:var(--pa-radius-lg);
  box-shadow:var(--pa-shadow-soft);
}

.card{
  overflow:hidden;
}

.card:hover,
.flow-card:hover,
.faq-item:hover{
  border-color:var(--pa-border);
  box-shadow:var(--pa-shadow-soft);
}

.service-media,
.product-choice .product-choice-media,
.modal-hero-media,
.thumb{
  background:var(--pa-surface-soft);
  border-color:var(--pa-border-soft);
}

.service-media,
.product-choice .product-choice-media{
  aspect-ratio:16 / 10;
  height:auto;
}

.service-media img,
.product-choice .product-choice-media img,
.modal-hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.card-actions,
.service-actions{
  align-items:center;
  justify-content:flex-end;
}

.table{
  min-width:720px;
}

.table th{
  background:var(--pa-surface-soft);
  color:var(--pa-muted);
  font-size:11px;
  letter-spacing:.08em;
  font-weight:750;
}

.table th,
.table td{
  border-bottom-color:var(--pa-border-soft);
}

.input,
.select,
.textarea{
  border-color:var(--pa-border);
  border-radius:var(--pa-radius-md);
  color:var(--pa-text);
  font-size:14px;
}

.input,
.select{
  min-height:46px;
}

.input:focus,
.select:focus,
.textarea:focus{
  border-color:var(--pa-success);
  box-shadow:0 0 0 4px rgba(15, 118, 110, .14);
}

.badge{
  min-height:26px;
  padding:5px 9px;
  border-color:var(--pa-border-soft);
  color:var(--pa-text);
  font-size:12px;
  font-weight:700;
  line-height:1.15;
}

.modal-overlay{
  background:rgba(15,23,42,.50);
  backdrop-filter:blur(4px);
}

.modal{
  padding:18px;
}

.modal-card{
  border:1px solid var(--pa-border-soft);
  border-radius:var(--pa-radius-xl);
  box-shadow:var(--pa-shadow-modal);
  max-height:min(90vh, 860px);
}

.modal-head{
  padding:18px 20px;
  border-bottom-color:var(--pa-border-soft);
}

.modal-body{
  padding:20px;
}

.modal-close{
  width:38px;
  height:38px;
  border-radius:var(--pa-radius-sm);
  border-color:var(--pa-border);
}

.hero-slide{
  min-height:520px;
  height:min(720px, calc(100svh - 72px));
}

.hero-title{
  font-size:clamp(34px, 5vw, 58px);
  font-weight:800;
}

.hero-subtitle{
  font-size:clamp(14px, 1.4vw, 17px);
}

.before-after-section,
.section-how,
.faq-shell{
  background:var(--pa-surface);
}

.flow-card::before,
.contact-cta::before,
.contact-cta::after{
  content:none;
}

.flow-icon-services,
.flow-icon-upload,
.flow-icon-review,
.flow-icon-result{
  background:var(--pa-primary);
}

.contact-cta{
  border:1px solid #dbeafe;
  background:#0f172a;
  box-shadow:var(--pa-shadow-soft);
}

.footer{
  background:var(--pa-surface);
  border-top:1px solid var(--pa-border-soft);
}

@media (max-width: 900px){
  .faq-contact-section{
    padding:48px 0;
  }

  .faq-contact-grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .faq-panel .faq-modern,
  .contact-panel .contact-cta{
    padding:22px;
  }
}

@media (max-width: 767px){
  .container{
    padding:0 16px;
  }

  .section{
    padding:32px 0;
  }

  .topbar-inner{
    min-height:64px;
  }

  .hero-slide{
    min-height:540px;
    height:min(640px, calc(100svh - 64px));
  }

  .hero-title{
    font-size:34px;
  }

  .card-actions,
  .service-actions{
    justify-content:stretch;
  }

  .card-actions .btn,
  .service-actions .btn{
    width:100%;
  }

  .modal{
    padding:0;
  }

  .modal-card{
    height:100svh;
    max-height:100svh;
    border-radius:0;
    border-left:0;
    border-right:0;
  }

  .modal-body{
    padding:16px;
  }

  .footer-modern{
    padding:28px 0 32px;
  }

  .footer-inner{
    grid-template-columns:1fr;
    grid-template-areas:
      "brand"
      "contact"
      "copy";
    text-align:center;
  }

  .footer-brand,
  .footer-contact,
  .footer-copy{
    justify-self:center;
  }

  .footer-brand{
    justify-content:center;
  }

  .footer-contact{
    max-width:none;
    justify-items:center;
  }

  .footer-contact-row{
    justify-content:center;
    text-align:center;
  }

  .footer-copy{
    text-align:center;
    justify-self:center;
    white-space:normal;
  }
}

@media (max-width: 430px){
  .public-logo{
    height:34px;
    max-width:min(150px, 42vw);
  }

  .top-actions{
    gap:6px;
  }

  .top-actions .btn{
    min-height:38px;
    padding-inline:9px;
  }

  .faq-panel .faq-modern,
  .contact-panel .contact-cta{
    padding:18px;
    border-radius:24px;
  }

  .faq-panel .faq-question{
    padding:14px 15px;
  }

  .faq-panel .faq-answer{
    padding:0 15px 15px;
  }

  .contact-meta-row{
    padding:11px 12px;
  }
}
