/* ─── Reset ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
ul{list-style:none}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ─── Variables ───────────────────────────────────────────────── */
:root{
  --clr-primary:#d1b64a;
  --clr-dark:#0d0d0d;
  --clr-light:#f9f9f9;
  --clr-grey:#777;
  --radius-lg:1.25rem;
  --radius-md:.75rem;
  --shadow:0 8px 16px rgba(0,0,0,.08);
  --font-head:'Poppins',sans-serif;
  --font-body:'Inter',sans-serif;
}

/* ─── Global Styles ───────────────────────────────────────────── */
body{
  font-family:var(--font-body);
  color:var(--clr-dark);
  background:var(--clr-light);
  line-height:1.6;
  scroll-behavior:smooth;
  overflow-x:hidden!important;
}
.container{width:min(90%,1200px);margin-inline:auto}
.section__title{
  font-family:var(--font-head);
  font-size:clamp(1.75rem,4vw,2.25rem);
  text-align:center;
  margin-bottom:1rem;
}
.section__subtitle{
  text-align:center;
  max-width:55ch;
  margin-inline:auto;
  color:var(--clr-grey);
  margin-bottom:2rem;
}

/* Buttons (centered labels) */
.btn,.pill{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.85rem 2.2rem;border-radius:50px;font-weight:600;line-height:1;
  white-space:nowrap;transition:transform .2s, background .2s, color .2s;
}
.btn{background:var(--clr-primary);color:#fff}
.btn:hover{transform:translateY(-3px)}
.btn--sm{padding:.6rem 1.3rem;font-size:.9rem}
.pill{border:1px solid var(--clr-dark);color:inherit;background:transparent;padding:.6rem 1.3rem}
.pill:hover{background:var(--clr-dark);color:#fff;transform:translateY(-2px)}

/* Focus styles */
a:focus-visible,button:focus-visible,.btn:focus-visible,
.swiper-button-next:focus-visible,.swiper-button-prev:focus-visible{outline:3px solid var(--clr-primary);outline-offset:2px}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ─── Header ──────────────────────────────────────────────────── */
.header{position:sticky;top:0;z-index:1000;backdrop-filter:blur(6px);background:rgba(255,255,255,.85);box-shadow:0 1px 4px rgba(0,0,0,.05)}
.header__bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0}
.brand{display:flex;align-items:center;font-weight:600;gap:.55rem}
.brand__svg{flex:0 0 auto}
.nav__links{display:flex;gap:2rem;font-weight:500}
.nav__links a.active,.nav__links a[aria-current="page"]{color:var(--clr-primary)}
#hamburger{display:none;background:none;border:0;flex-direction:column;gap:.25rem}
#hamburger .bar{width:22px;height:2px;background:var(--clr-dark)}
@media(max-width:768px){
  .nav__links{position:fixed;inset:0 0 0 40%;background:var(--clr-light);flex-direction:column;padding:7rem 2rem;transform:translateX(100%);transition:transform .3s}
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:1.125rem;line-height:1.9}
  #hamburger{display:flex}
}

