/* ===== CSS RESET & VARIABLES ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --background: hsl(40 26% 91%);
  --foreground: hsl(36 12% 12%);
  --card: hsl(43 21% 87%);
  --border: hsl(36 15% 82%);
  --primary: hsl(24 87% 44%);
  --primary-foreground: hsl(39 30% 97%);
  --muted-foreground: hsl(36 8% 50%);
  --dark-bg: hsl(36 12% 8%);
  --dark-text: hsl(41 28% 91%);
  --dark-muted: hsl(36 8% 55%);
  --dark-border: hsl(36 8% 20%);
  --font-display: 'Cormorant Garamond', serif;
  --font-body: 'DM Sans', sans-serif;
}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:linear-gradient(180deg,
    hsl(40 26% 93%) 0%,
    hsl(40 26% 91%) 20%,
    hsl(39 24% 90%) 50%,
    hsl(40 26% 91%) 80%,
    hsl(41 28% 92%) 100%);
  color:var(--foreground);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
input,textarea{font-family:var(--font-body)}

/* ===== UTILITY CLASSES ===== */
.font-display{font-family:var(--font-display)}
.font-body{font-family:var(--font-body)}
.max-w-7xl{max-width:80rem;margin-left:auto;margin-right:auto;padding:0 2.5rem}
.section-label{
  font-family:var(--font-body);
  font-size:.6rem;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted-foreground);
  display:flex;
  align-items:center;
  gap:.75rem;
}
.section-label::before{
  content:'';
  display:inline-block;
  width:2rem;
  height:2px;
  background:var(--primary);
  flex-shrink:0;
}
.section-label-dark{color:var(--dark-muted)}
.section-label-dark::before{background:var(--primary)}

/* ===== ANIMATIONS ===== */
.animate-on-scroll{opacity:0;transform:translateY(24px) translateZ(0);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}
.animate-on-scroll.from-left{transform:translateX(-24px) translateZ(0)}
.animate-on-scroll.from-right{transform:translateX(24px) translateZ(0)}
.animate-on-scroll.visible{opacity:1;transform:translate3d(0,0,0);will-change:auto}

