/* ============================================
   THE DIGITAL YES — Global Styles v2
   Unsplash images intégrées
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Jost:wght@200;300;400;500&family=Dancing+Script:wght@500;700&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Jost',sans-serif;font-weight:300;background:var(--cream);color:var(--dark);overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;object-fit:cover;}

:root{
  --cream:#faf7f2; --cream2:#f5efe4; --cream3:#ede4d4;
  --gold:#b8996a;  --gold-l:#d4b88a; --gold-p:#f0e8d8;
  --rose:#e8b4b8;  --rose-l:#f5dde0; --rose-d:#c4868b;
  --sage:#a8bba0;  --sage-l:#dde8d9; --sage-d:#6e8f68;
  --dark:#1a1410;  --mid:#5c4a35;    --soft:#9b8870; --muted:#c4b49a;
  --white:#ffffff;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px;
  --sh-sm:0 2px 12px rgba(90,60,20,.08);
  --sh-md:0 8px 40px rgba(90,60,20,.12);
  --sh-lg:0 20px 70px rgba(90,60,20,.18);
  --t:.35s cubic-bezier(.22,1,.36,1);
}

/* ── Typography ── */
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:300;line-height:1.12;}
.script{font-family:'Dancing Script',cursive;}
.label{font-size:10px;letter-spacing:.5em;text-transform:uppercase;font-weight:300;color:var(--gold);}

/* ── Utilities ── */
.container{max-width:1200px;margin:0 auto;padding:0 48px;}
.text-center{text-align:center;}

