/* =========================================================
   DENTORA — Diş Klinikası
   Design system, layout, components & animations
   ========================================================= */
.no-js .reveal,
.no-js .reveal-left,
.no-js .reveal-right,
.no-js .reveal-scale{opacity:1;transform:none}
/* ---------- Tokens ---------- */
:root{
  --ink:#0B2B2E;
  --ink-soft:#3C5755;
  --teal:#13B9A6;
  --teal-deep:#0C8576;
  --teal-50:#E7F6F3;
  --mist:#EAF6F3;
  --bg:#F4FAF8;
  --coral:#FF7A59;
  --coral-soft:#FFE7DE;
  --sand:#FFF6F0;
  --white:#FFFFFF;
  --line:rgba(11,43,46,.09);

  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Plus Jakarta Sans', system-ui, sans-serif;

  --r-sm:14px; --r:22px; --r-lg:32px; --r-xl:44px; --r-pill:999px;

  --shadow-sm:0 2px 12px rgba(11,43,46,.05);
  --shadow:0 22px 60px -26px rgba(11,43,46,.22);
  --shadow-teal:0 24px 54px -20px rgba(19,185,166,.5);
  --shadow-coral:0 24px 54px -20px rgba(255,122,89,.45);

  --container:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::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);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
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}
input,textarea,select{font-family:inherit;font-size:inherit}
::selection{background:var(--teal);color:#fff}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.08;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.6rem,6vw,4.6rem);font-optical-sizing:auto}
h2{font-size:clamp(2rem,4.4vw,3.3rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.8rem)}
.display-italic{font-style:italic;color:var(--teal-deep)}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-body);font-weight:700;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--teal-deep);
}
.eyebrow::before{
  content:"";width:26px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--teal),var(--coral));
}
.eyebrow.center::before{display:none}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:54ch}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
.section{padding:clamp(70px,9vw,128px) 0}
.section-tight{padding:clamp(48px,6vw,80px) 0}
.section-head{max-width:680px;margin-bottom:clamp(36px,5vw,60px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .lead{margin-top:1rem}
.grid{display:grid;gap:26px}
.split{display:grid;gap:clamp(36px,5vw,72px);align-items:center}
@media(min-width:860px){.split{grid-template-columns:1fr 1fr}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:.95rem 1.7rem;border-radius:var(--r-pill);
  font-weight:700;font-size:.97rem;letter-spacing:.01em;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  will-change:transform;
}
.btn svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow-teal)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 30px 60px -18px rgba(19,185,166,.6);background:var(--teal-deep)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.btn-ghost{background:var(--white);color:var(--ink);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.btn-ghost:hover{transform:translateY(-3px);box-shadow:var(--shadow);color:var(--teal-deep)}
.btn-coral{background:var(--coral);color:#fff;box-shadow:var(--shadow-coral)}
.btn-coral:hover{transform:translateY(-3px)}
.link-arrow{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--teal-deep)}
.link-arrow svg{width:16px;transition:transform .3s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* ---------- Header ---------- */
.header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  padding:18px 0;transition:padding .4s var(--ease),background .4s,box-shadow .4s;
  background-color: #f0fffe !important;
}
.header.scrolled{padding:10px 0;background:rgba(244,250,248,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-size:1.5rem;font-weight:600;letter-spacing:-.02em}
.brand-mark{width:38px;height:38px;display:grid;place-items:center;border-radius:12px;background:var(--teal);box-shadow:var(--shadow-teal)}
.brand-mark svg{width:22px;height:22px}
.brand b{color:var(--teal-deep);font-weight:600}
.nav-links{display:none;align-items:center;gap:6px}
@media(min-width:980px){.nav-links{display:flex}}
.nav-links a{
  position:relative;padding:.5rem .9rem;border-radius:var(--r-pill);
  font-weight:600;font-size:.95rem;color:var(--ink-soft);transition:color .25s,background .25s;
}
.nav-links a::after{
  content:"";position:absolute;left:50%;bottom:6px;width:0;height:2px;border-radius:2px;
  background:var(--teal);transform:translateX(-50%);transition:width .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:18px}
.nav-cta{display:none}
@media(min-width:980px){.nav-cta{display:inline-flex}}
.burger{display:grid;gap:5px;padding:10px;border-radius:12px;background:var(--white);box-shadow:var(--shadow-sm)}
@media(min-width:980px){.burger{display:none}}
.burger span{width:22px;height:2px;border-radius:2px;background:var(--ink);transition:.3s var(--ease)}
body.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:99;
  background:var(--bg);
  display:flex;flex-direction:column;justify-content:center;gap:8px;
  padding:90px 32px 40px;
  transform:translateX(100%);transition:transform .5s var(--ease);
}
body.nav-open .mobile-menu{transform:translateX(0)}
.mobile-menu a{
  font-family:var(--font-display);font-size:2rem;font-weight:500;
  padding:.4rem 0;color:var(--ink);opacity:0;transform:translateX(20px);
  transition:opacity .4s,transform .4s;
}
body.nav-open .mobile-menu a{opacity:1;transform:translateX(0)}
body.nav-open .mobile-menu a:nth-child(1){transition-delay:.12s}
body.nav-open .mobile-menu a:nth-child(2){transition-delay:.18s}
body.nav-open .mobile-menu a:nth-child(3){transition-delay:.24s}
body.nav-open .mobile-menu a:nth-child(4){transition-delay:.30s}
body.nav-open .mobile-menu a:nth-child(5){transition-delay:.36s}
.mobile-menu .btn{margin-top:18px;align-self:flex-start;opacity:0;transition:opacity .4s .42s}
body.nav-open .mobile-menu .btn{opacity:1}

/* ---------- Decorative blobs ---------- */
.blob{position:absolute;border-radius:50%;filter:blur(48px);opacity:.5;pointer-events:none;z-index:0}
.blob-teal{background:radial-gradient(circle,rgba(19,185,166,.7),transparent 70%)}
.blob-coral{background:radial-gradient(circle,rgba(255,122,89,.55),transparent 70%)}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(18px,-26px) scale(1.06)}}
.float-anim{animation:float 9s ease-in-out infinite}
.float-slow{animation:float 13s ease-in-out infinite}

