
*{box-sizing:border-box}
:root{
  --brand:#0f172a; --accent:#eab308; --ink:#0f172a; --muted:#334155; --bg:#ffffff; --glass:#ffffffb8;
  --shadow:0 14px 40px rgba(0,0,0,.18);
}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}
img{max-width:100%;height:auto;display:block;border-radius:14px}

/* Header */
.site-header{position:sticky;top:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:rgba(255,255,255,.75);backdrop-filter:blur(10px);border-bottom:1px solid #eef2f7}
.brand-link{font-weight:1000;letter-spacing:.2px;color:var(--brand);text-decoration:none;font-size:clamp(18px,2vw,22px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52vw}
.menu-btn{font-weight:900;border:1px solid #e5e7eb;background:#f8fafc;border-radius:999px;padding:10px 16px;box-shadow:var(--shadow)}
.menu-btn:focus{outline:2px solid var(--accent)}

/* Slide menu */
.menu-sheet{position:fixed;inset:0 0 0 auto;width:min(320px,86vw);background:#fff;box-shadow:-10px 0 30px rgba(0,0,0,.25);transform:translateX(100%);transition:.25s ease;display:flex;flex-direction:column;gap:10px;padding:16px;border-left:1px solid #eef2f7}
.menu-sheet.open{transform:none}
.menu-sheet a{padding:14px 16px;border-radius:14px;text-decoration:none;color:var(--ink);font-weight:900;background:#f8fafc;border:1px solid #eef2f7}
.menu-close{align-self:flex-end;border:0;background:#fff;font-size:28px;line-height:1;cursor:pointer}

/* Grain texture */
.grain{pointer-events:none;position:fixed;inset:0;opacity:.08;z-index:0;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width=\"120\" height=\"120\"><filter id=\"n\"><feTurbulence type=\"fractalNoise\" baseFrequency=\"0.9\" numOctaves=\"2\"/></filter><rect width=\"120\" height=\"120\" filter=\"url(%23n)\" opacity=\"0.5\"/></svg>');
  mix-blend-mode:multiply;
}

/* Parallax page background */
.page{min-height:calc(100vh - 120px); position:relative; z-index:1;}
.bg-parallax::before{
  content:""; position:fixed; inset:0; z-index:-2;
  background-size:cover; background-position:center;
  filter:blur(10px); opacity:.24;
}
.bg-parallax::after{
  content:""; position:fixed; inset:0; z-index:-1;
  background:
   radial-gradient(1200px 600px at -10% -20%, rgba(234,179,8,.25), transparent 40%),
   radial-gradient(900px 500px at 110% 120%, rgba(16,185,129,.18), transparent 50%),
   linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.96));
}
/* JS sets background image */

/* Stroke highlight for headings */
.stroke{background:
  linear-gradient(transparent 60%, rgba(234,179,8,.6) 60%, rgba(234,179,8,.6) 88%, transparent 88%);
  border-radius:6px;
}

/* Cards */
.card{border:1px solid #eef2f7;border-radius:18px;padding:22px;box-shadow:var(--shadow)}
.glass{background:var(--glass);backdrop-filter:blur(8px)}
.center{text-align:center;margin:0 auto;max-width:950px}
.readable{max-width:1000px;margin:0 auto}
.lift{transform:translateY(-6px)}

/* Hero collage */
.hero{padding:84px 16px 0; position:relative;}
.hero-collage{padding-bottom:26px}
.collage{position:relative; height:160px; margin:10px auto 0; max-width:1000px; filter:drop-shadow(0 12px 30px rgba(0,0,0,.15));}
.collage img{position:absolute; width:38%; border-radius:18px; object-fit:cover}
.collage .c1{left:6%; top:24px; transform:rotate(-3deg)}
.collage .c2{left:31%; top:-6px; transform:rotate(3deg)}
.collage .c3{left:56%; top:18px; transform:rotate(-2deg)}

/* Value cards row */
.value-cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; padding:20px 16px 32px; position:relative;}
.wave-top::before{content:""; position:absolute; left:0; right:0; top:-20px; height:40px; background:radial-gradient(100% 80% at 50% 0%, rgba(234,179,8,.35), transparent); filter:blur(14px);}
.v-card{background:#ffffffd0; border:1px solid #eef2f7; border-radius:16px; padding:16px; text-align:center; box-shadow:var(--shadow)}
.v-card h3{margin:0 0 6px}

/* Tiles */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;padding:14px 16px 36px}
.tile{display:block;text-decoration:none;background:#ffffffc9;border:1px solid #eef2f7;border-radius:16px;padding:16px;box-shadow:var(--shadow);transition:transform .15s ease, box-shadow .15s ease}
.tile:hover{transform:translateY(-2px); box-shadow:0 18px 48px rgba(0,0,0,.2)}
.tile h3{margin:0 0 6px;color:var(--brand)}
.tile p{margin:0;color:#475569}

/* Service ribbons with image backdrop */
.svc.banner{position:relative;border-radius:18px;overflow:hidden;margin:24px 0}
.svc.banner::before{content:""; position:absolute; inset:0; background-size:cover; background-position:center; filter:grayscale(.1) blur(2px); transform:scale(1.06); opacity:.5;}
.svc.banner .overlay{position:absolute; inset:0; background:linear-gradient(180deg, rgba(255,255,255,.93), rgba(255,255,255,.97));}
.svc.banner.ribbon .svc-content::after{
  content:""; position:absolute; right:-120px; top:24px; width:240px; height:38px;
  background:linear-gradient(90deg, #fde047, #34d399); transform:rotate(12deg); filter:blur(12px); opacity:.5;
}
.svc.banner.alt .svc-content::after{ left:-120px; right:auto; transform:rotate(-12deg); }
.svc.banner .svc-content{position:relative; padding:18px}
.svc-figs{display:flex;gap:12px;flex-wrap:wrap}
.svc-figs img{width:min(360px,48%);height:220px;object-fit:cover;border-radius:14px;box-shadow:var(--shadow)}

/* Reviews */
.reviews{margin-top:22px;padding-top:10px;border-top:1px solid #e5e7eb}
.review{background:#fff;border:1px solid #eef2f7;border-radius:14px;padding:12px;margin:10px 0;box-shadow:var(--shadow)}
.review span{color:#64748b}

/* Forms */
h1{font-size:clamp(30px,4.4vw,52px);margin:0 0 10px}
h2{font-size:clamp(22px,3.2vw,34px);margin:10px 0}
p{color:var(--muted);line-height:1.65}
.btn{display:inline-block;padding:12px 18px;border-radius:14px;text-decoration:none;font-weight:900}
.btn.big{padding:14px 22px}
.btn.primary{background:var(--brand);color:#fff}
.btn.ghost{border:2px solid var(--brand);color:var(--brand);background:transparent}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.quote-form{display:grid;gap:12px}
.row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
label{display:grid;gap:6px;font-weight:900;color:#334155}
input,select,textarea{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:10px;font-size:16px;background:#ffffffd0}
.contact{margin-top:16px;text-align:center}

/* Sticky call bar */
.call-bar{position:sticky;bottom:0;z-index:999;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px 14px;background:rgba(255,255,255,.98);border-top:1px solid #e5e7eb;backdrop-filter:blur(6px)}
.call-btn{text-align:center;padding:12px 10px;border-radius:10px;text-decoration:none;font-weight:900}
.call-btn.outline{border:2px solid var(--brand);color:var(--brand)}
.call-btn:not(.outline){background:var(--accent);color:#1f2937}

/* Footer with diagonal accent */
.site-footer{position:relative;text-align:center;padding:28px 16px;color:#6b7280}
.site-footer.diagonal::before{content:""; position:absolute; left:0; right:0; top:-36px; height:44px; background:linear-gradient(90deg,#fde047, #34d399); clip-path:polygon(0 100%,100% 0,100% 100%); opacity:.5}

/* Responsive */
@media(max-width:700px){
  .row{grid-template-columns:1fr}
  .brand-link{max-width:58vw}
  .collage{height:120px}
  .collage img{width:44%}
}


/* Logo styling */
.brand-link{display:flex;align-items:center;gap:10px}
.brand-mark{width:28px;height:28px;border-radius:6px;object-fit:cover;box-shadow:0 4px 12px rgba(0,0,0,.08)}
.footer-logo{width:46px;height:46px;opacity:.55;display:block;margin:0 auto 8px;border-radius:8px}


/* Reveal animations */
.reveal{opacity:0; transform:translateY(14px); transition:opacity .5s ease, transform .5s ease;}
.reveal.in{opacity:1; transform:none;}
.fade{opacity:0; transform:translateY(10px); transition:opacity .6s ease, transform .6s ease;}
.fade.in{opacity:1; transform:none;}