.divider-gold{
  width:120px;height:1px;margin:0 auto;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.divider-gold.wide{width:220px;}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;border-radius:40px;
  font-family:'Jost',sans-serif;font-size:11px;font-weight:400;
  letter-spacing:.35em;text-transform:uppercase;
  cursor:pointer;border:none;transition:var(--t);
}
.btn-primary{background:var(--gold);color:var(--dark);box-shadow:0 4px 20px rgba(184,153,106,.3);}
.btn-primary:hover{background:var(--gold-l);transform:translateY(-2px);box-shadow:0 8px 30px rgba(184,153,106,.4);}
.btn-outline{background:transparent;color:var(--gold);border:1px solid var(--gold);}
.btn-outline:hover{background:var(--gold-p);transform:translateY(-2px);}
.btn-white{background:var(--white);color:var(--dark);box-shadow:var(--sh-md);}
.btn-white:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);}
.btn-dark{background:var(--dark);color:var(--cream);}
.btn-dark:hover{background:#2c2018;transform:translateY(-2px);}
.btn-lg{padding:18px 44px;font-size:12px;}

/* ── Badges ── */
.badge{display:inline-block;padding:5px 14px;border-radius:40px;font-size:10px;letter-spacing:.25em;text-transform:uppercase;font-weight:400;}
.badge-gold{background:var(--gold-p);color:var(--mid);}
.badge-rose{background:var(--rose-l);color:var(--rose-d);}
.badge-sage{background:var(--sage-l);color:var(--sage-d);}
.badge-new{background:var(--rose-d);color:var(--white);}
.badge-dark{background:rgba(26,20,16,.08);color:var(--mid);}

/* ── Cards ── */
.card{
  background:var(--white);border-radius:var(--r-lg);
  border:1px solid var(--gold-p);overflow:hidden;
  transition:var(--t);box-shadow:var(--sh-sm);
}
.card:hover{transform:translateY(-7px);box-shadow:var(--sh-lg);}

/* ── Image helpers ── */
.img-cover{width:100%;height:100%;object-fit:cover;display:block;}
.img-ratio-portrait{aspect-ratio:3/4;}
.img-ratio-square{aspect-ratio:1/1;}
.img-ratio-landscape{aspect-ratio:16/9;}
.img-ratio-tall{aspect-ratio:2/3;}

/* ─────────────────────────────────────────
   NAVBAR
───────────────────────────────────────── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:0 48px;height:76px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .4s ease,box-shadow .4s ease,backdrop-filter .4s ease;
}
.navbar.scrolled{
  background:rgba(250,247,242,.94);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--gold-p);
}
.navbar-logo{
  font-family:'Dancing Script',cursive;font-size:26px;color:var(--dark);
  font-weight:700;display:flex;align-items:center;gap:6px;
}
.navbar-logo span{color:var(--gold);}
.navbar-nav{display:flex;align-items:center;gap:36px;}
.navbar-nav a{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--mid);font-weight:300;position:relative;transition:color var(--t);
}
.navbar-nav a::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:center;
  transition:transform var(--t);
}
.navbar-nav a:hover,.navbar-nav a.active{color:var(--gold);}
.navbar-nav a:hover::after,.navbar-nav a.active::after{transform:scaleX(1);}
.navbar-cta{margin-left:12px;}
.navbar-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.navbar-burger span{display:block;width:24px;height:1px;background:var(--mid);transition:var(--t);}

.mobile-nav{
  position:fixed;inset:0;z-index:890;
  background:var(--cream);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:36px;
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
.mobile-nav.open{opacity:1;pointer-events:all;}
.mobile-nav a{font-family:'Cormorant Garamond',serif;font-size:40px;font-style:italic;color:var(--dark);transition:color var(--t);}
.mobile-nav a:hover{color:var(--gold);}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
.footer{background:var(--dark);color:rgba(250,247,242,.65);padding:80px 48px 40px;}
.footer-inner{max-width:1200px;margin:0 auto;}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;
  padding-bottom:60px;border-bottom:1px solid rgba(184,153,106,.12);
}
.footer-logo{font-family:'Dancing Script',cursive;font-size:30px;color:var(--white);font-weight:700;margin-bottom:16px;}
.footer-logo span{color:var(--gold-l);}
.footer-desc{font-size:13px;line-height:1.9;color:rgba(250,247,242,.45);max-width:300px;}
.footer-heading{font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:var(--gold-l);margin-bottom:22px;font-weight:400;}
.footer-links{display:flex;flex-direction:column;gap:13px;}
.footer-links a{font-size:13px;color:rgba(250,247,242,.5);transition:color var(--t);}
.footer-links a:hover{color:var(--gold-l);}
.footer-bottom{
  max-width:1200px;margin:32px auto 0;
  display:flex;align-items:center;justify-content:space-between;
  font-size:11px;color:rgba(250,247,242,.25);
}
.footer-social{display:flex;gap:14px;}
.footer-social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(184,153,106,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;color:rgba(250,247,242,.45);transition:var(--t);
}
.footer-social a:hover{border-color:var(--gold-l);color:var(--gold-l);transform:translateY(-2px);}

/* ─────────────────────────────────────────
   HOME HERO
───────────────────────────────────────── */
.hero-home{
  min-height:100svh;position:relative;
  display:flex;align-items:center;overflow:hidden;
}
.hero-photo{
  position:absolute;inset:0;
}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(250,247,242,.97) 0%,rgba(250,247,242,.88) 38%,rgba(250,247,242,.4) 65%,rgba(250,247,242,.05) 100%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:620px;padding:120px 0 80px;
  margin-left:max(48px,calc((100vw - 1200px)/2));
}
.hero-eyebrow{
  font-size:10px;letter-spacing:.55em;text-transform:uppercase;
  color:var(--gold);font-weight:300;margin-bottom:28px;
  opacity:0;animation:fadeUp .8s .2s forwards;
}
.hero-title{
  font-size:clamp(44px,5.5vw,74px);color:var(--dark);line-height:1.06;
  margin-bottom:28px;opacity:0;animation:fadeUp .9s .35s forwards;
}
.hero-title em{font-style:italic;color:var(--mid);}
.hero-title .script{font-size:1.15em;color:var(--gold);display:block;}
.hero-subtitle{
  font-size:15px;color:var(--soft);line-height:1.85;
  max-width:460px;margin-bottom:44px;
  opacity:0;animation:fadeUp .8s .5s forwards;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp .8s .65s forwards;}
.hero-stats{
  display:flex;gap:52px;margin-top:64px;padding-top:48px;
  border-top:1px solid var(--gold-p);
  opacity:0;animation:fadeUp .8s .8s forwards;
}
.hero-stat-num{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:300;color:var(--dark);line-height:1;}
.hero-stat-lbl{font-size:11px;letter-spacing:.2em;color:var(--soft);text-transform:uppercase;margin-top:5px;}

/* floating petals */
.petal-float{
  position:absolute;border-radius:50% 0 50% 0;pointer-events:none;
  animation:petalFloat var(--dur) var(--delay) ease-in-out infinite alternate;
}
@keyframes petalFloat{
  0%{opacity:0;transform:translate(0,0) rotate(0deg);}
  20%{opacity:.5;}
  80%{opacity:.3;}
  100%{opacity:0;transform:translate(var(--tx),var(--ty)) rotate(200deg);}
}