/* ---------- Hero ---------- */
.hero{position:relative;padding:150px 0 90px;overflow:hidden}
.hero-grid{display:grid;gap:48px;align-items:center;position:relative;z-index:2}
@media(min-width:920px){.hero-grid{grid-template-columns:1.05fr .95fr}}
.hero-pill{
  display:inline-flex;align-items:center;gap:.6rem;margin-bottom:22px;
  padding:.5rem .9rem .5rem .5rem;border-radius:var(--r-pill);
  background:var(--white);box-shadow:var(--shadow-sm);font-weight:600;font-size:.85rem;
}
.hero-pill .dot{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--coral-soft)}
.hero-pill .dot span{width:8px;height:8px;border-radius:50%;background:var(--coral)}
.hero h1{margin-bottom:1.3rem}
.hero .lead{margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:2.6rem}
.hero-trust{display:flex;align-items:center;gap:18px}
.avatars{display:flex}
.avatars img{width:46px;height:46px;border-radius:50%;border:3px solid var(--bg);object-fit:cover;margin-left:-14px}
.avatars img:first-child{margin-left:0}
.hero-trust .num{font-family:var(--font-display);font-size:1.4rem;font-weight:600}
.hero-trust small{display:block;color:var(--ink-soft);font-size:.82rem}

