/* MyGP Surgery — inspired by dr-emma.co.uk (elegant editorial) + therapieclinic.com (bold service-led) */
:root{
  --primary:#0d4f4a;       /* deep teal-green, clinical & calm */
  --primary-dark:#08332f;
  --accent:#c9a86a;        /* muted gold */
  --cream:#f6f1ea;
  --ink:#15201f;
  --muted:#6b7472;
  --line:#e7e1d6;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',sans-serif;color:var(--ink);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
h2{font-size:clamp(2rem,3.5vw,2.9rem);line-height:1.15}
h2 em,h1 em{font-style:italic;color:var(--primary);font-weight:500}
p{color:var(--muted)}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark)}
.eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--primary);font-weight:600;margin-bottom:1rem}
.eyebrow.light{color:var(--accent)}
.bg-cream{background:var(--cream)}
.py-section{padding:6rem 0}
.section-head{max-width:720px;margin:0 auto}
.section-sub{margin-top:1rem;font-size:1.1rem}

/* Topbar */
.topbar{background:var(--primary-dark);color:#dfe9e7;font-size:.85rem;padding:.55rem 0}
.topbar a{color:#dfe9e7}
.topbar a:hover{color:var(--accent)}

/* Navbar */
.main-nav{background:#fff;border-bottom:1px solid var(--line);padding:.85rem 0}
.brand-mark{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:700;color:var(--ink);line-height:1}
.brand-mark span{color:var(--primary)}
.brand-sub{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.main-nav .nav-link{color:var(--ink);font-weight:500;font-size:.95rem;margin:0 .65rem;position:relative}
.main-nav .nav-link.active,.main-nav .nav-link:hover{color:var(--primary)}
.btn-book{background:var(--primary);border:none;color:#fff;padding:.65rem 1.6rem;border-radius:50px;font-weight:500}
.btn-book:hover{background:var(--primary-dark);color:#fff}
.btn-primary{background:var(--primary);border-color:var(--primary);border-radius:50px;padding:.75rem 1.8rem;font-weight:500}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}
.btn-outline-dark{border-radius:50px;padding:.75rem 1.8rem;border-width:1.5px}
.btn-light{border-radius:50px;padding:.85rem 2rem;font-weight:500}
.btn-outline-light{border-radius:50px}

/* Hero */
.hero{padding:5rem 0 6rem;background:linear-gradient(180deg,var(--cream) 0%,#fff 100%);position:relative;overflow:hidden}
.hero-title{font-size:clamp(2.4rem,4.6vw,4rem);line-height:1.05;margin:1rem 0 1.4rem}
.hero .lead{font-size:1.15rem;color:var(--muted);max-width:540px}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin:2rem 0 2.5rem}
.hero-trust{display:flex;gap:2.5rem;border-top:1px solid var(--line);padding-top:1.5rem;flex-wrap:wrap}
.hero-trust strong{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--primary);display:block}
.hero-trust strong i{font-size:1rem;color:var(--accent);margin-left:4px}
.hero-trust span{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.hero-visual{position:relative}
.hero-img-main{width:100%;border-radius:14px;box-shadow:0 30px 60px -25px rgba(0,0,0,.3);object-fit:cover;aspect-ratio:4/5}
.hero-card{position:absolute;bottom:-25px;left:-25px;background:#fff;padding:1.2rem 1.4rem;border-radius:12px;box-shadow:0 20px 40px -15px rgba(0,0,0,.18);display:flex;gap:1rem;align-items:center;max-width:320px}
.hero-card i{font-size:2rem;color:var(--primary)}
.hero-card strong{display:block;font-family:'Inter',sans-serif;font-size:.95rem;color:var(--ink)}
.hero-card small{color:var(--muted);font-size:.78rem;line-height:1.4}

/* Strip */
.strip{background:var(--primary);color:#fff;padding:1.4rem 0;font-weight:500}
.strip i{color:var(--accent);margin-right:.5rem}
.strip > .container > div{padding:.4rem 0}

/* Service cards */
.service-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;height:100%;transition:.35s;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-6px);box-shadow:0 25px 50px -20px rgba(13,79,74,.25);border-color:transparent}
.service-card img{width:100%;height:230px;object-fit:cover}
.service-body{padding:1.8rem;display:flex;flex-direction:column;flex:1}
.service-body h3{font-size:1.45rem;margin-bottom:.6rem}
.service-body p{flex:1}
.link-arrow{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--primary);margin-top:.8rem;font-size:.92rem;letter-spacing:.02em}
.link-arrow:hover i{transform:translateX(4px)}
.link-arrow i{transition:.25s}

/* About */
.about-gallery{position:relative;height:520px}
.about-gallery .img-1{width:75%;height:380px;object-fit:cover;border-radius:14px;box-shadow:0 25px 50px -20px rgba(0,0,0,.25)}
.about-gallery .img-2{position:absolute;right:0;bottom:0;width:55%;height:300px;object-fit:cover;border-radius:14px;border:8px solid var(--cream);box-shadow:0 25px 50px -20px rgba(0,0,0,.25)}
.check-list{list-style:none;padding:0;margin:1.5rem 0 0}
.check-list li{padding:.5rem 0;color:var(--ink)}
.check-list i{color:var(--primary);margin-right:.65rem}

/* CTA band */
.cta-band{background:var(--primary);color:#fff;padding:5rem 0;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.cta-band h2 a{color:var(--accent);border-bottom:2px solid var(--accent)}
.cta-band p{color:rgba(255,255,255,.85);max-width:560px;margin:1rem auto 2rem}

/* Clinics */
.clinic-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:2.5rem 2rem;text-align:center;height:100%;transition:.3s}
.clinic-card:hover{border-color:var(--primary);transform:translateY(-4px)}
.clinic-card i{font-size:2.5rem;color:var(--accent);margin-bottom:1rem}
.clinic-card h4{font-size:1.6rem}

/* Testimonials */
.quote-card{background:#fff;border-radius:14px;padding:2rem;height:100%;border:1px solid var(--line);position:relative}
.quote-card > i{font-size:2.5rem;color:var(--accent);line-height:1}
.quote-card p{font-style:italic;color:var(--ink);margin:1rem 0}
.quote-card strong{display:block;color:var(--primary);font-family:'Cormorant Garamond',serif;font-size:1.2rem}
.quote-card span{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* FAQ */
.accordion-item{border:none;border-bottom:1px solid var(--line);background:transparent}
.accordion-button{background:transparent;font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--ink);padding:1.4rem 0}
.accordion-button:not(.collapsed){background:transparent;color:var(--primary);box-shadow:none}
.accordion-button:focus{box-shadow:none}
.accordion-body{padding:0 0 1.4rem;color:var(--muted)}

/* Contact */
.bg-dark-soft{background:var(--primary-dark);color:#dfe9e7}
.bg-dark-soft h2,.bg-dark-soft .eyebrow{color:#fff}
.bg-dark-soft h2 em{color:var(--accent)}
.bg-dark-soft p{color:rgba(255,255,255,.75)}
.contact-list{list-style:none;padding:0;margin:2rem 0 0}
.contact-list li{padding:.6rem 0;font-size:1.05rem;color:#fff}
.contact-list i{color:var(--accent);margin-right:.8rem;width:20px}
.contact-list a{color:#fff}
.booking-form{background:#fff;padding:2.5rem;border-radius:14px}
.booking-form .form-control,.booking-form .form-select{border:1px solid var(--line);padding:.85rem 1rem;border-radius:8px;background:var(--cream)}
.booking-form .form-control:focus,.booking-form .form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(13,79,74,.1)}

/* Footer */
.footer{background:#0a1c1a;color:#a8b3b1;padding:5rem 0 2rem}
.footer h5{color:#fff;font-family:'Inter',sans-serif;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:1.2rem;font-weight:600}
.footer ul{list-style:none;padding:0}
.footer ul li{padding:.3rem 0}
.footer a{color:#a8b3b1}
.footer a:hover{color:var(--accent)}
.footer .brand-mark{color:#fff}
.footer hr{border-color:rgba(255,255,255,.08);margin:3rem 0 1.5rem}
.socials{margin-top:1.2rem;display:flex;gap:.8rem}
.socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:.25s}
.socials a:hover{background:var(--accent);color:var(--ink)}

@media (max-width:991px){
  .py-section{padding:4rem 0}
  .hero{padding:3rem 0 4rem}
  .hero-card{position:static;margin-top:1rem;max-width:100%}
  .about-gallery{height:auto}
  .about-gallery .img-2{position:static;width:100%;margin-top:1rem;height:240px}
  .about-gallery .img-1{width:100%;height:300px}
}