/* ─────────────────────────────────────────
   HOW IT WORKS
───────────────────────────────────────── */
.how-section{padding:120px 48px;background:var(--cream2);text-align:center;}
.how-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:48px;
  max-width:940px;margin:72px auto 0;position:relative;
}
.how-grid::before{
  content:'';position:absolute;top:36px;left:16%;right:16%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-p),var(--gold),var(--gold-p),transparent);
}
.how-step{display:flex;flex-direction:column;align-items:center;gap:18px;}
.how-num{
  width:72px;height:72px;border-radius:50%;
  border:1px solid var(--gold-p);background:var(--cream);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--gold);
  position:relative;z-index:1;transition:var(--t);
}
.how-step:hover .how-num{background:var(--gold-p);transform:scale(1.1);box-shadow:0 8px 28px rgba(184,153,106,.2);}
.how-step-title{font-size:20px;color:var(--dark);}
.how-step-desc{font-size:13px;color:var(--soft);line-height:1.75;max-width:230px;}

/* ─────────────────────────────────────────
   FEATURED INVITATION (homepage preview)
───────────────────────────────────────── */
.featured-section{padding:100px 48px;background:var(--cream);}
.featured-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;
  max-width:1100px;margin:0 auto;align-items:center;
}
.featured-mockup{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-lg);
}
.featured-mockup img{width:100%;height:560px;object-fit:cover;object-position:center top;display:block;}
.featured-mockup-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 50%,rgba(26,20,16,.5));
  display:flex;align-items:flex-end;padding:32px;
}
.featured-text .label{margin-bottom:14px;}
.featured-text h2{font-size:clamp(30px,4vw,50px);margin-bottom:20px;}
.featured-text p{font-size:14px;color:var(--soft);line-height:1.85;margin-bottom:32px;}
.featured-features{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:36px;}
.featured-features li{font-size:13px;color:var(--mid);display:flex;align-items:center;gap:10px;}
.featured-features li::before{content:'✦';color:var(--gold);font-size:10px;}

/* ─────────────────────────────────────────
   GALLERY ROW (homepage)
───────────────────────────────────────── */
.gallery-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  height:380px;overflow:hidden;
}
.gallery-strip-item{overflow:hidden;position:relative;cursor:pointer;}
.gallery-strip-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.gallery-strip-item:hover img{transform:scale(1.06);}
.gallery-strip-item::after{
  content:'';position:absolute;inset:0;
  background:rgba(26,20,16,0);transition:background .4s ease;
}
.gallery-strip-item:hover::after{background:rgba(26,20,16,.15);}

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
.testi-section{padding:120px 48px;background:var(--dark);position:relative;overflow:hidden;}
.testi-section::before{
  content:'❝';font-family:'Cormorant Garamond',serif;font-size:500px;
  color:rgba(184,153,106,.04);position:absolute;top:-120px;left:20px;line-height:1;
  pointer-events:none;
}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1100px;margin:64px auto 0;}
.testi-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(184,153,106,.12);
  border-radius:var(--r-lg);padding:36px;transition:var(--t);
}
.testi-card:hover{background:rgba(255,255,255,.07);border-color:rgba(184,153,106,.28);transform:translateY(-5px);}
.testi-avatar{
  width:52px;height:52px;border-radius:50%;overflow:hidden;margin-bottom:20px;
  border:2px solid rgba(184,153,106,.25);
}
.testi-avatar img{width:100%;height:100%;object-fit:cover;}
.testi-stars{color:var(--gold-l);letter-spacing:3px;font-size:13px;margin-bottom:14px;}
.testi-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;line-height:1.75;color:rgba(250,247,242,.78);margin-bottom:24px;}
.testi-author{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-l);}
.testi-couple{font-size:11px;color:rgba(250,247,242,.3);margin-top:4px;}

/* ─────────────────────────────────────────
   CTA BANNER
───────────────────────────────────────── */
.cta-banner{
  position:relative;padding:120px 48px;text-align:center;overflow:hidden;
}
.cta-banner-bg{
  position:absolute;inset:0;
}
.cta-banner-bg img{width:100%;height:100%;object-fit:cover;object-position:center 60%;}
.cta-banner-bg::after{
  content:'';position:absolute;inset:0;
  background:rgba(250,247,242,.88);
}
.cta-banner-content{position:relative;z-index:1;}
.cta-banner h2{font-size:clamp(32px,4.5vw,56px);color:var(--dark);margin-bottom:16px;}
.cta-banner p{font-size:15px;color:var(--soft);max-width:500px;margin:0 auto 40px;line-height:1.85;}