/* ===== HEADER ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:transparent;padding:1.25rem 0;
  transition:background .5s,box-shadow .5s;
  contain:layout style;
}
.site-header.scrolled{background:var(--background);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.header-inner{max-width:80rem;margin:0 auto;padding:0 2.5rem;display:flex;align-items:center;justify-content:space-between}
.logo-link{display:flex;align-items:center;gap:.75rem}
.logo-link:hover .logo-circle{border-color:var(--primary)}
.logo-link:hover .logo-text{color:var(--foreground)}
.logo-circle{
  width:2.25rem;height:2.25rem;border-radius:50%;
  border:2px solid var(--foreground);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .3s;
}
.logo-circle span{font-family:var(--font-display);font-weight:700;font-size:.875rem;letter-spacing:-.02em}
.logo-text{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(0,0,0,.5);transition:color .3s}
.nav-desktop{display:none;align-items:center;gap:2rem}
.nav-link{font-size:.75rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(0,0,0,.45);transition:color .2s}
.nav-link:hover{color:var(--foreground)}
.cta-header{
  display:none;align-items:center;gap:.5rem;
  background:var(--primary);color:var(--primary-foreground);
  font-size:.75rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  padding:.625rem 1.25rem;border-radius:9999px;transition:background .2s;
}
.cta-header:hover{background:hsl(24 87% 40%)}
.hamburger{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:2.25rem;height:2.25rem}
.hamburger span{display:block;height:2px;background:var(--foreground);transition:all .3s}
.hamburger span:nth-child(1),.hamburger span:nth-child(3){width:1.5rem}
.hamburger span:nth-child(2){width:1.25rem}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:40;background:var(--dark-bg);
  display:flex;flex-direction:column;
  opacity:0;pointer-events:none;transition:opacity .5s;
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu-inner{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding-top:5rem}
.mobile-menu-link{font-family:var(--font-display);font-size:2.25rem;font-weight:300;color:var(--dark-text);transition:color .2s}
.mobile-menu-link:hover{color:var(--primary)}
.mobile-menu-cta{margin-top:2rem;background:var(--primary);color:var(--primary-foreground);font-size:.875rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;padding:1rem 2rem;border-radius:9999px}
.mobile-menu-footer{padding-bottom:3rem;text-align:center}
.mobile-menu-footer p{font-size:.75rem;color:var(--dark-muted);letter-spacing:.15em;text-transform:uppercase}

@media(min-width:768px){
  .nav-desktop{display:flex}
  .cta-header{display:inline-flex}
  .hamburger{display:none}
}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;background:var(--background);overflow:hidden;padding:7rem 0 4rem}
.hero-bg{position:absolute;inset:0;opacity:.3;background-image:radial-gradient(circle at 20% 80%,hsl(24 87% 44%/.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,hsl(41 28% 80%/.4) 0%,transparent 50%)}
.hero-grid{position:relative;max-width:80rem;margin:0 auto;padding:0 2.5rem;display:grid;gap:3rem;align-items:center;min-height:calc(100vh - 8rem)}
.hero-text{display:flex;flex-direction:column;justify-content:center;order:2;padding-bottom:2rem}
.hero-title{font-family:var(--font-display);font-weight:300;font-size:clamp(3rem,6vw,5.5rem);line-height:.95;letter-spacing:-.02em;color:var(--foreground);margin-bottom:2rem}
.hero-title em{font-style:italic;color:var(--primary)}
.hero-desc{font-size:1rem;color:var(--muted-foreground);line-height:1.7;max-width:28rem;margin-bottom:2.5rem}
.hero-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}
.btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--primary);color:var(--primary-foreground);
  font-size:.875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  padding:.875rem 1.75rem;border-radius:9999px;transition:all .2s;
}
.btn-primary:hover{background:hsl(24 87% 40%);box-shadow:0 10px 25px hsl(24 87% 44%/.2)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.5rem;
  border:1px solid rgba(0,0,0,.2);color:var(--foreground);
  font-size:.875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  padding:.875rem 1.75rem;border-radius:9999px;transition:all .2s;
}
.btn-outline:hover{border-color:rgba(0,0,0,.4)}
.btn-outline-dark{border-color:rgba(255,255,255,.2);color:var(--dark-text)}
.btn-outline-dark:hover{border-color:rgba(255,255,255,.4)}

/* Hero image */
.hero-image-wrap{position:relative;order:1;display:flex;justify-content:center}
.hero-portrait{position:relative;width:100%;max-width:28rem;aspect-ratio:3/4;border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px rgba(0,0,0,.15)}
.hero-portrait img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-portrait-gradient{position:absolute;inset:0;background:linear-gradient(to top,hsl(36 12% 8%/.85),transparent 60%)}
.hero-portrait-info{position:absolute;bottom:0;left:0;right:0;padding:1.5rem}
.hero-portrait-info .founder-label{font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--primary);margin-bottom:.25rem}
.hero-portrait-info .founder-name{font-family:var(--font-display);font-size:1.875rem;font-weight:300;color:var(--dark-text);margin-bottom:1.5rem}
.hero-quote{background:hsl(36 12% 8%/.6);backdrop-filter:blur(8px);border-radius:.75rem;padding:1rem;border-left:2px solid var(--primary)}
.hero-quote p{font-family:var(--font-display);font-size:.875rem;font-style:italic;color:var(--dark-text);line-height:1.4;margin-bottom:.5rem}
.hero-quote-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}
.hero-quote-meta span{font-size:.55rem;color:var(--dark-muted);text-transform:uppercase;letter-spacing:.15em}
.hero-quote-meta .dot{color:hsl(24 87% 44%/.4)}

@media(min-width:1024px){
  .hero{padding:8rem 0 0}
  .hero-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .hero-text{order:1;padding-bottom:6rem}
  .hero-image-wrap{order:2;justify-content:flex-end}
  .hero-portrait{max-width:none;width:560px;aspect-ratio:auto;height:88vh}
  .hero-portrait-info{padding:2rem}
  .hero-portrait-info .founder-name{font-size:2.25rem}
  .hero-quote p{font-size:1rem}
}

