/* ============ Christy — moderný redizajn ============ */
:root{
  --ivory:#F7F2E8;
  --cream:#EFE7D6;
  --cream-deep:#E7DBC4;
  --ink:#1E1A14;
  --ink-80:#3A352C;
  --ink-60:#6B6457;
  --taupe:#A98C63;
  --taupe-deep:#8A6B43;
  --line:#D8CCB4;
  --white:#FFFFFF;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
/* spray / droplet overlay */
#spray-fx{position:fixed;inset:0;width:100vw;height:100vh;pointer-events:none;z-index:90;transition:opacity .15s linear}
body{
  font-family:var(--sans);
  background:var(--ivory);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* ---------- typography helpers ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:13px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--taupe-deep);
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--taupe);display:inline-block}
.display{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.02;
  letter-spacing:-.01em;
  color:var(--ink);
  text-wrap:balance;
}

/* ---------- reveal animation base ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 40px;
  transition:padding .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.scrolled{
  padding:13px 40px;
  background:rgba(247,242,232,.86);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);
}
.nav__logo{height:82px;width:auto;filter:brightness(0);transition:height .4s var(--ease)}
.nav.scrolled .nav__logo{height:60px}
.nav__links{display:flex;align-items:center;gap:38px}
.nav__links a{
  font-size:14.5px;font-weight:500;letter-spacing:.01em;position:relative;white-space:nowrap;
}
.nav__links a:not(.nav__cta)::after{
  content:"";position:absolute;left:0;bottom:-5px;height:1.5px;width:0;background:var(--ink);
  transition:width .35s var(--ease);
}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{
  background:var(--ink);color:var(--ivory);padding:11px 22px;border-radius:100px;
  font-weight:600;white-space:nowrap;transition:transform .3s var(--ease),background .3s var(--ease);
}
.nav__cta:hover{background:var(--taupe-deep);transform:translateY(-2px)}
.nav__burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.nav__burger span{width:26px;height:2px;background:var(--ink);display:block;transition:.3s}

/* ============ HERO ============ */
.hero{position:relative;padding:168px 0 90px;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero__title{font-size:clamp(46px,6.6vw,98px)}
.hero__lead{
  font-size:clamp(17px,1.4vw,20px);color:var(--ink-80);max-width:30em;margin:30px 0 38px;
}
.hero__actions{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:12px;cursor:pointer;border:0;font-family:var(--sans);
  font-size:15.5px;font-weight:600;letter-spacing:.01em;border-radius:100px;
  padding:17px 30px;transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease);
}
.btn--dark{background:var(--ink);color:var(--ivory)}
.btn--dark:hover{transform:translateY(-3px);background:var(--taupe-deep)}
.btn--dark .arr{transition:transform .35s var(--ease)}
.btn--dark:hover .arr{transform:translateX(5px)}
.btn--ghost{padding:14px 0;border-bottom:1.5px solid var(--ink);border-radius:0}
.btn--ghost:hover{color:var(--taupe-deep);border-color:var(--taupe-deep)}

.hero__media{position:relative}
.hero__img{
  border-radius:220px 220px 18px 18px;overflow:hidden;aspect-ratio:4/5;
  box-shadow:0 40px 80px -40px rgba(40,32,20,.45);
}
.hero__img img{width:100%;height:100%;object-fit:cover}
.hero__badge{
  position:absolute;left:-34px;bottom:42px;background:var(--ivory);
  padding:22px 26px;border-radius:18px;box-shadow:0 24px 50px -22px rgba(40,32,20,.4);
  display:flex;align-items:center;gap:16px;
}
.hero__badge .num{font-family:var(--serif);font-size:46px;line-height:1;color:var(--taupe-deep)}
.hero__badge .lbl{font-size:13.5px;color:var(--ink-60);max-width:11em;line-height:1.35}
.hero__deco{
  position:absolute;top:120px;right:-120px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--cream),transparent 70%);
  z-index:-1;
}

