@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800;900&display=swap');

:root{
  --bg:#020817;
  --panel:#0f172a;
  --panel-2:#111d33;
  --text:#f8fafc;
  --muted:#9fb0c9;
  --line:rgba(148,163,184,.16);
  --accent:#38bdf8;
  --accent-2:#8ee35d;
  --danger:#991b1b;
  --radius:28px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  background:var(--bg);
  color:var(--text);
}
a{color:inherit}
.container{width:min(1220px,92vw);margin:0 auto}

.site-header{
  position:sticky;top:0;z-index:50;
  height:82px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 42px;
  background:rgba(2,8,23,.82);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;gap:14px;align-items:center;text-decoration:none}
.brand-logo{
  width:48px;height:48px;border-radius:16px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  font-weight:900;color:white;
}
.brand strong{display:block;font-weight:900}
.brand small{display:block;color:var(--muted);font-size:12px;margin-top:4px}
.site-nav{display:flex;gap:28px;font-weight:800}
.site-nav a{text-decoration:none;color:#e2e8f0}
.site-nav a:hover{color:var(--accent)}
.nav-toggle{display:none}

.hero{
  min-height:calc(100vh - 82px);
  position:relative;
  display:flex;align-items:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 15% 35%, rgba(56,189,248,.18), transparent 38%),
    radial-gradient(circle at 80% 28%, rgba(142,227,93,.13), transparent 34%);
}
.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:70px;
  align-items:center;
  padding:80px 0;
}
.eyebrow{
  color:var(--accent);
  font-size:13px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
}
h1,h2,h3,p{margin-top:0}
h1{
  font-size:clamp(42px,5.6vw,82px);
  line-height:.95;
  letter-spacing:-.06em;
  margin-bottom:28px;
}
.lead{
  font-size:clamp(18px,1.55vw,23px);
  color:var(--muted);
  line-height:1.6;
  max-width:780px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:34px 0 24px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:54px;
  padding:0 22px;
  border-radius:999px;
  font-weight:900;
  text-decoration:none;
}
.btn.primary{background:var(--accent);color:#00111c}
.btn.secondary{background:rgba(15,23,42,.82);border:1px solid var(--line)}
.chips{display:flex;gap:12px;flex-wrap:wrap}
.chips span{
  background:rgba(15,23,42,.88);
  border:1px solid var(--line);
  color:#b9c7dc;
  padding:11px 16px;
  border-radius:999px;
  font-weight:800;
}
.hero-card{
  background:rgba(15,23,42,.72);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:0 30px 90px rgba(0,0,0,.3);
}
.hero-card-window{
  min-height:330px;
  border-radius:24px;
  padding:34px;
  display:flex;
  flex-direction:column;
  justify-content:end;
  background:linear-gradient(135deg,rgba(56,189,248,.18),rgba(142,227,93,.16));
}
.hero-card-window span{
  position:absolute;width:22px;height:22px;border-radius:50%;background:#a3e635;box-shadow:0 0 0 10px rgba(163,230,53,.16);
}
.hero-card h2{font-size:26px}
.hero-card p{line-height:1.6}
.hero-card a{color:var(--accent);font-weight:900}

.section{padding:92px 0;border-top:1px solid rgba(148,163,184,.08)}
.section-head{max-width:760px;margin-bottom:38px}
.section-head.wide{max-width:900px}
.section h2{
  font-size:clamp(36px,4.6vw,72px);
  letter-spacing:-.055em;
  line-height:1;
  margin-bottom:20px;
}
.section-head p,.split p{color:var(--muted);font-size:18px;line-height:1.7}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.service-card{
  background:linear-gradient(180deg,rgba(17,29,51,.95),rgba(9,16,31,.95));
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px;
}
.service-icon{
  width:52px;height:52px;border-radius:18px;
  display:grid;place-items:center;
  background:#050b18;
  border:1px solid var(--line);
  margin-bottom:20px;
}
.service-card h3{font-size:22px;margin-bottom:10px}
.service-card p{color:var(--muted);line-height:1.6}

.projects-section{background:linear-gradient(180deg,#020817,#030b1c)}
.projects-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  align-items:start;
}
.project-card{
  background:linear-gradient(180deg,#0f172a,#091225);
  border:1px solid rgba(56,189,248,.18);
  border-radius:28px;
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.project-card:hover{
  transform:translateY(-7px);
  border-color:rgba(56,189,248,.55);
  box-shadow:0 28px 80px rgba(0,0,0,.35);
}
.project-card.featured{grid-column:span 2}
.project-click{
  display:block;
  width:100%;
  padding:0;
  border:0;
  background:transparent;
  color:inherit;
  text-align:left;
  cursor:pointer;
  font:inherit;
}
.project-media{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
  background:#071126;
}
.project-card.featured .project-media{aspect-ratio:16/8}
.project-media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .55s ease, filter .55s ease;
}
.project-card:hover .project-media img{
  transform:scale(1.055);
  filter:saturate(1.12) contrast(1.05);
}
.project-placeholder{
  width:100%;height:100%;
  display:grid;place-items:center;
  font-size:42px;font-weight:900;
  color:rgba(255,255,255,.2);
}
.photo-count{
  position:absolute;right:16px;top:16px;
  background:rgba(2,8,23,.78);
  border:1px solid rgba(255,255,255,.18);
  color:#e2e8f0;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  backdrop-filter:blur(12px);
}
.project-body{padding:26px}
.badge{
  display:inline-flex;
  max-width:100%;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(56,189,248,.10);
  color:var(--accent);
  border:1px solid rgba(56,189,248,.22);
  font-size:12px;
  line-height:1;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.project-body h3{
  font-size:clamp(22px,2vw,32px);
  margin:18px 0 10px;
  letter-spacing:-.03em;
}
.project-body p{
  color:var(--muted);
  line-height:1.65;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.project-more{
  display:inline-flex;
  margin-top:14px;
  color:var(--accent);
  font-weight:900;
}
.empty-box,.mini-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
}
.split-grid{
  display:grid;
  grid-template-columns:1fr .55fr;
  gap:40px;
  align-items:center;
}
.mini-card strong{display:block;font-size:24px;margin-bottom:12px}
.mini-card span{color:var(--muted);line-height:1.6}

.footer{
  border-top:1px solid var(--line);
  padding:42px 0;
  background:#010614;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr repeat(3,1fr);
  gap:24px;
}
.footer span{display:block;color:var(--muted);font-size:13px;margin-bottom:8px}
.footer a{text-decoration:none;color:#fff;font-weight:900}
.footer p{color:var(--muted);margin-bottom:0}

.project-modal[hidden]{display:none}
.project-modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:24px}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(10px)}
.modal-card{
  position:relative;
  width:min(1050px,94vw);
  max-height:92vh;
  overflow:auto;
  background:#071126;
  border:1px solid rgba(56,189,248,.22);
  border-radius:30px;
  box-shadow:0 40px 120px rgba(0,0,0,.55);
}
.modal-close{
  position:absolute;top:14px;right:14px;z-index:5;
  width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(2,8,23,.76);
  color:#fff;font-size:30px;cursor:pointer;
}
.modal-image-wrap{
  position:relative;
  background:#020817;
}
.modal-image-wrap img{
  width:100%;
  max-height:66vh;
  object-fit:contain;
  display:block;
}
.modal-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:64px;border:0;
  background:rgba(2,8,23,.72);
  color:#fff;font-size:42px;cursor:pointer;
  border-radius:16px;
}
.modal-arrow.left{left:14px}
.modal-arrow.right{right:14px}
.modal-content{padding:26px}
.modal-content h3{font-size:34px;margin:16px 0 10px}
.modal-content p{color:var(--muted);line-height:1.65}
.modal-thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.modal-thumbs button{
  width:82px;height:62px;padding:0;border-radius:12px;overflow:hidden;
  border:2px solid transparent;background:#020817;cursor:pointer;
}
.modal-thumbs button.active{border-color:var(--accent)}
.modal-thumbs img{width:100%;height:100%;object-fit:cover;display:block}

@media(max-width:1000px){
  .hero-grid,.split-grid{grid-template-columns:1fr}
  .services-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}
  .project-card.featured{grid-column:span 1}
}
@media(max-width:720px){
  .site-header{height:auto;min-height:72px;padding:14px 18px}
  .nav-toggle{display:block;background:#0f172a;border:1px solid var(--line);color:#fff;border-radius:14px;padding:10px 13px}
  .site-nav{display:none;position:absolute;left:14px;right:14px;top:74px;flex-direction:column;background:#071126;border:1px solid var(--line);border-radius:20px;padding:18px}
  .site-nav.active{display:flex}
  .hero{min-height:auto}
  .hero-grid{padding:60px 0;gap:34px}
  .hero-card-window{min-height:240px}
  .services-grid,.projects-grid,.footer-grid{grid-template-columns:1fr}
  .section{padding:62px 0}
  .project-card.featured .project-media,.project-media{aspect-ratio:4/3}
  .modal-arrow{width:38px;height:52px;font-size:32px}
}
