﻿
/* =========================================================
   1. VARIABILE (TEME) — schimbă aici culori, fonturi, spațiere
   ========================================================= */
:root{
  /* Culori */
  --ink:        #0E0E10;   /* negru cald (fundal secțiuni dark) */
  --onyx:       #16161A;   /* suprafață dark puțin mai deschisă */
  --onyx-2:     #1E1E24;   /* carduri pe dark */
  --champagne:  #C9A86A;   /* auriu/champagne — accentul principal */
  --gold-soft:  #E6CC95;   /* auriu deschis pentru highlight/shimmer */
  --ivory:      #F7F4EE;   /* alb cald (fundal secțiuni light) */
  --white:      #FFFFFF;   /* alb pur (carduri pe ivory) */
  --line:       rgba(201,168,106,.22); /* linii fine aurii */

  /* Text */
  --tx-light:   #F3F1EC;   /* text pe dark */
  --tx-muted-d: #A7A39B;   /* text secundar pe dark */
  --tx-dark:    #1A1A1C;   /* text pe light */
  --tx-muted-l: #6B675F;   /* text secundar pe light */

  /* Tipografie */
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Inter", -apple-system, "Segoe UI", sans-serif;

  /* Layout */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 14px;
  --section-y: clamp(72px, 10vw, 140px);

  /* Tranziții */
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* =========================================================
   2. RESET & BAZĂ
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  font-weight:400;
  color:var(--tx-dark);
  background:var(--ivory);
  line-height:1.6;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
:focus-visible{ outline:2px solid var(--champagne); outline-offset:3px; border-radius:4px; }

/* Skip link (accesibilitate) */
.skip-link{
  position:absolute; left:-999px; top:8px; z-index:200;
  background:var(--champagne); color:var(--ink); padding:10px 18px; border-radius:8px;
  font-weight:500;
}
.skip-link:focus{ left:16px; }

/* Utilitar container */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* Tipografie titluri */
h1,h2,h3{ font-family:var(--font-display); font-weight:500; line-height:1.08; letter-spacing:.01em; }

/* Eyebrow (etichetă mică deasupra titlurilor) */
.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem; font-weight:500; letter-spacing:.32em; text-transform:uppercase;
  color:var(--champagne);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--champagne); opacity:.7; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--champagne); opacity:.7; }

/* =========================================================
   3. BUTOANE / CTA
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-weight:500; font-size:.92rem; letter-spacing:.04em;
  padding:.92em 1.8em; border-radius:50px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease), color .35s var(--ease);
  white-space:nowrap;
}
/* CTA principal auriu */
.btn-gold{
  background:linear-gradient(135deg, var(--gold-soft), var(--champagne));
  color:var(--ink);
  box-shadow:0 10px 30px -10px rgba(201,168,106,.55);
}
.btn-gold:hover{ transform:translateY(-3px); box-shadow:0 16px 38px -10px rgba(201,168,106,.7); }
/* Buton ghost (contur) */
.btn-ghost{
  border:1px solid var(--line);
  color:var(--tx-light);
}
.btn-ghost:hover{ border-color:var(--champagne); color:var(--champagne); transform:translateY(-3px); }
.btn-ghost.dark{ color:var(--tx-dark); border-color:rgba(26,26,28,.18); }
.btn-ghost.dark:hover{ color:var(--champagne); border-color:var(--champagne); }

/* =========================================================
   4. NAVIGAȚIE STICKY + DROPDOWN
   ========================================================= */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  background:var(--white);
  box-shadow:0 1px 0 rgba(26,26,28,.07), 0 8px 30px -22px rgba(26,26,28,.45);
  transition:box-shadow .4s var(--ease), padding .4s var(--ease);
  padding-block:18px;
}
.nav.scrolled{
  box-shadow:0 1px 0 rgba(26,26,28,.08), 0 10px 30px -18px rgba(26,26,28,.5);
  padding-block:12px;
}
.nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

