/* =========================================================
   RANGOLI STATIONERY — Custom site stylesheet
   Unique design: warm cream canvas, rangoli-inspired pattern
   accents, asymmetric layouts, soft organic shapes.
   ========================================================= */

:root{
  --ink:         #1a1a2e;
  --ink-soft:    #2d2d44;
  --cream:       #fff9f0;
  --cream-deep:  #faf2e3;
  --coral:       #ff6b6b;
  --teal:        #4ecdc4;
  --sun:         #ffd93d;
  --violet:      #6c5ce7;
  --rose:        #fd79a8;
  --leaf:        #00b894;
  --orange:      #e17055;
  --sky:         #0984e3;
  --grad:        linear-gradient(120deg,#ff6b6b 0%,#ffd93d 35%,#4ecdc4 70%,#6c5ce7 100%);
  --grad-warm:   linear-gradient(120deg,#ff6b6b,#ffd93d);
  --radius:      20px;
  --radius-sm:   12px;
  --radius-lg:   32px;
  --shadow-sm:   0 4px 16px rgba(26,26,46,.06);
  --shadow-md:   0 14px 40px rgba(26,26,46,.1);
  --shadow-lg:   0 30px 70px rgba(26,26,46,.15);
  --font-sans:   'Inter', system-ui, -apple-system, sans-serif;
  --font-serif:  'Fraunces', Georgia, serif;
  --container:   1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:16px;
  overflow-x:hidden;
  /* subtle dotted background inspired by rangoli patterns */
  background-image:
    radial-gradient(circle at 15% 12%, rgba(255,107,107,.04) 0, transparent 25%),
    radial-gradient(circle at 85% 80%, rgba(78,205,196,.05) 0, transparent 28%),
    radial-gradient(circle at 50% 50%, rgba(255,217,61,.03) 0, transparent 40%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s ease}
button{border:0;background:transparent;cursor:pointer;font:inherit;color:inherit}
input,textarea,select{font:inherit;color:inherit}

h1,h2,h3,h4,h5{font-family:var(--font-serif);font-weight:600;line-height:1.15;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.2rem,5.2vw,4.6rem);font-weight:800}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:700}
h3{font-size:1.3rem}
h4{font-size:1.1rem}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:90px 0;position:relative}

.grad{
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-style:italic;
  font-weight:800;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.8rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;color:var(--ink-soft);
  padding:6px 14px;border:1px solid rgba(26,26,46,.12);
  border-radius:999px;background:rgba(255,255,255,.6);
  backdrop-filter:blur(6px);
  margin-bottom:14px;
}
.dot{width:7px;height:7px;border-radius:50%;background:var(--coral);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}

/* =====================  BUTTONS  ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:999px;font-weight:600;font-size:.95rem;
  transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;
  letter-spacing:.01em;cursor:pointer;
}
.btn--solid{background:var(--ink);color:var(--cream);box-shadow:0 6px 20px rgba(26,26,46,.22)}
.btn--solid:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(26,26,46,.32);background:var(--coral)}
.btn--ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream);transform:translateY(-3px)}
.btn--wide{width:100%;padding:16px}

/* =====================  NAVBAR  ===================== */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,249,240,.85);backdrop-filter:blur(14px);border-bottom:1px solid rgba(26,26,46,.06)}
.nav__wrap{max-width:var(--container);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{
  width:42px;height:42px;position:relative;display:grid;
  grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:3px;
  transform:rotate(45deg);transition:transform .5s ease;
}
.brand:hover .brand__mark{transform:rotate(225deg)}
.brand__mark span{border-radius:50% 20% 50% 20%;display:block}
.brand__mark span:nth-child(1){background:var(--coral)}
.brand__mark span:nth-child(2){background:var(--teal)}
.brand__mark span:nth-child(3){background:var(--sun)}
.brand__mark span:nth-child(4){background:var(--violet)}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__text b{font-family:var(--font-serif);font-weight:800;font-size:1.25rem;letter-spacing:-.01em}
.brand__text i{font-style:normal;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}

.nav__links{display:flex;gap:6px;align-items:center}
.nav__links a{padding:10px 18px;border-radius:999px;font-weight:500;font-size:.95rem;color:var(--ink-soft);position:relative}
.nav__links a:hover{color:var(--ink);background:rgba(26,26,46,.05)}
.nav__links a.active{color:var(--ink);background:var(--cream-deep)}
.nav__links a.active::after{
  content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  width:20px;height:3px;background:var(--grad-warm);border-radius:2px;
}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
.nav-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-open .nav__burger span:nth-child(2){opacity:0}
.nav-open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__links{
    position:fixed;top:74px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--cream);padding:24px;border-top:1px solid rgba(26,26,46,.06);
    transform:translateY(-120%);transition:.4s cubic-bezier(.4,0,.2,1);
  }
  .nav-open .nav__links{transform:translateY(0)}
  .nav__links a{width:100%;padding:14px 18px;border-radius:12px}
}