/* ===== STATS BAND ===== */
.stats-band{background:var(--background);border-top:1px solid hsl(36 15% 82%/.5);border-bottom:1px solid hsl(36 15% 82%/.5)}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr)}
.stats-grid>div{padding:2.5rem 1.5rem;text-align:center;border-right:1px solid hsl(36 15% 82%/.5)}
.stats-grid>div:last-child{border-right:none}
.stat-number{font-family:var(--font-display);font-size:2.25rem;font-weight:300;color:var(--foreground);margin-bottom:.25rem}
.stat-label{font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-foreground)}
@media(min-width:768px){
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .stat-number{font-size:3rem}
}

/* ===== MARQUEE ===== */
.marquee-container{border-top:1px solid hsl(36 15% 82%/.5);padding:1rem 0;overflow:hidden;position:relative}
.marquee-track{display:flex;width:max-content;animation:marquee 40s linear infinite;will-change:transform;transform:translateZ(0)}
.marquee-item{display:flex;align-items:center;gap:1.5rem;padding:0 1.5rem;flex-shrink:0}
.marquee-item span.marquee-text{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.25rem);font-weight:300;font-style:italic;color:rgba(0,0,0,.18);white-space:nowrap}
.marquee-item span.marquee-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== LE CONSTAT ===== */
.constat{background:transparent;padding:6rem 0 6rem}
.constat-title{font-family:var(--font-display);font-weight:300;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em;color:var(--foreground);max-width:42rem}
.constat-title em{font-style:italic;color:var(--primary)}
.constat-grid{display:grid;gap:1.5rem;margin-top:4rem}
.constat-card{
  position:relative;overflow:hidden;
  background:hsl(43 21% 87%);border-radius:1rem;padding:2rem;
  border:1px solid hsl(36 15% 82%/.5);
  transition:border-color .3s,box-shadow .3s;
  contain:content;
}
.constat-card:hover{border-color:hsl(24 87% 44%/.3);box-shadow:0 10px 25px hsl(24 87% 44%/.05)}
.constat-card-icon{position:absolute;top:1rem;right:1rem;width:6rem;height:6rem;opacity:.3;pointer-events:none}
.constat-card:hover .constat-card-icon{opacity:.5}
.constat-card-icon img{width:100%;height:100%;object-fit:contain;filter:brightness(0)}
.constat-card h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--foreground);margin-bottom:.75rem;line-height:1.2;margin-top:5rem}
.constat-card p{font-size:.875rem;color:var(--muted-foreground);line-height:1.7}
@media(min-width:768px){.constat-grid{grid-template-columns:repeat(3,1fr)}}

/* ===== NOTRE APPROCHE ===== */
.approach{background:var(--background);padding:6rem 0;border-top:1px solid hsl(36 15% 82%/.5)}
.approach-grid{display:grid;gap:4rem;align-items:start}
.approach-left .approach-title{font-family:var(--font-display);font-weight:300;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em;color:var(--foreground)}
.approach-title em{font-style:italic;color:var(--primary)}
.approach-stats{margin-top:3rem;padding-top:3rem;border-top:1px solid hsl(36 15% 82%/.5);display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.approach-stat-num{font-family:var(--font-display);font-size:1.875rem;font-weight:300;color:var(--foreground);margin-bottom:.125rem}
.approach-stat-label{font-size:.75rem;color:var(--muted-foreground);letter-spacing:.05em}
.approach-item{
  position:relative;padding:2.5rem 0;
  border-bottom:1px solid hsl(36 15% 82%/.5);
  transition:padding-left .5s;
}
.approach-item:first-child{border-top:1px solid hsl(36 15% 82%/.5)}
.approach-item:hover{padding-left:1rem}
.approach-bar{position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--primary);transform:scaleY(0);transition:transform .5s;transform-origin:top}
.approach-item:hover .approach-bar{transform:scaleY(1)}
.approach-item-inner{display:flex;align-items:flex-start;gap:2rem}
.approach-num{flex-shrink:0;font-family:var(--font-display);font-size:3.5rem;line-height:1;font-weight:300;color:rgba(0,0,0,.08);transition:color .5s;margin-top:.25rem;user-select:none}
.approach-item:hover .approach-num{color:hsl(24 87% 44%/.2)}
.approach-item-content{flex:1;padding-top:.5rem}
.approach-micro{font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem}
.approach-item-content h3{font-family:var(--font-display);font-size:1.5rem;font-weight:300;color:var(--foreground);margin-bottom:.75rem;line-height:1.2}
.approach-item-content p{font-size:.875rem;color:var(--muted-foreground);line-height:1.7}
@media(min-width:1024px){
  .approach-grid{grid-template-columns:1fr 1fr;gap:6rem}
  .approach-left{position:sticky;top:8rem}
  .approach-num{font-size:5rem}
}

