:root{
  --bg:#0b0f17; --card:#121a27; --text:#eaf0ff; --muted:#b9c3da;
  --line:rgba(255,255,255,.10); --accent:#7c5cff; --accent2:#2ee9a6;
  --max:1080px; --r:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:16px/1.7 system-ui,Segoe UI,Roboto,Arial;
  background:
    radial-gradient(1200px 700px at 20% -10%,rgba(124,92,255,.25),transparent 60%),
    radial-gradient(900px 600px at 95% 10%,rgba(46,233,166,.18),transparent 55%),
    var(--bg);
  color:var(--text)
}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:auto;padding:0 18px}
.muted{color:var(--muted)}
hr{border:0;border-top:1px solid var(--line);margin:28px 0}

/* Top bar */
.top{position:sticky;top:0;z-index:20;background:rgba(11,15,23,.75);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand{font-weight:800;letter-spacing:.2px}
.links{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.links a{padding:9px 12px;border-radius:12px}
.links a:hover{background:rgba(255,255,255,.06)}
.btn{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:14px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.03))}
.btn:hover{transform:translateY(-1px);transition:.2s}

/* Hero */
.hero{padding:34px 0 14px}
.heroCard{border:1px solid var(--line);border-radius:var(--r);padding:22px;background:linear-gradient(180deg,rgba(255,255,255,.07),transparent)}
.kicker{display:inline-block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
h1{margin:.4rem 0 .2rem;font-size:clamp(28px,4vw,46px);line-height:1.12}
h2{margin:0 0 10px;font-size:clamp(20px,2.4vw,28px)}
h3{margin:0 0 8px}

/* Layout */
.grid{display:grid;grid-template-columns:1.6fr .9fr;gap:18px;align-items:start;padding:14px 0 40px}
@media (max-width:920px){.grid{grid-template-columns:1fr}}
.card{border:1px solid var(--line);border-radius:var(--r);background:rgba(18,26,39,.72)}
.pad{padding:18px}
.content p{margin:.7rem 0}

/* Photo grid (homepage) */
.photos{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:520px){.photos{grid-template-columns:1fr}}
.ph{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;background:#0e1420}
.ph img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02);transition:transform .4s ease}
.ph:hover img{transform:scale(1.10)}
.ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.55));opacity:.9}
.ph span{position:absolute;left:12px;bottom:10px;z-index:2;font-weight:700}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(10px);transition:.6s ease}
.reveal.show{opacity:1;transform:none}

/* Form */
input,textarea{width:100%;padding:12px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text)}
textarea{min-height:120px;resize:vertical}
label{display:block;margin:10px 0 6px;color:var(--muted);font-size:14px}

/* Footer */
footer{border-top:1px solid var(--line);padding:18px 0 28px;color:var(--muted)}
.small{font-size:14px}
.badge{display:inline-flex;gap:8px;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(90deg,var(--accent),var(--accent2))}

/* ===== Unique single-image effects per page ===== */

/* Page 2: centered media (blur -> sharp on hover) */
.centerMedia{
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#0e1420;
  margin-top:14px;
}
.centerMedia img{
  width:100%; height:auto; display:block;
  filter:blur(2px) saturate(1.05) contrast(1.05);
  transform:scale(1.03);
  transition:filter .45s ease, transform .45s ease;
}
.centerMedia:hover img{
  filter:blur(0) saturate(1.15) contrast(1.08);
  transform:scale(1.06);
}
.centerMedia .caption{
  padding:12px 14px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:14px;
}

/* Page 3: float image inside article (tilt + shine hover) */
.floatMedia{
  float:right;
  width:min(320px, 45%);
  margin:0 0 14px 14px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#0e1420;
  position:relative;
  transform:rotate(-1deg);
}
.floatMedia img{
  width:100%; height:auto; display:block;
  transform:scale(1.02);
  transition:transform .45s ease;
}
.floatMedia::after{
  content:"";
  position:absolute; inset:-40%;
  background:linear-gradient(120deg, transparent 40%, rgba(255,255,255,.18), transparent 60%);
  transform:translateX(-30%) rotate(18deg);
  opacity:0;
  transition:.5s ease;
}
.floatMedia:hover img{ transform:scale(1.10) }
.floatMedia:hover::after{ opacity:1; transform:translateX(30%) rotate(18deg) }
@media (max-width:920px){
  .floatMedia{ float:none; width:100%; margin:0 0 14px 0; transform:none; }
}

/* Page 4: sticky sidebar media (grayscale -> color hover) */
.stickyMedia{
  position:sticky;
  top:92px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#0e1420;
}
.stickyMedia img{
  width:100%; height:auto; display:block;
  filter:grayscale(1) contrast(1.05);
  transform:scale(1.02);
  transition:filter .45s ease, transform .45s ease;
}
.stickyMedia:hover img{
  filter:grayscale(0);
  transform:scale(1.08);
}
.stickyMedia .caption{
  padding:12px 14px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:14px;
}

/* Contact: glow + tiny bounce on hover */
.glowMedia{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#0e1420;
  transform:translateZ(0);
  transition:transform .25s ease, box-shadow .25s ease;
}
.glowMedia img{ width:100%; height:auto; display:block; }
.glowMedia:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(124,92,255,.18), 0 10px 30px rgba(46,233,166,.10);
}
.glowMedia .caption{
  padding:12px 14px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:14px;
}