/* Norma's Cleaning Services — fresh, photo-free premium cleaning site */
:root{
  --bg:#f5f3ec; --paper:#ffffff; --teal:#2f9c95; --teal-deep:#1c6f69; --teal-ink:#114b47;
  --mint:#dcefeb; --mint2:#eef7f4; --ink:#1d2a28; --muted:#5c6a66; --line:rgba(28,40,38,.12);
  --sun:#f0b429; --shadow:0 20px 50px -24px rgba(28,79,71,.38); --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Hanken Grotesk",system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.dsp{font-family:"Gabarito","Hanken Grotesk",sans-serif;font-weight:700;line-height:1.05;letter-spacing:-.015em}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--teal-deep)}
.eyebrow.on-dark{color:#bfe7e0}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;font-weight:700;font-size:.95rem;padding:13px 24px;border:none;cursor:pointer;transition:transform .18s,box-shadow .18s,background .18s}
.btn-teal{background:var(--teal);color:#fff;box-shadow:0 10px 24px -10px rgba(47,156,149,.7)}
.btn-teal:hover{transform:translateY(-2px);background:var(--teal-deep)}
.btn-ghost{background:transparent;border:1.6px solid currentColor}
.btn-ghost:hover{background:rgba(47,156,149,.08)}

/* demo banner */
.demo{background:var(--teal-ink);color:#eafaf6;font-size:.85rem;display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;padding:9px 18px;text-align:center}
.demo strong{color:#fff}
.demo a{border:1px solid #8fd3cb;color:#d6f3ee;padding:4px 14px;border-radius:999px;font-weight:600;transition:.2s}
.demo a:hover{background:#d6f3ee;color:var(--teal-ink)}

/* header */
header{position:sticky;top:0;z-index:40;background:rgba(245,243,236,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Gabarito",sans-serif;font-weight:700;font-size:1.16rem}
.brand .mk{width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,var(--teal),var(--teal-deep));display:grid;place-items:center;color:#fff;font-size:1rem;box-shadow:var(--shadow)}
.nav-links{display:flex;gap:28px;align-items:center;font-size:.94rem;font-weight:600}
.nav-links a:hover{color:var(--teal-deep)}
.nav .btn{padding:10px 18px}

/* hero */
.hero{position:relative;overflow:hidden;padding:90px 0 96px;background:
  radial-gradient(60% 70% at 82% 18%,var(--mint) 0%,transparent 60%),
  radial-gradient(50% 60% at 10% 90%,#eaf4ef 0%,transparent 55%),var(--bg)}
.hero .blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;z-index:0}
.hero .b1{width:120px;height:120px;background:#bfe7e0;top:60px;right:18%}
.hero .b2{width:60px;height:60px;background:#cfe9c9;bottom:70px;left:12%}
.hero .spark{position:absolute;color:var(--teal);opacity:.45;font-size:1.4rem;z-index:0}
.hero-inner{position:relative;z-index:1;max-width:760px}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem)}
.hero h1 .hl{color:var(--teal-deep);position:relative;white-space:nowrap}
.hero p.lead{font-size:clamp(1.08rem,1.7vw,1.32rem);color:#3a4742;max-width:48ch;margin:20px 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.trust{margin-top:30px;display:flex;gap:22px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:.92rem;font-weight:600}
.trust .star{color:var(--sun)}
.reveal{opacity:0;transform:translateY(20px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.16s}.d3{animation-delay:.3s}.d4{animation-delay:.44s}
@keyframes rise{to{opacity:1;transform:none}}

/* stats */
.stats{background:var(--teal-deep);color:#eafaf6}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;padding:28px 24px}
.stat .n{font-family:"Gabarito",sans-serif;font-size:1.9rem;color:#fff}
.stat .l{font-size:.82rem;color:#bfe7e0;margin-top:4px}

section{padding:84px 0}
.head{max-width:60ch}
.head h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-top:12px}
.head p{color:var(--muted);margin-top:12px;font-size:1.05rem}

/* about */
.about{background:var(--mint2)}
.about .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.about .lede{font-family:"Gabarito",sans-serif;font-size:1.5rem;line-height:1.3;color:var(--teal-ink);margin-bottom:16px}
.about p{font-size:1.08rem;color:#3a4742}
.about .card{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:30px;box-shadow:var(--shadow)}
.about .card h3{font-size:1.2rem;margin-bottom:14px}
.checks{list-style:none;display:grid;gap:12px}
.checks li{display:flex;gap:11px;align-items:flex-start;font-weight:600;color:#2c3a36}
.checks li::before{content:"✦";color:var(--teal);font-size:1rem;margin-top:2px}

/* services */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.card2{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px 26px;transition:transform .22s,box-shadow .22s}
.card2:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card2 .ic{width:50px;height:50px;border-radius:14px;background:var(--mint);display:grid;place-items:center;font-size:1.5rem;margin-bottom:16px}
.card2 h3{font-size:1.22rem;margin-bottom:8px}
.card2 p{color:var(--muted);font-size:.98rem}

/* reviews */
.reviews{background:var(--teal-ink);color:#eafaf6;position:relative}
.reviews .head h2{color:#fff}
.reviews .head p{color:#bfe7e0}
.q-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.quote{background:rgba(255,255,255,.06);border:1px solid rgba(191,231,224,.25);border-radius:18px;padding:26px;display:flex;flex-direction:column;gap:12px}
.quote .st{color:var(--sun);letter-spacing:2px}
.quote p{color:#eafaf6;font-size:1.02rem}
.quote .who{font-weight:700;font-size:.92rem;margin-top:auto;color:#fff}
.quote .who span{display:block;font-weight:500;color:#9fd3cb;font-size:.8rem}

/* contact */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.contact .panel{background:linear-gradient(150deg,var(--teal),var(--teal-deep));color:#fff;border-radius:24px;padding:40px;box-shadow:var(--shadow)}
.contact .panel h2{font-size:clamp(1.8rem,3vw,2.5rem)}
.contact .panel p{color:#dcf3ef;margin:12px 0 24px}
.contact .panel .btn{background:#fff;color:var(--teal-deep)}
.contact .panel .btn:hover{background:#eafaf6;transform:translateY(-2px)}
.info{display:grid;gap:14px;font-size:1.02rem}
.info .row{display:flex;gap:12px;align-items:flex-start;padding-bottom:13px;border-bottom:1px solid var(--line)}
.info .row .k{color:var(--teal-deep);font-weight:700;min-width:84px}
.hours{list-style:none;font-size:.97rem;margin-top:6px}
.hours li{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--line)}
.hours .c{color:var(--muted)}

/* footer + map */
footer{background:#10302d;color:#9fc4bd;padding:0 0 46px;font-size:.9rem}
.footer-map{padding-top:46px;margin-bottom:34px}
.footer-map .fm p{color:#bfe7e0;margin-top:6px;font-size:.95rem}
.footer-map iframe{width:100%;height:300px;border:0;border-radius:18px;margin-top:14px;display:block;box-shadow:var(--shadow)}
footer .fwrap{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center}
footer a:hover{color:#eafaf6}
footer .legal{font-size:.8rem;color:#6f928c;max-width:60ch}

/* faq */
.faq-hero{background:var(--teal-ink);color:#eafaf6;padding:110px 0 64px;text-align:center}
.faq-hero h1{font-size:clamp(2.2rem,5vw,3.4rem)}
.faq-hero p{color:#bfe7e0;margin-top:12px;max-width:52ch;margin-inline:auto}
.faq-list{max-width:820px;margin:0 auto;padding:64px 24px}
.faq-item{border-bottom:1px solid var(--line);padding:24px 0}
.faq-item h3{font-size:1.24rem;color:var(--teal-ink);display:flex;gap:11px;align-items:baseline}
.faq-item h3::before{content:"✦";color:var(--teal);font-size:.85rem}
.faq-item p{color:#3a4742;margin-top:10px;font-size:1.02rem}

.sr{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.sr.in{opacity:1;transform:none}

@media(max-width:860px){
  .nav-links{display:none}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:16px}
  .about .wrap,.contact .wrap{grid-template-columns:1fr;gap:30px}
  .cards,.q-grid{grid-template-columns:1fr}
  section{padding:60px 0}
  .footer-map iframe{height:230px}
}