/* ===== EXPERTISES ===== */
.expertises{background:hsl(43 21% 87%);padding:6rem 0;border-top:1px solid hsl(36 15% 82%/.5)}
.expertises-header{display:flex;flex-direction:column;gap:2rem;margin-bottom:4rem}
.expertises-title{font-family:var(--font-display);font-weight:300;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em;color:var(--foreground);max-width:32rem}
.expertises-title em{font-style:italic;color:var(--primary)}
.expertises-desc{font-size:.875rem;color:var(--muted-foreground);line-height:1.7;max-width:24rem}
.expertises-grid{display:grid;gap:1.25rem}
.expertise-card{
  text-align:left;background:hsl(40 26% 91%);border-radius:1rem;padding:1.75rem;
  border:1px solid hsl(36 15% 82%/.5);transition:border-color .3s,box-shadow .3s;
  display:flex;flex-direction:column;
  contain:content;
}
.expertise-card:hover{border-color:hsl(24 87% 44%/.4);box-shadow:0 20px 40px hsl(24 87% 44%/.05)}
.expertise-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;flex-shrink:0}
.expertise-icon{width:2.5rem;height:2.5rem;border-radius:.75rem;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--primary);transition:all .3s}
.expertise-card:hover .expertise-icon{border-color:hsl(24 87% 44%/.5);background:hsl(24 87% 44%/.05)}
.expertise-arrow{width:1rem;height:1rem;color:rgba(0,0,0,.2);transition:all .2s;margin-top:.125rem}
.expertise-card:hover .expertise-arrow{color:var(--primary);transform:translate(2px,-2px)}
.expertise-card h3{font-size:.95rem;font-weight:600;letter-spacing:-.01em;color:var(--foreground);margin-bottom:.5rem;flex-shrink:0}
.expertise-card p{font-size:.875rem;color:var(--muted-foreground);line-height:1.7;margin-bottom:1.25rem;flex:1}
.expertise-tags{display:flex;flex-wrap:wrap;gap:.375rem}
.expertise-tag{
  display:inline-block;font-size:.5rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  padding:.2rem .4rem;border-radius:9999px;
  background:hsl(43 21% 87%);border:1px solid hsl(36 15% 82%/.8);color:var(--muted-foreground);
  transition:border-color .3s;white-space:nowrap;
}
.expertise-card:hover .expertise-tag{border-color:hsl(24 87% 44%/.2)}
@media(min-width:640px){.expertises-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){
  .expertises-grid{grid-template-columns:repeat(3,1fr)}
  .expertises-header{flex-direction:row;align-items:flex-end;justify-content:space-between}
}

/* ===== TÉMOIGNAGES ===== */
.testimonials{background:hsl(40 26% 91%);padding:6rem 0;border-top:1px solid hsl(36 15% 82%/.5)}
.testimonials-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3.5rem}
.testimonials-title{font-family:var(--font-display);font-weight:300;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em;color:var(--foreground);max-width:32rem}
.testimonials-title em{font-style:italic;color:var(--primary)}
.google-badge{display:flex;align-items:center;gap:1rem;background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1rem 1.5rem;align-self:flex-start}
.google-badge .score{font-family:var(--font-display);font-size:1.875rem;font-weight:300;color:var(--primary)}
.google-badge .stars{display:flex;gap:2px;margin:.25rem 0}
.google-badge .stars svg{width:.75rem;height:.75rem;fill:var(--primary);color:var(--primary)}
.google-badge .g-label{font-size:.6rem;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.15em}
.star-svg{width:.875rem;height:.875rem;fill:var(--primary);color:var(--primary)}