/* Hero visual */
.hero-visual{position:relative}
.hero-photo{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:4/4.4;background:var(--mist);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-card{
  position:absolute;background:var(--white);border-radius:var(--r);
  box-shadow:var(--shadow);padding:14px 18px;display:flex;align-items:center;gap:12px;z-index:3;
}
.hero-card .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none}
.hero-card b{display:block;font-size:.95rem}
.hero-card small{color:var(--ink-soft);font-size:.78rem}
.hero-card.tl{top:24px;left:-22px}
.hero-card.br{bottom:30px;right:-18px}
@media(max-width:520px){.hero-card.tl{left:6px}.hero-card.br{right:6px}}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;padding:26px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:60px;width:max-content;animation:scrollx 26s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(-50%)}}
.marquee-item{display:flex;align-items:center;gap:.7rem;font-weight:700;color:var(--ink-soft);white-space:nowrap;font-size:1.05rem}
.marquee-item svg{width:22px;height:22px;color:var(--teal)}

/* ---------- Feature cards ---------- */
.feature-grid{display:grid;gap:24px}
@media(min-width:680px){.feature-grid{grid-template-columns:repeat(3,1fr)}}
.feature{
  background:var(--white);border-radius:var(--r-lg);padding:34px 28px;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);position:relative;overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.feature::after{content:"";position:absolute;inset:auto -40% -60% auto;width:160px;height:160px;border-radius:50%;background:var(--teal-50);transition:transform .5s var(--ease);z-index:0}
.feature:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.feature:hover::after{transform:scale(1.6)}
.feature>*{position:relative;z-index:1}
.feature .ico{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:20px;background:var(--mist)}
.feature .ico svg{width:28px;height:28px;color:var(--teal-deep)}
.feature h3{margin-bottom:.5rem}
.feature p{color:var(--ink-soft);font-size:.97rem}

/* ---------- Stats band ---------- */
.stats{display:grid;gap:24px;text-align:center}
@media(min-width:640px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat .num{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.4rem);font-weight:600;line-height:1;color:var(--teal-deep)}
.stat .num span{color:var(--coral)}
.stat p{margin-top:.5rem;color:var(--ink-soft);font-size:.95rem}

/* ---------- Services list ---------- */
.svc-grid{display:grid;gap:24px}
@media(min-width:720px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.svc-grid.three{grid-template-columns:repeat(3,1fr)}}
.svc-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--white);
  box-shadow:var(--shadow-sm);border:1px solid var(--line);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.svc-card .num{position:absolute;top:18px;right:22px;font-family:var(--font-display);font-size:1.1rem;color:var(--teal-deep);opacity:.6;z-index:2}
.svc-media{height:200px;overflow:hidden;background:var(--mist)}
.svc-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.svc-card:hover .svc-media img{transform:scale(1.08)}
.svc-body{padding:26px 26px 30px}
.svc-body .ico{width:50px;height:50px;border-radius:14px;background:var(--teal-50);display:grid;place-items:center;margin:-50px 0 16px;position:relative;z-index:2;box-shadow:var(--shadow-sm)}
.svc-body .ico svg{width:26px;height:26px;color:var(--teal-deep)}
.svc-body h3{margin-bottom:.55rem}
.svc-body p{color:var(--ink-soft);font-size:.96rem;margin-bottom:1.1rem}

/* ---------- Split visual blocks ---------- */
.visual-stack{position:relative}
.visual-stack img{border-radius:var(--r-lg);box-shadow:var(--shadow);width:100%}
.checklist{display:grid;gap:14px;margin:1.6rem 0}
.checklist li{display:flex;align-items:flex-start;gap:.8rem;font-weight:500}
.checklist .tick{flex:none;width:26px;height:26px;border-radius:50%;background:var(--teal-50);display:grid;place-items:center;margin-top:1px}
.checklist .tick svg{width:15px;color:var(--teal-deep)}

/* ---------- Steps / process ---------- */
.steps{display:grid;gap:22px}
@media(min-width:780px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{position:relative;padding-top:14px}
.step .idx{
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-display);font-size:1.3rem;color:#fff;background:var(--teal);
  box-shadow:var(--shadow-teal);margin-bottom:18px;
}
.step:nth-child(2) .idx{background:var(--coral);box-shadow:var(--shadow-coral)}
.step:nth-child(3) .idx{background:var(--ink)}
.step h3{font-size:1.2rem;margin-bottom:.45rem}
.step p{color:var(--ink-soft);font-size:.94rem}