/* =====================  HERO  ===================== */
.hero{padding:50px 0 0;position:relative;overflow:hidden}
.hero__grid{
  max-width:var(--container);margin:0 auto;padding:40px 24px 80px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;
}
.hero__title{margin:8px 0 24px}
.hero__sub{font-size:1.1rem;color:var(--ink-soft);max-width:520px;margin-bottom:32px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.hero__stats{display:flex;gap:44px;padding-top:28px;border-top:1px dashed rgba(26,26,46,.18)}
.hero__stats div{display:flex;flex-direction:column;gap:4px}
.hero__stats b{font-family:var(--font-serif);font-size:2.2rem;font-weight:700;color:var(--ink)}
.hero__stats span{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}

.hero__visual{position:relative;height:560px;display:flex;align-items:center;justify-content:center}
.hero__blob{
  position:absolute;width:100%;height:100%;
  background:var(--grad);opacity:.85;
  border-radius:58% 42% 50% 50%/50% 56% 44% 50%;
  animation:blob 16s ease-in-out infinite;
  filter:blur(2px);
  box-shadow:0 30px 80px rgba(255,107,107,.25);
}
@keyframes blob{
  0%,100%{border-radius:58% 42% 50% 50%/50% 56% 44% 50%;transform:rotate(0deg)}
  33%{border-radius:42% 58% 60% 40%/55% 45% 55% 45%;transform:rotate(6deg)}
  66%{border-radius:50% 50% 40% 60%/42% 58% 42% 58%;transform:rotate(-4deg)}
}
.hero__img{
  position:absolute;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  object-fit:cover;
}
.hero__img--1{width:280px;height:360px;top:10%;left:8%;animation:float 7s ease-in-out infinite}
.hero__img--2{width:200px;height:200px;bottom:8%;right:4%;animation:float 8s ease-in-out infinite .8s}
.hero__img--3{width:180px;height:220px;top:12%;right:8%;animation:float 9s ease-in-out infinite 1.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

.hero__chip{
  position:absolute;background:#fff;padding:10px 18px;border-radius:999px;
  font-weight:700;font-size:.88rem;box-shadow:var(--shadow-md);
  display:flex;align-items:center;gap:6px;z-index:3;
}
.hero__chip--a{bottom:22%;left:-4%;color:var(--coral);animation:float 6s ease-in-out infinite}
.hero__chip--b{top:50%;right:-2%;color:var(--teal);animation:float 7s ease-in-out infinite 1s}

.hero__marquee{
  background:var(--ink);color:var(--cream);overflow:hidden;padding:22px 0;
  font-family:var(--font-serif);font-size:1.3rem;white-space:nowrap;
  transform:rotate(-1.5deg);margin:0 -40px;position:relative;z-index:2;
}
.marquee__track{display:inline-flex;animation:marquee 35s linear infinite;gap:40px;padding-left:40px}
.marquee__track span{opacity:.8;display:inline-block}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__visual{height:440px}
  .hero__img--1{width:220px;height:280px}
  .hero__img--2{width:150px;height:150px}
  .hero__img--3{width:140px;height:180px}
  .hero__stats{gap:24px}
  .hero__stats b{font-size:1.6rem}
}

/* =====================  PAGE HERO (inner pages)  ===================== */
.page-hero{
  padding:80px 0 100px;position:relative;overflow:hidden;
  background:var(--cream-deep);
  border-bottom:1px solid rgba(26,26,46,.06);
}
.page-hero h1{margin:6px 0 20px}
.page-hero p{max-width:560px;font-size:1.1rem;color:var(--ink-soft)}
.page-hero__shape{
  position:absolute;right:-100px;top:-100px;width:420px;height:420px;
  background:var(--grad);opacity:.15;
  border-radius:50% 30% 60% 40%/40% 60% 30% 70%;
  animation:blob 20s ease-in-out infinite;
  filter:blur(20px);
}

/* =====================  SECTION HEAD  ===================== */
.section__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:30px;margin-bottom:50px;flex-wrap:wrap;
}
.section__head h2{max-width:680px}
.section__lead{max-width:420px;color:var(--ink-soft);font-size:1.02rem}