/* ─── Hero (split layout) ────────────────────────────────────── */
.hero{position:relative;min-height:70vh;display:flex;flex-direction:column;justify-content:center;padding-block:2rem 3rem}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(#fff0,#fff)}
.hero__bg{position:absolute;inset:0;background:url("../assets/images/bg.png") center/cover no-repeat;z-index:-1}
.hero--split .hero__grid{display:grid;gap:2.5rem}
.hero__grid--two{grid-template-columns:repeat(12,1fr);align-items:center}
.hero__copy{grid-column:span 7}
.hero__visual{grid-column:span 5;display:flex;justify-content:center}
.hero__title{font-family:var(--font-head);font-size:clamp(2.6rem,6vw,3.5rem);line-height:1.08;margin-bottom:.6rem}
.hero__title .accent{color:var(--clr-primary)}
.hero__mission{font-size:clamp(1rem,2.2vw,1.15rem);color:#333;margin-bottom:1rem}
.hero__bullets{color:var(--clr-grey);margin:0 0 1.25rem 0}
.hero__bullets li{position:relative;padding-left:1.25rem;margin:.25rem 0}
.hero__bullets li::before{content:"•";position:absolute;left:0;top:0;color:var(--clr-primary);font-weight:700}
.hero__cta{display:flex;gap:.75rem;flex-wrap:wrap}
.hero__image{max-width:420px;width:100%;height:auto;object-fit:cover;border-radius:1.25rem;box-shadow:var(--shadow)}
@media(max-width:992px){.hero__copy{grid-column:1/-1}.hero__visual{grid-column:1/-1}.hero__image{max-width:520px;margin-inline:auto}}

/* ─── About ──────────────────────────────────────────────────── */
.about{padding-block:3rem 3.5rem}
.about__grid{display:grid;gap:2rem}
.about__intro .section__title{margin-bottom:.5rem}
.about__intro .section__subtitle{margin-bottom:1.5rem}
.about__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.about-card{border-radius:var(--radius-lg);background:linear-gradient(180deg,#d9d9d9 0%, #ffc89a 100%);box-shadow:var(--shadow);padding:1.5rem 1.25rem 1.6rem}
.about-card__icon{font-size:1.35rem;line-height:1;margin-bottom:.4rem}
.about-card h3{font-family:var(--font-head);font-size:1.1rem;margin-bottom:.35rem}
.about-card p{color:var(--clr-dark);max-width:45ch}

/* ─── Portfolio teaser (carousel) ────────────────────────────── */
.portfolio{padding-block:2.25rem}
.portfolio__slide{display:flex;flex-direction:column;align-items:center;justify-content:center;filter:blur(4px);opacity:.4;transition:filter .3s,opacity .3s}
.swiper-slide-active{filter:blur(0);opacity:1}
/* Captions below images (no overlap) */
.portfolio__caption{position:static!important;margin-top:.75rem;font-family:var(--font-head);font-weight:600;font-size:1rem;color:var(--clr-dark);text-align:center;opacity:.35;transform:none!important}
.swiper-slide-active .portfolio__caption{opacity:1}
.portfolio-swiper{margin-bottom:3.5rem}

/* ─── Services ───────────────────────────────────────────────── */
.services{padding-block:4rem}
.service-card{border-radius:var(--radius-lg);background:linear-gradient(180deg,#d9d9d9 0%,#ffc89a 100%);box-shadow:var(--shadow);padding:2.2rem 2rem;overflow:hidden}
.service-card__grid{display:grid;gap:1.5rem 2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:center}
.service__text h3{font-size:clamp(1.35rem,3.6vw,1.8rem);font-family:var(--font-head);margin-bottom:.4rem}
.service__text p{max-width:48ch;color:var(--clr-grey);margin-bottom:.6rem}
.service-card__deliverables{margin:.4rem 0 0 0;padding:0;color:var(--clr-grey)}
.service-card__deliverables li{margin:.25rem 0;padding-left:1.1rem;position:relative}
.service-card__deliverables li::before{content:"✔";position:absolute;left:0;top:0;color:var(--clr-primary);font-weight:700}
.service__img img{border-radius:0;box-shadow:none;background:none;width:100%;height:auto;object-fit:cover}
.services-swiper{overflow:visible}
.services-swiper .swiper-pagination{bottom:-25px}

/* ─── Testimonials ───────────────────────────────────────────── */
.details{padding-block:3.25rem}
.rating-summary{display:flex;gap:.75rem;align-items:center;justify-content:center;margin:0 auto 1.25rem auto;text-align:center}
.rating-summary .stars{letter-spacing:.15rem;font-size:1.2rem}
.rating-summary__text{color:var(--clr-grey)}
.review-card{max-width:820px;margin-inline:auto;padding:1.25rem 1.25rem 1.5rem;border-radius:var(--radius-lg);background:linear-gradient(180deg,#d9d9d9 0%,#ffc89a 100%);box-shadow:var(--shadow)}
.review-figure{display:grid;gap:1rem;grid-template-columns:1fr}
.review-figure img{width:100%;height:auto;object-fit:contain;border-radius:.5rem;background:#fff;box-shadow:0 4px 10px rgba(0,0,0,.06)}
.review-figure figcaption{text-align:left}
.reviewer{font-family:var(--font-head);font-size:1.05rem;margin-bottom:.25rem}
.quote{color:var(--clr-dark);margin-bottom:.5rem}
.rating{display:flex;gap:.25rem}
.star::before{content:"★";font-size:1.1rem;color:#ddd}
.star.filled::before{color:var(--clr-primary)}
.testimonials-swiper{overflow:visible}
.testimonials-swiper .swiper-pagination{bottom:-25px}

.portfolio-card{
    width:30%;
}
.portfolio-card{border-radius:var(--radius-lg);background:linear-gradient(180deg,#d9d9d9 0%, #ffc89a 100%);box-shadow:var(--shadow);padding:1.5rem 1.25rem 1.6rem}
.about-card h3{font-family:var(--font-head);font-size:1.1rem;margin-bottom:.35rem}
.about-card p{color:var(--clr-dark);max-width:45ch}
/* ─── Footer / CTA ──────────────────────────────────────────── */
.footer{padding-block:4rem 2rem;background:#f1f1f1;text-align:center}
.footer__content>h3{font-family:var(--font-head);font-size:clamp(1.5rem,4vw,2rem);margin-bottom:1rem}
.footer__content p{max-width:55ch;margin-inline:auto;color:var(--clr-grey);margin-bottom:2rem}
.footer__bar{display:flex;justify-content:center;gap:1rem;align-items:center;flex-wrap:wrap;color:var(--clr-grey);font-size:.875rem}

/* Footer: refined stack + SVG icons + sitenav */
.footer__bar--stack{display:grid;gap:.9rem;justify-items:center;margin-top:1.25rem}
.footer__brandline{display:flex;align-items:center;gap:.5rem;color:var(--clr-grey)}
.footer__tagline{color:#333;font-weight:600}
.footer__social{display:flex;gap:.75rem;align-items:center;justify-content:center}
.social__icon{display:inline-flex;padding:.4rem;border-radius:.65rem;transition:transform .15s,color .2s,background .2s}
.social__icon svg{display:block}
.social__icon:hover{transform:translateY(-2px);color:var(--clr-primary);background:#fff}
.footer__sitenav{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.footer__sitenav a{font-weight:600;color:#444}
.footer__sitenav a:hover{color:var(--clr-primary)}

/* Alt contact chips + form status + toast + FAQ */
.contact-alt{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin:1rem auto 1.25rem}
.contact-pill{font-weight:600}
.form-status{margin-top:.5rem;text-align:center;font-size:.95rem;min-height:1.25rem;color:var(--clr-grey)}
.form-status--ok{color:#167c2c}
.form-status--err{color:#b00020}
.toast{position:fixed;left:50%;transform:translateX(-50%) translateY(20px);bottom:24px;background:#111;color:#fff;padding:.75rem 1rem;border-radius:.75rem;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:2000;font-size:.95rem}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast--ok{background:#167c2c}
.toast--err{background:#b00020}
.faq{margin:1.75rem auto 0;max-width:720px}
.faq__title{text-align:center;font-family:var(--font-head);margin-bottom:.75rem}
.faq__item{background:#fff;border-radius:.75rem;margin:.5rem 0;padding:.6rem .9rem;box-shadow:var(--shadow)}
.faq__item summary{cursor:pointer;font-weight:600}
.faq__content{color:var(--clr-grey);margin-top:.4rem}

/* Utilities */
.hidden{display:none}

/* Footer form */
.footer__form{display:flex;flex-direction:column;gap:1rem;max-width:500px;margin:2.5rem auto}
.footer__form input,.footer__form textarea{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;font:inherit;resize:vertical}

/* Responsive tweaks */
@media(max-width:480px){.footer__form .btn{width:100%;text-align:center}}
@media(max-width:576px){
  .hero__bg{background-size:cover;background-position:center 35%}
  .service-card__grid{grid-template-columns:1fr}
}