/* floating sparkles */
.spark{position:absolute;color:var(--taupe);opacity:.5;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* ============ MARQUEE strip ============ */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;margin-top:60px;overflow:hidden}
.marquee{display:flex;gap:64px;white-space:nowrap;width:max-content;animation:scroll 32s linear infinite}
.marquee span{font-family:var(--serif);font-size:30px;color:var(--ink-80);display:inline-flex;align-items:center;gap:64px}
.marquee span::after{content:"✦";color:var(--taupe);font-size:18px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ INTRO statements ============ */
.intro{padding:120px 0 40px}
.intro__head{max-width:760px;margin-bottom:72px}
.intro__statements{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.stmt{position:relative}
.stmt__img{border-radius:16px;overflow:hidden;aspect-ratio:3/2.4;margin-bottom:26px}
.stmt__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.stmt:hover .stmt__img img{transform:scale(1.06)}
.stmt__n{font-family:var(--serif);font-size:18px;color:var(--taupe-deep);display:block;margin-bottom:10px}
.stmt p{font-size:18px;color:var(--ink-80);line-height:1.5}

/* ============ FEATURES (premium services 4) ============ */
.features{padding:120px 0}
.features__head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:60px;flex-wrap:wrap}
.features__title{font-size:clamp(36px,4.6vw,66px)}
.features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.feat{
  position:relative;border-radius:18px;overflow:hidden;aspect-ratio:3/4.1;
  display:flex;align-items:flex-end;color:var(--white);isolation:isolate;
}
.feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.3s var(--ease)}
.feat::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(20,16,10,.86) 0%,rgba(20,16,10,.25) 48%,rgba(20,16,10,.05) 100%);}
.feat:hover img{transform:scale(1.08)}
.feat__body{padding:26px}
.feat__body h3{font-family:var(--serif);font-size:25px;font-weight:600;line-height:1.1;margin-bottom:10px}
.feat__body p{font-size:14px;line-height:1.45;opacity:0;max-height:0;transition:opacity .5s var(--ease),max-height .6s var(--ease),margin .5s var(--ease);overflow:hidden}
.feat:hover .feat__body p{opacity:.92;max-height:120px}

/* ============ SERVICES accordion list ============ */
.services{padding:30px 0 130px}
.services__layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:70px;align-items:start}
.services__intro{position:sticky;top:120px}
.services__title{font-size:clamp(36px,4.4vw,60px);margin:22px 0 24px}
.services__intro p{color:var(--ink-80);font-size:17px;max-width:24em}
.acc{border-top:1px solid var(--line)}
.acc__item{border-bottom:1px solid var(--line)}
.acc__head{
  width:100%;background:none;border:0;cursor:pointer;font-family:var(--sans);text-align:left;
  display:flex;align-items:center;gap:24px;padding:28px 6px;color:var(--ink);
}
.acc__num{font-family:var(--serif);font-size:18px;color:var(--taupe-deep);min-width:30px}
.acc__name{font-family:var(--serif);font-size:clamp(24px,2.6vw,34px);font-weight:500;flex:1;transition:color .3s}
.acc__icon{position:relative;width:20px;height:20px;flex-shrink:0}
.acc__icon::before,.acc__icon::after{content:"";position:absolute;background:var(--ink);transition:transform .4s var(--ease)}
.acc__icon::before{top:9px;left:0;width:20px;height:2px}
.acc__icon::after{left:9px;top:0;width:2px;height:20px}
.acc__item.open .acc__icon::after{transform:scaleY(0)}
.acc__item.open .acc__name{color:var(--taupe-deep)}
.acc__panel{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)}
.acc__panel p{padding:0 6px 30px 54px;color:var(--ink-80);font-size:16.5px;max-width:46em}
.acc__head:hover .acc__name{color:var(--taupe-deep)}