/* ---------- Testimonials ---------- */
.testi{position:relative;overflow:hidden}
.testi-track{display:flex;transition:transform .6s var(--ease)}
.testi-slide{flex:0 0 100%;padding:6px}
.testi-card{
  background:var(--white);border-radius:var(--r-lg);padding:clamp(30px,4vw,52px);
  box-shadow:var(--shadow);border:1px solid var(--line);position:relative;
}
.testi-card .quote-mark{font-family:var(--font-display);font-size:5rem;line-height:.6;color:var(--teal-50);position:absolute;top:30px;right:36px}
.stars{display:flex;gap:4px;margin-bottom:1.2rem}
.stars svg{width:20px;height:20px;color:var(--coral)}
.testi-card blockquote{font-family:var(--font-display);font-size:clamp(1.2rem,2.5vw,1.7rem);font-weight:400;line-height:1.4;margin-bottom:1.8rem}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-author img{width:54px;height:54px;border-radius:50%;object-fit:cover}
.testi-author b{display:block}
.testi-author small{color:var(--ink-soft)}
.testi-nav{display:flex;gap:10px;justify-content:center;margin-top:28px}
.testi-dot{width:10px;height:10px;border-radius:50%;background:var(--line);transition:.3s var(--ease)}
.testi-dot.active{background:var(--teal);width:28px;border-radius:5px}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:clamp(44px,6vw,80px);background:var(--ink);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.8);max-width:52ch;margin:1rem auto 2rem}
.cta-band .btn-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-band .blob{opacity:.6}

/* ---------- Blog ---------- */
.blog-grid{display:grid;gap:28px}
@media(min-width:720px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.post{
  background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);display:flex;flex-direction:column;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.post:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.post-media{height:210px;overflow:hidden;position:relative;background:var(--mist)}
.post-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.post:hover .post-media img{transform:scale(1.07)}
.post-tag{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);color:var(--teal-deep);font-weight:700;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;padding:.35rem .8rem;border-radius:var(--r-pill)}
.post-body{padding:26px;display:flex;flex-direction:column;flex:1}
.post-meta{display:flex;gap:14px;color:var(--ink-soft);font-size:.82rem;margin-bottom:.7rem}
.post-body h3{font-size:1.3rem;margin-bottom:.6rem;line-height:1.2}
.post-body p{color:var(--ink-soft);font-size:.95rem;margin-bottom:1.2rem;flex:1}
.post-featured{display:grid;gap:0;border-radius:var(--r-lg);overflow:hidden;background:var(--white);box-shadow:var(--shadow);border:1px solid var(--line)}
@media(min-width:860px){.post-featured{grid-template-columns:1.1fr 1fr}}
.post-featured .post-media{height:100%;min-height:300px}
.post-featured .post-body{padding:clamp(30px,4vw,52px);justify-content:center}
.post-featured h3{font-size:clamp(1.6rem,3vw,2.2rem)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;overflow:hidden;padding:160px 0 70px;text-align:center}
.page-hero .lead{margin:1.2rem auto 0}
.breadcrumb{display:flex;gap:.5rem;justify-content:center;align-items:center;color:var(--ink-soft);font-size:.88rem;font-weight:600;margin-bottom:1.2rem}
.breadcrumb a:hover{color:var(--teal-deep)}
.breadcrumb span{color:var(--teal-deep)}