/* ─────────────────────────────────────────
   PAGE HERO (inner pages)
───────────────────────────────────────── */
.page-hero{
  position:relative;padding:0;overflow:hidden;
  min-height:400px;display:flex;align-items:center;justify-content:center;
}
.page-hero-bg{position:absolute;inset:0;}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%;}
.page-hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(250,247,242,.85) 0%,rgba(250,247,242,.75) 100%);
}
.page-hero-content{
  position:relative;z-index:1;text-align:center;
  padding:160px 48px 80px;
}
.page-hero-content h1{font-size:clamp(36px,5vw,66px);color:var(--dark);margin-top:12px;}
.page-hero-content p{font-size:15px;color:var(--soft);max-width:540px;margin:16px auto 0;line-height:1.85;}

/* ─────────────────────────────────────────
   CATALOGUE
───────────────────────────────────────── */
.filter-bar{
  padding:28px 48px;background:var(--white);
  border-bottom:1px solid var(--gold-p);
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  position:sticky;top:76px;z-index:50;
}
.filter-btn{
  padding:8px 22px;border-radius:40px;border:1px solid var(--gold-p);
  background:transparent;font-family:'Jost',sans-serif;font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--soft);
  cursor:pointer;transition:var(--t);
}
.filter-btn.active,.filter-btn:hover{background:var(--gold-p);border-color:var(--gold);color:var(--mid);}

.catalogue-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:36px;padding:72px 48px;max-width:1280px;margin:0 auto;
}
.catalogue-card .card-img{
  width:100%;height:340px;overflow:hidden;position:relative;
}
.catalogue-card .card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;
}
.catalogue-card:hover .card-img img{transform:scale(1.05);}
.catalogue-card .card-img-overlay{
  position:absolute;inset:0;
  background:rgba(26,20,16,0);
  display:flex;align-items:center;justify-content:center;
  transition:background .3s ease;
}
.catalogue-card:hover .card-img-overlay{background:rgba(26,20,16,.12);}
.catalogue-card .card-demo-btn{opacity:0;transform:scale(.9) translateY(6px);transition:opacity .3s,transform .3s;}
.catalogue-card:hover .card-demo-btn{opacity:1;transform:scale(1) translateY(0);}
.card-body{padding:24px 28px 28px;}
.card-title{font-size:22px;color:var(--dark);margin-bottom:8px;}
.card-desc{font-size:13px;color:var(--soft);line-height:1.75;margin-bottom:16px;}
.card-price{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--dark);font-weight:400;}
.card-price span{font-size:14px;color:var(--soft);font-family:'Jost',sans-serif;font-weight:300;}

/* ─────────────────────────────────────────
   ABOUT
───────────────────────────────────────── */
.about-story{
  padding:120px 48px;display:grid;grid-template-columns:1fr 1fr;
  gap:80px;max-width:1200px;margin:0 auto;align-items:center;
}
.about-img-wrap{position:relative;}
.about-img-main{
  width:100%;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-lg);
}
.about-img-main img{width:100%;height:100%;object-fit:cover;}
.about-img-accent{
  position:absolute;bottom:-24px;right:-24px;
  width:45%;aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;
  border:4px solid var(--white);box-shadow:var(--sh-md);
}
.about-img-accent img{width:100%;height:100%;object-fit:cover;}
.about-text h2{font-size:clamp(28px,3.5vw,46px);margin-bottom:24px;}
.about-text p{font-size:14px;color:var(--soft);line-height:1.9;margin-bottom:18px;}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:40px;}
.about-value{padding:20px;border:1px solid var(--gold-p);border-radius:var(--r-md);transition:var(--t);}
.about-value:hover{background:var(--gold-p);transform:translateY(-3px);}
.about-value-icon{font-size:22px;margin-bottom:10px;}
.about-value-title{font-size:16px;color:var(--dark);margin-bottom:5px;font-family:'Cormorant Garamond',serif;}
.about-value-desc{font-size:12px;color:var(--soft);line-height:1.65;}