/* ============ TESTIMONIALS ============ */
.test{background:var(--ink);color:var(--ivory);padding:130px 0}
.test .eyebrow{color:var(--taupe)}
.test .eyebrow::before{background:var(--taupe)}
.test__title{font-size:clamp(36px,4.6vw,62px);color:var(--ivory);margin:22px 0 64px;max-width:14em}
.test__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tcard{
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);
  border-radius:18px;padding:34px 32px;display:flex;flex-direction:column;gap:22px;
  transition:transform .5s var(--ease),background .5s var(--ease);
}
.tcard:hover{transform:translateY(-8px);background:rgba(255,255,255,.07)}
.tcard__quote{font-family:var(--serif);font-size:21px;line-height:1.4;color:var(--ivory)}
.tcard__stars{color:var(--taupe);letter-spacing:3px;font-size:15px}
.tcard__who{display:flex;align-items:center;gap:14px;margin-top:auto}
.tcard__who img{width:50px;height:50px;border-radius:50%;object-fit:cover}
.tcard__who b{font-weight:600;font-size:15px}
.tcard__who span{display:block;font-size:13px;color:rgba(247,242,232,.6)}

/* ============ CONTACT ============ */
.contact{padding:130px 0}
.contact__layout{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center}
.contact__title{font-size:clamp(38px,4.8vw,64px);margin:22px 0 22px}
.contact__intro p{font-size:18px;color:var(--ink-80);max-width:24em;margin-bottom:34px}
.contact__socials{display:flex;gap:14px}
.contact__socials a{
  width:48px;height:48px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;transition:.35s var(--ease);
}
.contact__socials a:hover{background:var(--ink);color:var(--ivory);transform:translateY(-3px)}
.contact__socials svg{width:20px;height:20px}
.form{background:var(--white);border:1px solid var(--line);border-radius:22px;padding:40px;box-shadow:0 30px 70px -45px rgba(40,32,20,.4)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{position:relative;margin-bottom:18px}
.field label{position:absolute;left:16px;top:15px;color:var(--ink-60);font-size:15px;pointer-events:none;transition:.25s var(--ease)}
.field input,.field textarea{
  width:100%;border:1px solid var(--line);background:var(--ivory);border-radius:12px;
  padding:15px 16px;font-family:var(--sans);font-size:15px;color:var(--ink);transition:border .3s,background .3s;
}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--taupe);background:var(--white)}
.field input:focus+label,.field textarea:focus+label,
.field input:not(:placeholder-shown)+label,.field textarea:not(:placeholder-shown)+label{
  top:-9px;left:12px;font-size:11.5px;background:var(--white);padding:0 6px;color:var(--taupe-deep);letter-spacing:.04em;
}
.form .btn--dark{width:100%;justify-content:center;margin-top:6px}
.form__note{font-size:12px;color:var(--ink-60);margin-top:16px;line-height:1.5}
.form__note a{text-decoration:underline}

/* ============ FOOTER ============ */
.foot{background:var(--cream);border-top:1px solid var(--line);padding:64px 0 40px}
.foot__top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;margin-bottom:48px}
.foot__logo{height:46px;filter:brightness(0)}
.foot__tag{font-family:var(--serif);font-size:26px;max-width:12em;line-height:1.15}
.foot__nav{display:flex;gap:30px;flex-wrap:wrap}
.foot__nav a{font-size:14.5px;color:var(--ink-80);transition:color .3s}
.foot__nav a:hover{color:var(--taupe-deep)}
.foot__bottom{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:26px;font-size:13px;color:var(--ink-60);flex-wrap:wrap;gap:10px}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:48px}
  .hero__media{max-width:460px;margin:0 auto}
  .intro__statements{grid-template-columns:1fr}
  .features__grid{grid-template-columns:repeat(2,1fr)}
  .feat__body p{opacity:.92;max-height:120px}
  .services__layout{grid-template-columns:1fr;gap:40px}
  .services__intro{position:static}
  .test__grid{grid-template-columns:1fr}
  .contact__layout{grid-template-columns:1fr;gap:48px}
}
@media(max-width:640px){
  .wrap{padding:0 22px}
  .nav{padding:16px 22px}
  .nav.scrolled{padding:12px 22px}
  .nav__links{display:none}
  .nav__burger{display:flex}
  .features__grid{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .hero{padding:128px 0 70px}
  .hero__badge{left:0}
}