/* ---------- Team ---------- */
.team-grid{display:grid;gap:24px}
@media(min-width:560px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:920px){.team-grid{grid-template-columns:repeat(4,1fr)}}
.member{border-radius:var(--r-lg);overflow:hidden;position:relative;box-shadow:var(--shadow-sm);background:var(--mist)}
.member img{width:100%;aspect-ratio:1/1.15;object-fit:cover;transition:transform .6s var(--ease)}
.member:hover img{transform:scale(1.05)}
.member-info{position:absolute;left:14px;right:14px;bottom:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-radius:var(--r);padding:14px 18px;transform:translateY(8px);opacity:.96;transition:.4s var(--ease)}
.member:hover .member-info{transform:translateY(0)}
.member-info b{display:block;font-family:var(--font-display);font-size:1.1rem}
.member-info small{color:var(--teal-deep);font-weight:700}

/* ---------- Values ---------- */
.value-grid{display:grid;gap:1px;background:var(--line);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}
@media(min-width:680px){.value-grid{grid-template-columns:repeat(2,1fr)}}
.value{background:var(--white);padding:34px 30px;transition:background .3s}
.value:hover{background:var(--mist)}
.value .ico{width:48px;height:48px;border-radius:14px;background:var(--teal-50);display:grid;place-items:center;margin-bottom:16px}
.value .ico svg{width:24px;color:var(--teal-deep)}
.value h3{font-size:1.25rem;margin-bottom:.5rem}
.value p{color:var(--ink-soft);font-size:.95rem}

/* ---------- Pricing ---------- */
.price-grid{display:grid;gap:24px}
@media(min-width:720px){.price-grid{grid-template-columns:repeat(2,1fr)}}
.price-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 0;border-bottom:1px dashed var(--line)}
.price-row:last-child{border-bottom:none}
.price-row .pname b{display:block;font-family:var(--font-display);font-size:1.15rem}
.price-row .pname small{color:var(--ink-soft);font-size:.85rem}
.price-row .pval{font-family:var(--font-display);font-size:1.3rem;color:var(--teal-deep);white-space:nowrap}
.price-card{background:var(--white);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.price-card h3{margin-bottom:1rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin-inline:auto;display:grid;gap:14px}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .3s}
.faq-item.open{box-shadow:var(--shadow)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 26px;font-weight:700;font-size:1.05rem;width:100%;text-align:left;color:var(--ink)}
.faq-q .plus{flex:none;width:30px;height:30px;border-radius:50%;background:var(--teal-50);display:grid;place-items:center;position:relative;transition:background .3s}
.faq-item.open .faq-q .plus{background:var(--teal)}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--teal-deep);border-radius:2px;transition:.3s var(--ease)}
.faq-q .plus::before{width:13px;height:2px}
.faq-q .plus::after{width:2px;height:13px}
.faq-item.open .faq-q .plus::before,.faq-item.open .faq-q .plus::after{background:#fff}
.faq-item.open .faq-q .plus::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding:0 26px 24px;color:var(--ink-soft)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;gap:36px}
@media(min-width:920px){.contact-grid{grid-template-columns:1fr 1.15fr}}
.contact-info{display:grid;gap:18px}
.info-card{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease)}
.info-card:hover{transform:translateX(6px)}
.info-card .ico{flex:none;width:48px;height:48px;border-radius:14px;background:var(--teal-50);display:grid;place-items:center}
.info-card .ico svg{width:24px;color:var(--teal-deep)}
.info-card b{display:block;font-family:var(--font-display);font-size:1.1rem;margin-bottom:.2rem}
.info-card p,.info-card a{color:var(--ink-soft);font-size:.95rem}

.form{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,4vw,42px);box-shadow:var(--shadow)}
.form-row{display:grid;gap:18px}
@media(min-width:560px){.form-row.two{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:.45rem;margin-bottom:18px}
.field label{font-weight:700;font-size:.88rem}
.field input,.field textarea,.field select{
  padding:.9rem 1.1rem;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--bg);color:var(--ink);transition:border-color .25s,box-shadow .25s,background .25s;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(19,185,166,.13);
}
.form-note{margin-top:14px;font-size:.85rem;color:var(--ink-soft);text-align:center}
.form-success{display:none;align-items:center;gap:12px;background:var(--teal-50);color:var(--teal-deep);font-weight:700;padding:14px 18px;border-radius:var(--r-sm);margin-bottom:18px}
.form-success.show{display:flex}
.form-success svg{width:22px;flex:none}