/* =====================  CATEGORY GRID  ===================== */
.categories{background:var(--cream)}
.cat-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.cat-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:#fff;box-shadow:var(--shadow-sm);
  transition:.4s cubic-bezier(.4,0,.2,1);
  display:block;aspect-ratio:1/1.2;
}
.cat-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.85) 100%);
  z-index:1;transition:.4s;
}
.cat-card::after{
  content:'';position:absolute;top:14px;left:14px;width:30px;height:30px;
  background:var(--c,var(--coral));border-radius:10px 2px 10px 2px;
  z-index:2;transform:rotate(12deg);box-shadow:0 4px 12px rgba(0,0,0,.15);
}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:.6s}
.cat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.cat-card:hover img{transform:scale(1.1)}
.cat-card__body{
  position:absolute;bottom:0;left:0;right:0;z-index:2;padding:22px;color:#fff;
}
.cat-card__body h3{color:#fff;margin-bottom:4px;font-size:1.2rem}
.cat-card__body p{font-size:.82rem;opacity:.85}
.cat-card__arrow{
  position:absolute;top:14px;right:14px;width:40px;height:40px;
  background:#fff;color:var(--ink);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;transition:.3s;z-index:3;
}
.cat-card:hover .cat-card__arrow{background:var(--c);color:#fff;transform:rotate(-45deg)}

@media(max-width:980px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.cat-grid{grid-template-columns:1fr}}

/* =====================  WHY US  ===================== */
.why{background:var(--cream-deep)}
.why__wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.why__left h2{margin:6px 0 22px}
.why__left p{color:var(--ink-soft);font-size:1.05rem;max-width:420px}
.why__right{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.why__card{
  background:#fff;padding:26px;border-radius:var(--radius);
  box-shadow:var(--shadow-sm);transition:.3s;
  border:1px solid rgba(26,26,46,.04);
}
.why__card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.why__icon{font-size:2rem;margin-bottom:10px}
.why__card h4{margin-bottom:6px}
.why__card p{font-size:.9rem;color:var(--ink-soft)}
@media(max-width:900px){.why__wrap{grid-template-columns:1fr;gap:40px}.why__right{grid-template-columns:1fr}}

/* =====================  PRODUCT GRID  ===================== */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.prod-grid--featured{grid-template-columns:repeat(4,1fr)}
@media(max-width:1000px){.prod-grid,.prod-grid--featured{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.prod-grid,.prod-grid--featured{grid-template-columns:1fr}}

.prod{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.4s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  border:1px solid rgba(26,26,46,.04);
}
.prod:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.prod__img{aspect-ratio:1/1;overflow:hidden;background:var(--cream-deep);position:relative}
.prod__img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.prod:hover .prod__img img{transform:scale(1.08)}
.prod__body{padding:20px;flex:1;display:flex;flex-direction:column;gap:8px}
.prod__tag{
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  color:var(--c,var(--coral));padding:3px 10px;border-radius:999px;
  background:color-mix(in srgb,var(--c,var(--coral)) 12%,#fff);
  align-self:flex-start;
}
.prod__body h4{margin-top:2px}
.prod__body p{color:var(--ink-soft);font-size:.88rem;flex:1}
.prod__enquire{
  margin-top:8px;font-weight:600;color:var(--ink);font-size:.9rem;
  align-self:flex-start;padding:6px 0;position:relative;
}
.prod__enquire::after{
  content:'';position:absolute;bottom:2px;left:0;width:0;height:2px;
  background:var(--grad-warm);transition:.3s;
}
.prod__enquire:hover::after{width:100%}

/* =====================  PRODUCTS PAGE  ===================== */
.filter{padding:40px 0 10px;position:sticky;top:74px;background:var(--cream);z-index:20;border-bottom:1px solid rgba(26,26,46,.04)}
.filter__chips{display:flex;gap:10px;flex-wrap:wrap;padding-bottom:10px}
.chip{
  padding:9px 18px;border-radius:999px;font-weight:500;font-size:.88rem;
  background:#fff;border:1px solid rgba(26,26,46,.08);
  transition:.25s;color:var(--ink-soft);
}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip--active{background:var(--ink);color:var(--cream);border-color:var(--ink)}

.cat-section{padding:60px 0;scroll-margin-top:140px}
.cat-section:nth-child(odd){background:var(--cream-deep)}
.cat-section__head{
  display:flex;align-items:center;gap:18px;margin-bottom:36px;flex-wrap:wrap;
}
.cat-section__mark{
  width:56px;height:56px;background:var(--c,var(--coral));
  border-radius:18px 4px 18px 4px;transform:rotate(12deg);
  box-shadow:0 8px 20px color-mix(in srgb,var(--c,var(--coral)) 35%,transparent);
  flex-shrink:0;
}
.cat-section__head > div:nth-child(2){flex:1}
.cat-section__head h2{margin-bottom:2px}
.cat-section__head p{color:var(--ink-soft);font-size:.95rem}
.cat-section__count{
  padding:6px 14px;background:#fff;border-radius:999px;font-size:.82rem;
  font-weight:600;color:var(--ink-soft);border:1px solid rgba(26,26,46,.08);
}

/* =====================  FEATURED SECTION  ===================== */
.featured{background:var(--cream)}

/* =====================  TESTIMONIAL  ===================== */
.testi{background:var(--cream-deep)}
.testi__card{
  max-width:820px;margin:0 auto;background:#fff;
  padding:60px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);position:relative;
  border:1px solid rgba(26,26,46,.04);
}
.testi__quote{
  position:absolute;top:-30px;left:40px;
  font-family:var(--font-serif);font-size:8rem;line-height:1;
  background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.testi__text{font-family:var(--font-serif);font-size:1.4rem;font-style:italic;line-height:1.5;margin-bottom:28px;color:var(--ink)}
.testi__who{display:flex;align-items:center;gap:14px}
.testi__avatar{
  width:50px;height:50px;border-radius:50%;background:var(--grad);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:1.2rem;
}
.testi__who b{display:block;font-weight:700}
.testi__who span{color:var(--ink-soft);font-size:.88rem}

/* =====================  STORY PAGE  ===================== */
.story{background:var(--cream)}
.story--alt{background:var(--cream-deep)}
.story__row{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.story__row--rev{direction:rtl}
.story__row--rev > *{direction:ltr}
.story__img{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.story__img img{width:100%;height:100%;object-fit:cover}
.story__tag{
  position:absolute;bottom:24px;left:24px;background:#fff;
  padding:10px 20px;border-radius:999px;font-weight:700;
  font-size:.85rem;box-shadow:var(--shadow-md);
}
.story__text h2{margin:6px 0 22px}
.story__text p{color:var(--ink-soft);margin-bottom:14px;font-size:1.02rem}
@media(max-width:900px){.story__row{grid-template-columns:1fr;gap:40px}.story__row--rev{direction:ltr}}

/* =====================  VALUES  ===================== */
.values{background:var(--cream)}
.values__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:40px}
.value{
  background:#fff;padding:30px 26px;border-radius:var(--radius);
  box-shadow:var(--shadow-sm);transition:.3s;position:relative;
  border-top:4px solid var(--c);
}
.value:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.value__num{
  font-family:var(--font-serif);font-size:2.2rem;font-weight:800;
  color:var(--c);margin-bottom:10px;line-height:1;
}
.value h3{margin-bottom:8px;font-size:1.15rem}
.value p{font-size:.9rem;color:var(--ink-soft)}
@media(max-width:900px){.values__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.values__grid{grid-template-columns:1fr}}

/* =====================  TIMELINE  ===================== */
.timeline-sec{background:var(--cream-deep)}
.timeline{max-width:720px;margin:50px auto 0;position:relative}
.timeline::before{
  content:'';position:absolute;left:12px;top:10px;bottom:10px;
  width:2px;background:linear-gradient(180deg,var(--coral),var(--teal),var(--sun),var(--violet));
  border-radius:2px;
}
.timeline__item{display:flex;gap:28px;padding:18px 0;position:relative}
.timeline__dot{
  width:26px;height:26px;border-radius:50%;background:#fff;
  border:3px solid var(--coral);flex-shrink:0;margin-top:4px;
  box-shadow:0 4px 12px rgba(255,107,107,.3);z-index:2;
}
.timeline__item:nth-child(2) .timeline__dot{border-color:var(--teal);box-shadow:0 4px 12px rgba(78,205,196,.3)}
.timeline__item:nth-child(3) .timeline__dot{border-color:var(--sun);box-shadow:0 4px 12px rgba(255,217,61,.3)}
.timeline__item:nth-child(4) .timeline__dot{border-color:var(--violet);box-shadow:0 4px 12px rgba(108,92,231,.3)}
.timeline__body{flex:1;background:#fff;padding:20px 24px;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.timeline__body h4{margin-bottom:4px}
.timeline__body p{color:var(--ink-soft);font-size:.94rem}

/* =====================  CONTACT PAGE  ===================== */
.contact__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;align-items:start}
.contact__info{display:flex;flex-direction:column;gap:16px}
.info-card{
  background:#fff;padding:22px;border-radius:var(--radius);
  display:flex;gap:18px;align-items:flex-start;
  box-shadow:var(--shadow-sm);border:1px solid rgba(26,26,46,.04);
  transition:.3s;
}
.info-card:hover{transform:translateX(6px);box-shadow:var(--shadow-md);border-color:var(--c)}
.info-card__icon{
  width:48px;height:48px;border-radius:14px;
  background:color-mix(in srgb,var(--c,var(--coral)) 18%,#fff);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;flex-shrink:0;
}
.info-card h4{margin-bottom:4px}
.info-card p{font-size:.95rem;color:var(--ink);font-weight:500;margin-bottom:4px}
.info-card span{font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.1em}

.contact__form{
  background:#fff;padding:40px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);border:1px solid rgba(26,26,46,.04);
}
.form__head{margin-bottom:26px}
.form__head h2{font-size:1.8rem;margin-bottom:6px}
.form__head p{color:var(--ink-soft);font-size:.95rem}
.contact__form label{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.contact__form label span{font-size:.82rem;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}
.contact__form label small{text-transform:none;letter-spacing:normal;font-weight:400;opacity:.7}
.contact__form input,.contact__form textarea{
  padding:14px 16px;background:var(--cream);border:1.5px solid transparent;
  border-radius:var(--radius-sm);font-size:.98rem;transition:.25s;
  font-family:inherit;resize:vertical;
}
.contact__form input:focus,.contact__form textarea:focus{
  outline:0;background:#fff;border-color:var(--coral);
  box-shadow:0 0 0 4px rgba(255,107,107,.1);
}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form__row label{margin-bottom:16px}

.alert{padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.92rem;font-weight:500}
.alert--ok{background:color-mix(in srgb,var(--leaf) 14%,#fff);color:var(--leaf);border:1px solid color-mix(in srgb,var(--leaf) 30%,transparent)}
.alert--err{background:color-mix(in srgb,var(--coral) 14%,#fff);color:#c23e3e;border:1px solid color-mix(in srgb,var(--coral) 30%,transparent)}

@media(max-width:900px){.contact__grid{grid-template-columns:1fr;gap:30px}.form__row{grid-template-columns:1fr}.contact__form{padding:28px}}

/* =====================  MAP  ===================== */
.map-sec{background:var(--cream-deep)}
.map-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);border:4px solid #fff}

/* =====================  CTA STRIP  ===================== */
.cta-strip{padding:80px 0;background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.cta-strip::before{
  content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;
  background:var(--grad);opacity:.3;border-radius:50%;filter:blur(60px);
}
.cta-strip::after{
  content:'';position:absolute;bottom:-80px;left:-80px;width:240px;height:240px;
  background:var(--teal);opacity:.2;border-radius:50%;filter:blur(70px);
}
.cta-strip__wrap{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;position:relative;z-index:2}
.cta-strip h2{color:var(--cream);font-size:clamp(1.5rem,2.6vw,2.2rem)}
.cta-strip p{color:rgba(255,249,240,.75);margin-top:8px}
.cta-strip__actions{display:flex;gap:14px;flex-wrap:wrap}
.cta-strip .btn--solid{background:var(--cream);color:var(--ink)}
.cta-strip .btn--solid:hover{background:var(--coral);color:#fff}
.cta-strip .btn--ghost{border-color:var(--cream);color:var(--cream)}
.cta-strip .btn--ghost:hover{background:var(--cream);color:var(--ink)}

/* =====================  FOOTER  ===================== */
.foot{background:var(--ink);color:rgba(255,249,240,.75);padding:70px 0 0}
.foot__wrap{display:grid;grid-template-columns:1.3fr .8fr 1.2fr 1fr;gap:40px;padding-bottom:50px}
.brand--light .brand__text b{color:var(--cream)}
.brand--light .brand__text i{color:rgba(255,249,240,.5)}
.foot__col{display:flex;flex-direction:column;gap:10px}
.foot__col h5{color:var(--cream);font-family:var(--font-sans);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;margin-bottom:8px}
.foot__col a{color:rgba(255,249,240,.75);transition:color .25s}
.foot__col a:hover{color:var(--coral)}
.foot__col p{font-size:.92rem;line-height:1.7}
.foot__bottom{border-top:1px solid rgba(255,249,240,.1);padding:22px 0}
.foot__bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem;color:rgba(255,249,240,.5)}
@media(max-width:900px){.foot__wrap{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:560px){.foot__wrap{grid-template-columns:1fr}}

/* =====================  REVEAL ANIMATION  ===================== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s cubic-bezier(.4,0,.2,1)}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* =====================  FILTER HIDE  ===================== */
.cat-section.is-hidden{display:none}

/* =====================  UTIL  ===================== */
::selection{background:var(--coral);color:#fff}