/* Logo */
.logo{ display:flex; align-items:center; gap:12px; color:var(--tx-light); }
.logo__img{ height:48px; width:auto; display:block; }
.nav.scrolled .logo__img{ height:40px; transition:height .4s var(--ease); }
.footer .logo__img{ height:54px; }
.logo__mark{
  width:38px; height:38px; flex:none; border-radius:50%;
  display:grid; place-items:center;
  background:radial-gradient(circle at 30% 30%, var(--gold-soft), var(--champagne) 60%, #9c814d);
  color:var(--ink); font-family:var(--font-display); font-weight:600; font-size:1.3rem;
  box-shadow:0 6px 18px -8px rgba(201,168,106,.7);
}
.logo__text{ line-height:1; }
.logo__name{ font-family:var(--font-display); font-size:1.35rem; font-weight:600; letter-spacing:.02em; }
.logo__sub{ display:block; font-size:.6rem; letter-spacing:.34em; text-transform:uppercase; color:var(--champagne); margin-top:3px; }

/* Meniu desktop */
.menu{ display:flex; align-items:center; gap:6px; }
.menu > li{ position:relative; }
.menu a, .menu .menu__btn{
  display:inline-flex; align-items:center; gap:6px;
  color:var(--tx-dark); font-size:.9rem; letter-spacing:.04em;
  padding:10px 16px; border-radius:8px;
  transition:color .3s var(--ease);
}
/* Underline animat la hover */
.menu__link{ position:relative; }
.menu__link::after{
  content:""; position:absolute; left:16px; right:16px; bottom:6px; height:1px;
  background:var(--champagne); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.menu__link:hover{ color:var(--champagne); }
.menu__link:hover::after{ transform:scaleX(1); }
.menu .chev{ transition:transform .3s var(--ease); }

/* Dropdown servicii */
.dropdown__panel{
  position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(10px);
  min-width:430px;
  background:var(--white); border:1px solid rgba(26,26,28,.08); border-radius:16px;
  padding:14px; opacity:0; visibility:hidden;
  box-shadow:0 30px 60px -25px rgba(26,26,28,.35);
  transition:opacity .3s var(--ease), transform .3s var(--ease), visibility .3s;
  display:grid; grid-template-columns:1fr 1fr; gap:4px;
}
.has-dropdown:hover .dropdown__panel,
.has-dropdown:focus-within .dropdown__panel{
  opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);
}
.dropdown__panel a{
  display:flex; align-items:center; gap:10px;
  padding:11px 12px; border-radius:10px; font-size:.86rem; color:var(--tx-muted-l);
  transition:background .25s var(--ease), color .25s var(--ease);
}
.dropdown__panel a:hover{ background:#faf6ec; color:#9c814d; }
.dropdown__panel a .dot{ width:5px; height:5px; border-radius:50%; background:var(--champagne); flex:none; opacity:.6; transition:transform .25s var(--ease); }
.dropdown__panel a:hover .dot{ transform:scale(1.8); opacity:1; }

.nav__cta{ display:flex; align-items:center; gap:14px; }

/* Buton hamburger (mobil) */
.burger{ display:none; width:44px; height:44px; flex:none; position:relative; }
.burger span{
  position:absolute; left:11px; right:11px; height:2px; background:var(--tx-dark); border-radius:2px;
  transition:transform .35s var(--ease), opacity .25s var(--ease), top .35s var(--ease);
}
.burger span:nth-child(1){ top:15px; }
.burger span:nth-child(2){ top:21px; }
.burger span:nth-child(3){ top:27px; }
.burger.open span:nth-child(1){ top:21px; transform:rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ top:21px; transform:rotate(-45deg); }

/* =========================================================
   5. HERO — imaginea full-width ca background; textul peste, în stânga
   ========================================================= */
.hero{
  position:relative; display:flex; align-items:center;
  /* fundal pe TOT hero-ul, ancorat dreapta (cuplul rămâne vizibil pe ecran lat) */
  background:#efe7d4 url("/bg.png") right center / cover no-repeat;
  min-height:560px; height:min(78svh, 760px);
  margin-top:84px;                  /* lasă loc sub navbar-ul fix alb */
  overflow:hidden;
}
/* Văl alb dinspre stânga: textul rămâne lizibil peste fundal, fără a acoperi cuplul */
.hero::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg,
    rgba(247,244,238,.97) 0%,
    rgba(247,244,238,.92) 26%,
    rgba(247,244,238,.6) 42%,
    rgba(247,244,238,.15) 54%,
    rgba(247,244,238,0) 64%);
}
/* Conținut: titlu + subtitlu + lead + butoane, în zona liberă din stânga */
.hero__content{
  position:relative; z-index:3;
  width:100%; max-width:var(--maxw); margin-inline:auto;
  padding-inline:var(--gutter);
}
.hero__text{ max-width:560px; }
.hero__photo{ display:none; }          /* doar pe mobil; pe desktop fundalul e imaginea */
.hero h1{
  color:var(--tx-dark);
  font-size:clamp(2.6rem, 5.2vw, 4.6rem);
  font-weight:600; line-height:1.04; letter-spacing:.005em; margin-bottom:8px;
}
.hero h1 em{ font-style:italic; color:#9c814d; }
.hero__sub{
  font-family:var(--font-display); font-style:italic; font-weight:500;
  font-size:clamp(1.6rem,2.8vw,2.4rem); color:var(--champagne);
  line-height:1; margin-bottom:28px;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero .btn-lg{ font-size:1rem; padding:1.02em 1.9em; }
/* Buton secundar din hero: vizibil peste fotografie */
.hero .btn-ghost.dark{
  background:rgba(255,255,255,.7); color:var(--tx-dark);
  border-color:rgba(156,129,77,.55); backdrop-filter:blur(2px);
}
.hero .btn-ghost.dark:hover{
  background:#fff; color:#9c814d; border-color:var(--champagne);
}

/* =========================================================
   6. FEATURES (bandă de încredere) — pe dark, sub hero
   ========================================================= */
.features{ background:var(--ivory); padding-block:clamp(40px,6vw,72px); border-top:1px solid rgba(26,26,28,.06); }
.features__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.feature{ display:flex; gap:18px; align-items:flex-start; }
.feature__ico{
  flex:none; width:52px; height:52px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(140deg,#fbf6ec,#f1e6cf); border:1px solid var(--line); color:#9c814d;
}
.feature h3{ font-family:var(--font-body); font-size:1.02rem; font-weight:500; color:var(--tx-dark); margin-bottom:6px; letter-spacing:.02em; }
.feature p{ color:var(--tx-muted-l); font-size:.9rem; font-weight:300; }

/* =========================================================
   7. SERVICII — secțiune LIGHT cu carduri
   ========================================================= */
.section{ padding-block:var(--section-y); }
.section--light{ background:var(--ivory); color:var(--tx-dark); }
.section--dark{ background:var(--white); color:var(--tx-dark); }
.section--white{ background:var(--white); color:var(--tx-dark); }

.section__head{ max-width:640px; margin-bottom:clamp(40px,6vw,64px); }
.section__head.center{ margin-inline:auto; text-align:center; }
.section__head h2{ font-size:clamp(2.2rem,4.5vw,3.4rem); margin-top:18px; }
.section__head h2 em{ font-style:italic; color:var(--champagne); }
.section--light .section__head p{ color:var(--tx-muted-l); }
.section--dark .section__head p{ color:var(--tx-muted-l); }
.section__head p{ margin-top:16px; font-weight:300; font-size:1.05rem; }

/* Grid carduri servicii — chenare cu video/imagine (stil magic-story, mai rafinat) */
.svc-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; }
.svc-tile{
  position:relative; display:block; aspect-ratio:3/4; border-radius:16px; overflow:hidden;
  background:#e9e0cd; box-shadow:0 18px 40px -28px rgba(40,30,10,.5);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
  isolation:isolate;
}
.svc-tile__media{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .7s var(--ease); z-index:0;
}
/* gradient jos pentru contrastul titlului */
.svc-tile::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(to top, rgba(12,10,6,.82) 0%, rgba(12,10,6,.28) 38%, rgba(12,10,6,0) 62%);
  transition:opacity .4s var(--ease);
}
.svc-tile__title{
  position:absolute; left:0; right:0; bottom:18px; z-index:2;
  padding-inline:16px; text-align:center;
  font-family:var(--font-display); font-weight:600; font-size:1.35rem; color:#fff;
  letter-spacing:.01em; text-shadow:0 2px 10px rgba(0,0,0,.5);
  transition:transform .4s var(--ease);
}
/* linie aurie care apare la hover sub titlu */
.svc-tile__title::after{
  content:""; display:block; width:26px; height:2px; margin:8px auto 0;
  background:var(--champagne); transform:scaleX(0); transform-origin:center;
  transition:transform .4s var(--ease);
}
.svc-tile:hover{ transform:translateY(-6px); box-shadow:0 34px 60px -30px rgba(40,30,10,.7); }
.svc-tile:hover .svc-tile__media{ transform:scale(1.07); }
.svc-tile:hover .svc-tile__title{ transform:translateY(-4px); }
.svc-tile:hover .svc-tile__title::after{ transform:scaleX(1); }

/* Buton sub grila de servicii */
.services__more{ text-align:center; margin-top:48px; }

/* =========================================================
   8. GALERIE — grid de poze (placeholdere editoriale)
   ========================================================= */
.gallery__grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); gap:14px; }
.gtile{
  position:relative; aspect-ratio:4/5; border-radius:12px; overflow:hidden; cursor:pointer;
  /* ÎNLOCUIEȘTE CU POZA TA:
     background-image:url('imagini/eveniment-1.jpg'); background-size:cover; background-position:center; */
  background-size:cover; background-position:center;
  border:1px solid var(--line);
}
/* Placeholder vizual elegant (șters automat când pui background-image cu poză) */
.gtile::before{
  content:""; position:absolute; inset:0;
  background:var(--ph, linear-gradient(150deg,#23211c,#3a3326));
  transition:transform .6s var(--ease);
}
.gtile::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(8,8,8,.82) 0%, rgba(8,8,8,.1) 45%, transparent 70%);
  opacity:.85; transition:opacity .4s var(--ease);
}
.gtile:hover::before{ transform:scale(1.07); }
.gtile:hover::after{ opacity:1; }
.gtile__cap{
  position:absolute; left:18px; right:18px; bottom:16px; z-index:2; color:var(--tx-light);
  transform:translateY(6px); opacity:.9; transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.gtile:hover .gtile__cap{ transform:translateY(0); opacity:1; }
.gtile__cap span{ font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--champagne); }
.gtile__cap strong{ display:block; font-family:var(--font-display); font-weight:500; font-size:1.25rem; margin-top:3px; }