/* team */
.team-section{padding:100px 48px;background:var(--cream2);text-align:center;}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:920px;margin:64px auto 0;}
.team-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--gold-p);transition:var(--t);}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md);}
.team-photo{width:100%;height:240px;overflow:hidden;}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .5s ease;}
.team-card:hover .team-photo img{transform:scale(1.05);}
.team-body{padding:24px;}
.team-name{font-size:22px;color:var(--dark);margin-bottom:5px;}
.team-role{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.team-bio{font-size:13px;color:var(--soft);line-height:1.7;}

/* ─────────────────────────────────────────
   PRICING
───────────────────────────────────────── */
.pricing-section{padding:80px 48px;max-width:1140px;margin:0 auto;}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px;}
.pricing-card{
  border-radius:var(--r-lg);padding:44px 36px;
  border:1px solid var(--gold-p);background:var(--white);
  position:relative;transition:var(--t);
}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);}
.pricing-card.featured{background:var(--dark);border-color:rgba(184,153,106,.25);transform:scale(1.04);}
.pricing-card.featured:hover{transform:scale(1.04) translateY(-6px);}
.pricing-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--dark);
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  padding:5px 18px;border-radius:40px;font-weight:400;white-space:nowrap;
}
.pricing-plan{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.pricing-price{font-family:'Cormorant Garamond',serif;font-size:60px;font-weight:300;line-height:1;color:var(--dark);margin-bottom:6px;}
.pricing-card.featured .pricing-price{color:var(--cream);}
.pricing-note{font-size:12px;color:var(--soft);margin-bottom:36px;}
.pricing-card.featured .pricing-note{color:rgba(250,247,242,.45);}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:40px;}
.pricing-features li{font-size:13px;color:var(--soft);display:flex;align-items:center;gap:10px;}
.pricing-card.featured .pricing-features li{color:rgba(250,247,242,.6);}
.pricing-features li::before{content:'✓';color:var(--gold);font-size:12px;flex-shrink:0;}
.pricing-features li.no::before{content:'—';color:rgba(155,136,112,.3);}
.pricing-features li.no{opacity:.45;}

/* ─────────────────────────────────────────
   CONTACT
───────────────────────────────────────── */
.contact-section{
  padding:80px 48px;max-width:1060px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start;
}
.contact-info h2{font-size:38px;color:var(--dark);margin-bottom:20px;}
.contact-info p{font-size:14px;color:var(--soft);line-height:1.85;margin-bottom:36px;}
.contact-item{display:flex;gap:16px;margin-bottom:24px;align-items:flex-start;}
.contact-icon{width:44px;height:44px;border-radius:50%;border:1px solid var(--gold-p);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;}
.contact-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.contact-value{font-size:14px;color:var(--mid);}
.contact-form{display:flex;flex-direction:column;gap:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--soft);}
.form-input{
  padding:14px 18px;border-radius:var(--r-sm);
  border:1px solid var(--gold-p);background:var(--white);
  font-family:'Jost',sans-serif;font-size:14px;font-weight:300;
  color:var(--dark);outline:none;transition:border-color var(--t);
  -webkit-appearance:none;
}
.form-input:focus{border-color:var(--gold);}
.form-input::placeholder{color:var(--muted);}
textarea.form-input{resize:vertical;min-height:130px;line-height:1.65;}

/* ─────────────────────────────────────────
   ANIMATIONS & REVEAL
───────────────────────────────────────── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .85s ease,transform .85s ease;}
.reveal.visible{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}
.reveal-delay-4{transition-delay:.45s;}
.reveal-scale{opacity:0;transform:scale(.96);transition:opacity .7s ease,transform .7s ease;}
.reveal-scale.visible{opacity:1;transform:scale(1);}

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media(max-width:1024px){
  .catalogue-grid{grid-template-columns:repeat(2,1fr);}
  .featured-grid{gap:48px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .navbar{padding:0 24px;}
  .navbar-nav,.navbar-cta{display:none;}
  .navbar-burger{display:flex;}
  .hero-content{padding:100px 24px 60px;margin-left:0;}
  .hero-photo::after{background:linear-gradient(to bottom,rgba(250,247,242,.96) 0%,rgba(250,247,242,.85) 60%,rgba(250,247,242,.5) 100%);}
  .hero-stats{gap:28px;padding-top:32px;}
  .how-section,.testi-section,.team-section,.pricing-section{padding:80px 24px;}
  .how-grid{grid-template-columns:1fr;}
  .how-grid::before{display:none;}
  .featured-section{padding:80px 24px;}
  .featured-grid{grid-template-columns:1fr;gap:48px;}
  .gallery-strip{grid-template-columns:repeat(2,1fr);height:280px;}
  .testi-grid{grid-template-columns:1fr;}
  .cta-banner{padding:80px 24px;}
  .catalogue-grid{grid-template-columns:1fr;padding:48px 24px;}
  .filter-bar{padding:20px 24px;}
  .about-story{grid-template-columns:1fr;padding:80px 24px;}
  .about-img-accent{display:none;}
  .team-grid{grid-template-columns:1fr;}
  .pricing-grid{grid-template-columns:1fr;}
  .pricing-card.featured{transform:none;}
  .contact-section{grid-template-columns:1fr;gap:48px;padding:60px 24px;}
  .form-row{grid-template-columns:1fr;}
  .footer{padding:60px 24px 36px;}
  .footer-grid{grid-template-columns:1fr;gap:36px;padding-bottom:40px;}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center;}
  .page-hero-content{padding:120px 24px 60px;}
}