/* Main testimonial */
.testimonial-main{position:relative;background:hsl(43 21% 87%);border:1px solid hsl(36 15% 82%/.5);border-radius:1rem;padding:2.5rem;margin-bottom:1.25rem;overflow:hidden}
.testimonial-main .big-quote{position:absolute;top:1.5rem;right:2rem;font-family:'Cormorant Garamond',serif;font-size:10rem;line-height:1;color:hsl(34 11% 12%);opacity:.08;user-select:none;pointer-events:none}
.testimonial-main blockquote{font-family:var(--font-display);font-weight:300;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.35;letter-spacing:-.01em;color:var(--foreground);margin:1.25rem 0 2rem;max-width:56rem}
.testimonial-author{display:flex;align-items:center;gap:1rem}
.testimonial-avatar{width:2.5rem;height:2.5rem;border-radius:50%;background:hsl(24 87% 44%/.15);display:flex;align-items:center;justify-content:center}
.testimonial-avatar span{font-size:.875rem;font-weight:700;color:var(--primary)}
.testimonial-name{font-size:.875rem;font-weight:600;color:var(--foreground)}
.testimonial-role{font-size:.75rem;color:var(--muted-foreground)}

/* Small testimonials */
.testimonials-small{display:grid;gap:1.25rem}
.testimonial-small{background:hsl(43 21% 87%);border-radius:1rem;padding:1.75rem;border:1px solid hsl(36 15% 82%/.5)}
.testimonial-small p{font-size:.875rem;color:var(--foreground);line-height:1.7;margin:.875rem 0}
.testimonial-small-author{display:flex;align-items:center;gap:.75rem;padding-top:.75rem;border-top:1px solid hsl(36 15% 82%/.5)}
.testimonial-small-avatar{width:1.75rem;height:1.75rem;border-radius:50%;background:hsl(24 87% 44%/.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.testimonial-small-avatar span{font-size:.65rem;font-weight:700;color:var(--primary)}
.testimonial-small-name{font-size:.75rem;font-weight:600;color:var(--foreground)}
.testimonial-small-role{font-size:.65rem;color:var(--muted-foreground)}
@media(min-width:640px){.testimonials-small{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){
  .testimonials-header{flex-direction:row;align-items:flex-end;justify-content:space-between}
  .testimonial-main{padding:3.5rem}
}

/* ===== CTA DARK ===== */
.cta-dark{position:relative;background:linear-gradient(135deg,hsl(40 11% 11%),hsl(28 38% 15%));overflow:hidden;padding:6rem 0}
.cta-dark-radial{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(ellipse 70% 60% at 50% 100%,hsl(24 87% 44%/.12) 0%,transparent 70%)}
.cta-dark-bg-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;user-select:none;overflow:hidden}
.cta-dark-bg-text span{font-family:var(--font-display);font-weight:300;font-size:clamp(6rem,18vw,18rem);line-height:1;color:rgba(255,255,255,.025);white-space:nowrap}
.cta-dark-content{position:relative;max-width:80rem;margin:0 auto;padding:0 2.5rem}
.cta-dark-title{font-family:var(--font-display);font-weight:300;font-size:clamp(2.8rem,6vw,5rem);line-height:1;letter-spacing:-.02em;color:var(--dark-text);margin-bottom:2rem}
.cta-dark-title em{font-style:italic;color:var(--primary)}
.cta-dark-desc{font-size:1rem;color:var(--dark-muted);line-height:1.7;max-width:36rem;margin-bottom:3rem}
.cta-dark-badges{display:flex;flex-wrap:wrap;align-items:center;gap:1.5rem;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--dark-border)}
.cta-badge{display:flex;align-items:center;gap:.5rem}
.cta-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}
.cta-badge span{font-size:.75rem;color:var(--dark-muted);letter-spacing:.05em}

