/* Orbelle — Primavera
   Seasonal palette variant. */

:root{
  --base:8px;
  --max-width:1360px;

  --bg:#FBFAFC;
  --surface:#ffffff;
  --ink:#414951;
  --muted:#6b7278;
  --border:rgba(65,73,81,0.08);

  --accent-1:#F7229B;
  --accent-2:#934CD5;
  --accent-3:#2AAAFE;
  --accent-gradient:linear-gradient(90deg,var(--accent-1),var(--accent-2));

  --radius:14px;
  --shadow-sm:0 6px 18px rgba(65,73,81,0.04);
  --shadow-md:0 14px 36px rgba(65,73,81,0.08);

  --section-gap:112px;
  --transition-ease:cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;height:auto}
a{color:inherit}

.container{
  max-width:var(--max-width);
  margin:0 auto;
  padding-left:64px;
  padding-right:64px;
}

.main{min-height:60vh}

.eyebrow{
  letter-spacing:0.11em;
  font-size:0.95rem;
  color:var(--muted);
  text-transform:none;
}

.kicker{
  letter-spacing:0.12em;
  font-size:0.9rem;
  color:var(--muted);
  text-transform:uppercase;
}

.h1{
  font-size:48px;
  line-height:1.15;
  margin:16px 0 18px 0;
  font-weight:650;
  letter-spacing:-0.02em;
}

.h2{
  font-size:28px;
  line-height:1.2;
  margin:10px 0 0 0;
  font-weight:650;
  letter-spacing:-0.01em;
}

.lead{
  margin:0 0 28px 0;
  color:var(--muted);
  max-width:62ch;
}

.section{padding-top:var(--section-gap);padding-bottom:var(--section-gap)}
.section--tight{padding-top:80px;padding-bottom:80px}

.section-head{display:flex;flex-direction:column;gap:8px;margin-bottom:28px}

.site-header{
  position:sticky;
  top:0;
  z-index:40;
  backdrop-filter:blur(8px);
  background:rgba(255,255,255,0.72);
  border-bottom:1px solid rgba(65,73,81,0.06);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:88px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}

.brand-mark{
  display:block;
  width:32px;
  height:32px;
  border-radius:10px;
  box-shadow:0 6px 18px rgba(65,73,81,0.10);
}

.brand-name{
  font-weight:650;
  font-size:1.05rem;
  letter-spacing:0.04em;
}

.nav{display:flex;gap:28px;align-items:center}
.nav-link{
  text-decoration:none;
  letter-spacing:0.08em;
  font-size:0.95rem;
  color:var(--ink);
  position:relative;
}
.nav-link::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  height:2px;
  width:0%;
  background:var(--accent-gradient);
  transition:width .35s var(--transition-ease);
}
.nav-link:hover::after{width:100%}

.hero{padding-top:148px;padding-bottom:96px}
.hero-inner{display:flex;gap:48px;align-items:center}
.hero-copy{flex:1;max-width:640px}
.hero-media{flex:1;max-width:560px}
.hero-image{
  display:block;
  width:100%;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--surface);
  box-shadow:var(--shadow-sm);
}

.hero--simple .hero-inner{align-items:flex-end}
.hero--simple .hero-media{display:none}

.hero--case .hero-media{max-width:760px}
.case-hero-image{
  display:block;
  width:100%;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  background:var(--surface);
}

.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:8px}

.btn{
  display:inline-block;
  padding:12px 18px;
  border-radius:12px;
  text-decoration:none;
  font-weight:600;
  letter-spacing:0.02em;
}

.btn-primary{
  background:var(--accent-gradient);
  color:#ffffff;
  box-shadow:0 10px 22px rgba(65,73,81,0.12);
  transition:transform .28s var(--transition-ease), box-shadow .28s var(--transition-ease);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(65,73,81,0.16)}

.btn-link{
  background:transparent;
  padding:12px 6px;
  color:var(--ink);
  font-weight:650;
  text-decoration:none;
  position:relative;
}
.btn-link::after{
  content:"";
  position:absolute;
  left:0;
  bottom:6px;
  height:2px;
  width:100%;
  background:var(--accent-gradient);
  opacity:0.55;
}

.featured{
  display:flex;
  gap:48px;
  align-items:flex-start;
}
.featured-media{flex:1}
.featured-image{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  background:var(--surface);
  display:block;
  width:100%;
}
.featured-copy{flex:1;max-width:520px}
.quote{
  font-size:20px;
  font-style:italic;
  margin:12px 0 10px 0;
}
.quote-meta{letter-spacing:0.12em;color:var(--muted)}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  margin-top:28px;
}
.service-card{
  background:var(--surface);
  border:1px solid rgba(65,73,81,0.06);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--transition-ease);
}
.service-card:hover{transform:translateY(-6px)}
.service-title{font-weight:650;margin-bottom:8px;letter-spacing:0.01em}
.service-desc{color:var(--muted)}

.work-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.work-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  background:var(--surface);
  border:1px solid rgba(65,73,81,0.06);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--transition-ease), box-shadow .35s var(--transition-ease);
}
.work-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.work-media{aspect-ratio:3/2;overflow:hidden;background:var(--surface)}
.work-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s var(--transition-ease)}
.work-card:hover .work-image{transform:scale(1.03)}
.work-meta{padding:18px 18px 20px 18px}
.work-title{font-weight:650;margin-bottom:6px}
.work-sub{color:var(--muted);font-size:0.95rem}

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.portfolio-item{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--surface);
  border:1px solid rgba(65,73,81,0.06);
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--transition-ease), box-shadow .35s var(--transition-ease);
}
.portfolio-item:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.portfolio-media{aspect-ratio:3/2;overflow:hidden;background:var(--surface)}
.portfolio-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s var(--transition-ease)}
.portfolio-item:hover .portfolio-image{transform:scale(1.03)}
.portfolio-caption{padding:16px 18px 18px 18px}
.portfolio-title{font-weight:650;margin-bottom:6px}
.portfolio-desc{color:var(--muted);font-size:0.95rem}

.case-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.case-media{
  margin:0;
  background:var(--surface);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.case-image{width:100%;height:100%;object-fit:cover;display:block}

.contact-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.contact-card{
  background:var(--surface);
  border:1px solid rgba(65,73,81,0.06);
  border-radius:var(--radius);
  padding:20px;
  box-shadow:var(--shadow-sm);
}
.contact-line{margin-top:10px;color:var(--muted)}
.contact-line a{color:var(--ink);text-decoration:none}
.contact-line a:hover{text-decoration:underline}

.site-footer{
  padding-top:96px;
  padding-bottom:64px;
  border-top:1px solid rgba(65,73,81,0.06);
  margin-top:64px;
}
.footer-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}
.footer-brand{font-weight:650;letter-spacing:0.05em}
.footer-meta{color:var(--muted);margin-top:8px}
.footer-right{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end}
.footer-link{text-decoration:none;letter-spacing:0.06em;color:var(--ink)}
.footer-link:hover{text-decoration:underline}

@media (max-width: 1100px){
  .container{padding-left:40px;padding-right:40px}
  .hero-inner{flex-direction:column;align-items:flex-start}
  .hero-media{max-width:720px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .case-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
}

@media (max-width: 640px){
  .container{padding-left:20px;padding-right:20px}
  .nav{display:none}
  .h1{font-size:30px}
  .hero{padding-top:96px;padding-bottom:64px}
  .services-grid{grid-template-columns:1fr}
  .work-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .case-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;align-items:flex-start}
}