/* =========================================================
   9. CIFRE / STATISTICI — dark, cu count-up
   ========================================================= */
.stats{ background:var(--ivory); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.stat{ text-align:center; padding:14px clamp(12px,3vw,40px); position:relative; }
.stat:not(:last-child)::after{ content:""; position:absolute; right:0; top:18%; bottom:18%; width:1px; background:var(--line); }
.stat__num{
  font-family:var(--font-display); font-weight:500; color:var(--champagne);
  font-size:clamp(2.6rem,5vw,4rem); line-height:1; letter-spacing:.01em;
  display:flex; align-items:baseline; justify-content:center; gap:2px;
}
.stat__num .suf{ font-size:.5em; color:var(--gold-soft); }
.stat__label{ margin-top:14px; color:var(--tx-muted-l); font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; font-weight:400; }
.stat__num, .stat__num > *:not(.count):not(.suf){ color:var(--champagne); }

/* =========================================================
   10. TESTIMONIALE — slider centrat, dark
   ========================================================= */
.testi{ background:var(--white); color:var(--tx-dark); }
.testi__slider{ max-width:880px; margin-inline:auto; text-align:center; position:relative; }
.quote-mark{ font-family:var(--font-display); font-size:6rem; line-height:.6; color:var(--champagne); opacity:.45; }
.testi__track{ position:relative; min-height:230px; }
.testi__slide{
  position:absolute; inset:0; opacity:0; visibility:hidden;
  transition:opacity .6s var(--ease); display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.testi__slide.active{ opacity:1; visibility:visible; position:relative; }
.testi__stars{ color:var(--champagne); letter-spacing:.25em; margin-bottom:22px; font-size:1.05rem; }
.testi__text{
  font-family:var(--font-display); font-style:italic; font-weight:400;
  font-size:clamp(1.3rem,2.6vw,1.85rem); line-height:1.5; color:#2a2823; max-width:760px;
}
.testi__author{ margin-top:26px; }
.testi__author strong{ font-family:var(--font-body); font-weight:500; font-size:1rem; letter-spacing:.03em; }
.testi__author span{ display:block; color:var(--tx-muted-l); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-top:4px; }

.testi__nav{ display:flex; align-items:center; justify-content:center; gap:24px; margin-top:40px; }
.testi__arrow{ width:48px; height:48px; border-radius:50%; border:1px solid rgba(26,26,28,.18); color:var(--tx-dark);
  display:grid; place-items:center; transition:all .3s var(--ease); }
.testi__arrow:hover{ background:var(--champagne); border-color:var(--champagne); color:var(--ink); }
.testi__dots{ display:flex; gap:10px; }
.testi__dots button{ width:9px; height:9px; border-radius:50%; background:rgba(26,26,28,.2); transition:all .3s var(--ease); }
.testi__dots button.active{ background:var(--champagne); width:26px; border-radius:5px; }

/* =========================================================
   11. CONTACT — dark, split (info + formular)
   ========================================================= */
.contact{ background:
    radial-gradient(700px 400px at 90% 10%, rgba(201,168,106,.14), transparent 60%),
    var(--ivory); }
.contact__grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(40px,6vw,80px); align-items:start; }
.contact__info h2{ font-size:clamp(2.2rem,4.5vw,3.4rem); margin:18px 0 20px; }
.contact__info p{ color:var(--tx-muted-l); font-weight:300; max-width:420px; margin-bottom:36px; }
.contact__list{ display:grid; gap:20px; margin-bottom:38px; }
.contact__item{ display:flex; gap:16px; align-items:center; }
.contact__item .ci-ico{ width:46px; height:46px; border-radius:12px; flex:none; display:grid; place-items:center;
  background:linear-gradient(140deg,#fbf6ec,#f1e6cf); border:1px solid var(--line); color:#9c814d; }
.contact__item .ci-meta span{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--tx-muted-l); }
.contact__item .ci-meta strong{ display:block; color:var(--tx-dark); font-weight:500; font-size:1.05rem; margin-top:2px; }
.contact__item .ci-meta strong a{ color:inherit; transition:color .25s var(--ease); }
.contact__item .ci-meta strong a:hover{ color:#9c814d; }
.contact__socials{ display:flex; gap:12px; }
.soc{ width:44px; height:44px; border-radius:50%; border:1px solid rgba(26,26,28,.18); color:var(--tx-dark);
  display:grid; place-items:center; transition:all .3s var(--ease); }
.soc:hover{ background:var(--champagne); border-color:var(--champagne); color:var(--ink); transform:translateY(-3px); }

/* Formular */
.form{
  background:var(--white); border:1px solid rgba(26,26,28,.08); border-radius:18px; padding:clamp(26px,4vw,40px);
  box-shadow:0 30px 60px -40px rgba(40,30,10,.4);
}
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ position:relative; margin-bottom:18px; }
.field label{ display:block; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--tx-muted-l); margin-bottom:8px; }
.field input, .field select, .field textarea{
  width:100%; background:var(--ivory); border:1px solid rgba(26,26,28,.14); border-radius:10px;
  padding:13px 15px; color:var(--tx-dark); font-family:inherit; font-size:.95rem;
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.field textarea{ resize:vertical; min-height:120px; }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239c814d' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--champagne); box-shadow:0 0 0 3px rgba(201,168,106,.18);
}
.field input::placeholder, .field textarea::placeholder{ color:#a49f95; }
.field.error input, .field.error select, .field.error textarea{ border-color:#c9706a; }
.field .err-msg{ color:#b84b44; font-size:.74rem; margin-top:6px; display:none; }
.field.error .err-msg{ display:block; }
.form .btn-gold{ width:100%; margin-top:6px; }
.form__note{ font-size:.78rem; color:var(--tx-muted-l); text-align:center; margin-top:16px; font-weight:300; }
/* Mesaj succes */
.form__success{ display:none; text-align:center; padding:20px; }
.form__success.show{ display:block; }
.form__success .ok-ico{ width:64px; height:64px; border-radius:50%; margin:0 auto 18px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--gold-soft),var(--champagne)); color:var(--ink); }
.form__success h3{ font-size:1.8rem; color:var(--tx-dark); margin-bottom:8px; }
.form__success p{ color:var(--tx-muted-l); font-weight:300; }

/* =========================================================
   12. FOOTER
   ========================================================= */
.footer{ background:var(--white); color:var(--tx-muted-l); padding-top:clamp(56px,7vw,84px); border-top:1px solid rgba(26,26,28,.06); }
.footer__top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(26,26,28,.08); }
.footer__brand .logo{ margin-bottom:18px; }
.footer__brand p{ font-weight:300; font-size:.92rem; max-width:300px; margin-bottom:22px; }
.footer__col h4{ font-family:var(--font-body); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:#9c814d; margin-bottom:20px; font-weight:600; }
.footer__col ul{ display:grid; gap:11px; }
.footer__col a{ font-size:.88rem; font-weight:300; color:var(--tx-muted-l); transition:color .25s var(--ease), padding-left .25s var(--ease); }
.footer__col a:hover{ color:#9c814d; padding-left:5px; }
.footer__socials{ display:flex; gap:10px; }
.footer__bottom{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; padding-block:26px; font-size:.8rem; }
.footer__bottom a{ color:var(--tx-muted-l); transition:color .25s var(--ease); }
.footer__bottom a:hover{ color:#9c814d; }
.footer__legal{ display:flex; flex-wrap:wrap; gap:18px; }

/* Buton WhatsApp flotant */
.fab{
  position:fixed; right:22px; bottom:22px; z-index:90;
  width:56px; height:56px; border-radius:50%; display:grid; place-items:center;
  background:linear-gradient(135deg,#25D366,#128C7E); color:#fff;
  box-shadow:0 12px 30px -8px rgba(18,140,126,.6);
  transition:transform .3s var(--ease);
}
.fab:hover{ transform:scale(1.08) translateY(-2px); }

/* =========================================================
   13. ANIMAȚII REVEAL (la scroll)
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; }

/* =========================================================
   14. RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .footer__top{ grid-template-columns:1fr 1fr 1fr; }
  .footer__brand{ grid-column:1 / -1; }
}
@media (max-width:900px){
  /* Navigație mobilă */
  .burger{ display:block; }
  .menu, .nav .menu__btn .chev{ display:none; }
  .menu{
    position:fixed; inset:0 0 0 auto; width:min(86vw,360px);
    flex-direction:column; align-items:stretch; gap:2px;
    background:var(--white); padding:100px 22px 40px; z-index:99;
    transform:translateX(100%); transition:transform .45s var(--ease);
    overflow-y:auto; border-left:1px solid rgba(26,26,28,.08); box-shadow:-20px 0 50px -30px rgba(40,30,10,.4);
  }
  .menu.open{ display:flex; transform:translateX(0); }
  .menu > li{ width:100%; }
  .menu a, .menu .menu__btn{ width:100%; padding:14px 12px; font-size:1rem; border-radius:10px; }
  .menu__link::after{ display:none; }
  .menu__btn{ display:flex !important; justify-content:space-between; width:100%; color:var(--tx-dark); }
  .menu__btn .chev{ display:inline-flex !important; }
  /* Dropdown devine acordeon */
  .dropdown__panel{
    position:static; transform:none; min-width:0; opacity:1; visibility:visible;
    grid-template-columns:1fr; box-shadow:none; border:none; background:transparent;
    max-height:0; overflow:hidden; padding:0 0 0 8px; transition:max-height .4s var(--ease);
  }
  .has-dropdown.open .dropdown__panel{ max-height:760px; padding-block:6px; }
  .has-dropdown.open .menu__btn .chev{ transform:rotate(180deg); }
  /* overlay fundal când meniul e deschis */
  .nav-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.5); opacity:0; visibility:hidden; transition:opacity .4s; z-index:98; }
  .nav-overlay.show{ opacity:1; visibility:visible; }

  .features__grid{ grid-template-columns:1fr; gap:22px; }
  .svc-grid{ grid-template-columns:repeat(3,1fr); gap:14px; }
  .stats__grid{ grid-template-columns:1fr 1fr; gap:30px 0; }
  .stat:nth-child(2)::after{ display:none; }
  .contact__grid{ grid-template-columns:1fr; }
}
/* HERO pe mobil: imaginea (cuplu+confetti) e fundalul; titlu sus, butoane jos peste cuplu */
@media (max-width:680px){
  /* fundal în tonul pozei (alb sus -> auriu jos), text lizibil; cuplul = element foto dedesubt */
  .hero{
    display:block; position:relative;
    background:linear-gradient(180deg, #f7f4ee 0%, #f3ecdb 60%, #efe2c4 100%);
    height:auto; min-height:0; max-height:none;
    margin-top:74px;
    text-align:center;
    overflow:hidden;
  }
  .hero::before{ display:none; }
  .hero__content{
    position:static; z-index:3; width:100%;
    padding:30px 0 18px;
  }
  .hero__text{ max-width:none; margin-inline:auto; }
  .hero h1{ color:var(--tx-dark); font-size:clamp(2rem,8vw,2.7rem); line-height:1.08; overflow-wrap:break-word; }
  .hero__sub{ font-size:clamp(1.4rem,6vw,1.9rem); margin-bottom:0; }
  /* imaginea cuplului, întreagă, sub text — se leagă de fundalul auriu */
  .hero__photo{
    display:block; width:100%;
    height:min(86vw, 440px);
    object-fit:cover; object-position:center 68%;
  }
  /* butoanele suprapuse peste partea de jos a imaginii */
  .hero__actions{
    position:absolute; left:0; right:0; bottom:24px; z-index:4;
    justify-content:center; padding-inline:var(--gutter);
  }
  .hero__actions .btn{ max-width:100%; white-space:normal; }
}
@media (max-width:560px){
  .form__row{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr 1fr; }
  .stat::after{ display:none !important; }
  .footer__top{ grid-template-columns:1fr 1fr; }
  .footer__bottom{ flex-direction:column; align-items:flex-start; }
  .hero__actions .btn{ width:100%; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .svc-tile__title{ font-size:1.1rem; }
  .gallery__grid{ grid-template-columns:1fr 1fr; }
}

/* Respectă preferința „mișcare redusă" */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}


/* ===== PAGINI INTERIOARE (servicii, despre, contact, legal) ===== */
.svc-hero{ position:relative; margin-top:84px; height:min(46svh,420px); min-height:300px; display:flex; align-items:flex-end; overflow:hidden; background:#efe7d4; }
.svc-hero__media{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.svc-hero__overlay{ position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(12,10,6,.78), rgba(12,10,6,.15) 55%, rgba(12,10,6,.35)); }
.svc-hero__inner{ position:relative; z-index:2; padding-bottom:36px; }
.svc-hero h1{ font-family:var(--font-display); color:#fff; font-weight:600; font-size:clamp(2.2rem,5vw,3.8rem); line-height:1.05; text-shadow:0 2px 18px rgba(0,0,0,.4); }
.crumbs{ font-size:.82rem; letter-spacing:.04em; color:rgba(255,255,255,.85); margin-bottom:12px; }
.crumbs a{ color:rgba(255,255,255,.85); transition:color .25s var(--ease); }
.crumbs a:hover{ color:var(--gold-soft); }
.crumbs span{ color:var(--gold-soft); }

.svc-page__wrap{ max-width:820px; margin-inline:auto; }
.svc-body h2{ font-family:var(--font-display); font-weight:600; color:var(--tx-dark); font-size:clamp(1.5rem,2.6vw,2rem); margin:32px 0 12px; }
.svc-body h3{ font-family:var(--font-display); font-weight:600; color:var(--tx-dark); font-size:1.3rem; margin:24px 0 10px; }
.svc-body p{ color:var(--tx-muted-l); font-size:1.02rem; font-weight:300; line-height:1.75; margin-bottom:14px; }
.svc-body .svc-list{ list-style:none; display:grid; gap:10px; margin:6px 0 20px; }
.svc-body .svc-list li{ position:relative; padding-left:30px; color:var(--tx-dark); font-weight:400; font-size:1rem; line-height:1.6; }
.svc-body .svc-list li::before{ content:""; position:absolute; left:6px; top:.6em; width:8px; height:8px; border-radius:50%; background:linear-gradient(135deg,var(--gold-soft),var(--champagne)); }
.svc-body blockquote{ margin:20px 0; padding:16px 22px; border-left:3px solid var(--champagne); background:#faf6ec; border-radius:0 12px 12px 0; font-family:var(--font-display); font-style:italic; font-size:1.15rem; color:#4a3f28; }
.svc-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; padding-top:30px; border-top:1px solid rgba(26,26,28,.08); }

/* Pagini text simplu (legal, despre) */
.page-hero{ margin-top:84px; padding:clamp(48px,7vw,90px) 0 clamp(24px,4vw,44px); background:var(--ivory); text-align:center; }
.page-hero h1{ font-family:var(--font-display); font-weight:600; font-size:clamp(2.2rem,5vw,3.6rem); color:var(--tx-dark); }
.page-hero .crumbs{ color:var(--tx-muted-l); margin-top:10px; }
.page-hero .crumbs a{ color:var(--tx-muted-l); } .page-hero .crumbs a:hover{ color:#9c814d; } .page-hero .crumbs span{ color:#9c814d; }
.legal-body{ max-width:800px; margin-inline:auto; }
.legal-body h2{ font-family:var(--font-display); font-weight:600; color:var(--tx-dark); font-size:1.5rem; margin:28px 0 10px; }
.legal-body h3{ font-family:var(--font-display); font-weight:600; color:var(--tx-dark); font-size:1.2rem; margin:20px 0 8px; }
.legal-body p{ color:var(--tx-muted-l); font-weight:300; line-height:1.75; margin-bottom:12px; }
.legal-body ul{ list-style:none; display:grid; gap:8px; margin:6px 0 18px; }
.legal-body li{ position:relative; padding-left:26px; color:var(--tx-dark); font-weight:300; line-height:1.6; }
.legal-body li::before{ content:""; position:absolute; left:4px; top:.6em; width:7px; height:7px; border-radius:50%; background:var(--champagne); }
@media (max-width:680px){ .svc-hero{ margin-top:74px; } .page-hero{ margin-top:74px; } .svc-cta .btn{ width:100%; } }