/* map embed */
.map-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);height:380px}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.02)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#fff;margin-top:0;position:relative;overflow:hidden}
.footer-top{display:grid;gap:40px;padding:clamp(56px,7vw,90px) 0 50px;position:relative;z-index:2}
@media(min-width:860px){.footer-top{grid-template-columns:1.4fr 1fr 1fr 1.3fr}}
.footer .brand{color:#fff;margin-bottom:18px}
.footer .brand b{color:#fff}
.footer-about p{color:rgba(255,255,255,.66);font-size:.95rem;max-width:36ch;margin-bottom:20px}
.socials{display:flex;gap:10px}
.socials a{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.08);transition:.3s var(--ease)}
.socials a:hover{background:var(--teal);transform:translateY(-4px)}
.socials svg{width:19px;color:#fff}
.footer h4{font-family:var(--font-body);font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px}
.footer-links{display:grid;gap:12px}
.footer-links a{color:rgba(255,255,255,.78);font-size:.97rem;transition:color .25s,padding .25s}
.footer-links a:hover{color:#fff;padding-left:5px}
.footer-news p{color:rgba(255,255,255,.66);font-size:.95rem;margin-bottom:16px}
.news-form{display:flex;gap:8px;background:rgba(255,255,255,.08);border-radius:var(--r-pill);padding:6px}
.news-form input{flex:1;background:none;border:none;color:#fff;padding:.6rem 1rem}
.news-form input::placeholder{color:rgba(255,255,255,.5)}
.news-form input:focus{outline:none}
.news-form button{flex:none;width:46px;height:46px;border-radius:50%;background:var(--teal);display:grid;place-items:center;transition:.3s var(--ease)}
.news-form button:hover{background:var(--coral);transform:rotate(-10deg)}
.news-form button svg{width:18px;color:#fff}
.footer-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding:24px 0;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.55);font-size:.88rem;position:relative;z-index:2}

/* ---------- Reveal animations ---------- */
/*.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}*/
/*.reveal.in{opacity:1;transform:none}*/
/*.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}*/
/*.reveal-left.in{opacity:1;transform:none}*/
/*.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}*/
/*.reveal-right.in{opacity:1;transform:none}*/
/*.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .8s var(--ease),transform .8s var(--ease)}*/
/*.reveal-scale.in{opacity:1;transform:none}*/
/*[data-delay="1"]{transition-delay:.08s}*/
/*[data-delay="2"]{transition-delay:.16s}*/
/*[data-delay="3"]{transition-delay:.24s}*/
/*[data-delay="4"]{transition-delay:.32s}*/
/*[data-delay="5"]{transition-delay:.4s}*/

/* hero load stagger */
.hero-load{opacity:0;transform:translateY(26px);animation:heroIn .9s var(--ease) forwards}
.hero-load.d1{animation-delay:.15s}
.hero-load.d2{animation-delay:.30s}
.hero-load.d3{animation-delay:.45s}
.hero-load.d4{animation-delay:.60s}
.hero-load.d5{animation-delay:.75s}
@keyframes heroIn{to{opacity:1;transform:none}}

/* utilities */
.text-center{text-align:center}
.mt-sm{margin-top:1rem}.mt-md{margin-top:2rem}
.tag{display:inline-block;padding:.35rem .9rem;border-radius:var(--r-pill);background:var(--coral-soft);color:var(--coral);font-weight:700;font-size:.78rem}
.bg-mist{background:var(--mist)}
.rounded-section{border-radius:var(--r-xl)}

/* progress bar */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--teal),var(--coral));z-index:200;transition:width .1s linear}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal,.reveal-left,.reveal-right,.reveal-scale,.hero-load{opacity:1!important;transform:none!important}
}