/* ===== CONTACT ===== */
.contact{background:var(--card);padding:6rem 0;border-top:1px solid hsl(36 15% 82%/.5)}
.contact-title{font-family:var(--font-display);font-weight:300;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em;color:var(--foreground);max-width:42rem}
.contact-title em{font-style:italic;color:var(--primary)}
.contact-grid{display:grid;gap:3rem;margin-top:4rem}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:grid;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-group label{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-foreground)}
.form-group label .req{color:var(--primary)}
.form-group input,.form-group textarea{
  font-size:.875rem;background:var(--background);border:1px solid var(--border);
  border-radius:.75rem;padding:.75rem 1rem;color:var(--foreground);
  transition:all .2s;outline:none;
}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(0,0,0,.3)}
.form-group input:focus,.form-group textarea:focus{border-color:hsl(24 87% 44%/.5);box-shadow:0 0 0 3px hsl(24 87% 44%/.1)}
.form-group textarea{resize:none}
.btn-submit{
  margin-top:.5rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-size:.875rem;font-weight:600;letter-spacing:.05em;
  background:var(--primary);color:var(--primary-foreground);
  padding:1rem 2rem;border-radius:.75rem;transition:all .2s;
}
.btn-submit:hover{background:hsl(24 87% 40%)}
.btn-submit:active{transform:scale(.98)}

/* Contact cards */
.contact-cards{display:flex;flex-direction:column;gap:2rem}
.contact-card{background:var(--background);border-radius:1rem;padding:1.75rem;border:1px solid hsl(36 15% 82%/.5)}
.contact-card h3{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--primary);margin-bottom:1.25rem}
.contact-card-row{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}
.contact-card-row:last-child{margin-bottom:0}
.contact-card-icon{flex-shrink:0;width:2rem;height:2rem;border-radius:.5rem;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.contact-card-icon svg{width:1rem;height:1rem;color:var(--muted-foreground)}
.contact-card-row p{font-size:.875rem;color:var(--foreground);line-height:1.5}
.contact-card-row a.map-link{font-size:.75rem;color:var(--primary);display:inline-block;margin-top:.25rem}
.contact-card-row a.map-link:hover{text-decoration:underline}
.contact-card-row a.tel-link{font-size:.875rem;color:var(--foreground);transition:color .2s}
.contact-card-row a.tel-link:hover{color:var(--primary)}
.contact-email-link{font-size:.875rem;color:var(--foreground);transition:color .2s}
.contact-email-link:hover{color:var(--primary)}
@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1fr;gap:5rem}}

/* ===== FOOTER ===== */
.site-footer{background:var(--foreground);color:var(--background);padding:4rem 0 2rem}
.footer-grid{display:grid;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .footer-logo{display:flex;align-items:baseline;gap:.375rem;margin-bottom:1rem}
.footer-brand .footer-logo span:first-child{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--background)}
.footer-brand .footer-logo span:last-child{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--primary)}
.footer-brand p{font-size:.875rem;color:rgba(255,255,255,.45);line-height:1.7;max-width:24rem;margin-bottom:1.5rem}
.footer-social a{width:2.25rem;height:2.25rem;border-radius:.5rem;border:1px solid rgba(255,255,255,.1);display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);transition:all .2s}
.footer-social a:hover{color:var(--background);border-color:rgba(255,255,255,.3)}
.footer-nav-title{font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1.25rem}
.footer-nav-list li{margin-bottom:.75rem}
.footer-nav-list a{font-size:.875rem;color:rgba(255,255,255,.55);transition:color .2s}
.footer-nav-list a:hover{color:var(--background)}
.footer-office-name{font-size:.75rem;font-weight:600;color:var(--primary);margin-bottom:.25rem}
.footer-office-address{font-size:.75rem;color:rgba(255,255,255,.35);line-height:1.5;white-space:pre-line;margin-bottom:.25rem}
.footer-office-tel{font-size:.75rem;color:rgba(255,255,255,.45);transition:color .2s}
.footer-office-tel:hover{color:var(--primary)}
.footer-office+.footer-office{margin-top:1.25rem}
.footer-bottom{padding-top:2rem;display:flex;flex-direction:column;gap:1rem;align-items:center}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.2);order:2}
.footer-bottom-links{display:flex;align-items:center;gap:1.5rem;order:1}
.footer-bottom-links a{font-size:.75rem;color:rgba(255,255,255,.2);transition:color .2s}
.footer-bottom-links a:hover{color:rgba(255,255,255,.45)}
@media(min-width:640px){
  .footer-bottom{flex-direction:row;justify-content:space-between}
  .footer-bottom p{order:1}
  .footer-bottom-links{order:2}
}
@media(min-width:1024px){
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
}
