/* v2026-05-13 — Fisioterapia Fuengirola */
:root{
  --green:#3F6B5E;
  --green-dark:#2D4F45;
  --sage:#8CB1A6;
  --cream:#F5F1E6;
  --cream-soft:#FBF9F2;
  --ink:#1F2A26;
  --muted:#5C6B66;
  --line:rgba(31,42,38,.1);
  --radius:14px;
  --shadow:0 10px 40px -20px rgba(31,42,38,.25);
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:#fff;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.5rem);margin-bottom:.6em}
h3{font-size:1.25rem;font-weight:600}
p{margin:0 0 1em;color:var(--muted)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{color:var(--muted)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* top bar */
.topbar{background:var(--green-dark);color:#fff;font-size:.85rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:8px 24px;gap:16px;flex-wrap:wrap}
.topbar a{display:inline-flex;align-items:center;gap:6px;opacity:.9}
.topbar a:hover{opacity:1}
.topbar svg{width:14px;height:14px}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;max-width:var(--maxw);margin:0 auto}
.logo{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:500;color:var(--green-dark);letter-spacing:-.02em}
.logo span{color:var(--sage)}
.menu{display:flex;gap:32px;align-items:center}
.menu a{font-size:.95rem;color:var(--ink);transition:color .2s;position:relative}
.menu a:hover{color:var(--green)}
.menu .has-sub{cursor:pointer}
.submenu{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;min-width:280px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;display:flex;flex-direction:column;gap:2px;z-index:60}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{padding:8px 12px;border-radius:8px;font-size:.92rem;display:block}
.submenu a:hover{background:var(--cream-soft);color:var(--green)}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;padding:12px 22px;border-radius:999px;font-weight:500;font-size:.95rem;transition:background .2s,transform .2s;border:0;cursor:pointer;font-family:inherit}
.btn:hover{background:var(--green-dark);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--green);border:1px solid var(--green)}
.btn.ghost:hover{background:var(--green);color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:4px 0;transition:.3s}

/* hero (home) */
.hero{background:linear-gradient(180deg,var(--cream-soft) 0%,#fff 100%);padding:80px 0 100px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.eyebrow{display:inline-block;background:var(--cream);color:var(--green-dark);padding:6px 14px;border-radius:999px;font-size:.8rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:20px}
.hero h1{margin-bottom:.4em}
.hero h1 em{font-style:italic;color:var(--green);font-weight:400}
.hero p.lead{font-size:1.15rem;color:var(--muted);max-width:520px;margin-bottom:32px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-img{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;background:var(--sage);box-shadow:var(--shadow)}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;bottom:24px;left:24px;background:#fff;padding:16px 20px;border-radius:12px;box-shadow:0 10px 30px -10px rgba(0,0,0,.2);display:flex;gap:14px;align-items:center}
.hero-badge strong{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--green-dark);display:block;line-height:1}
.hero-badge small{font-size:.8rem;color:var(--muted)}

/* page hero (inner) */
.page-hero{background:var(--cream-soft);padding:60px 0;border-bottom:1px solid var(--line)}
.page-hero .wrap{text-align:center}
.page-hero h1{margin-bottom:.3em}
.page-hero p{max-width:640px;margin:0 auto;font-size:1.05rem}
.crumbs{display:flex;justify-content:center;gap:8px;font-size:.85rem;color:var(--muted);margin-bottom:18px}
.crumbs a:hover{color:var(--green)}
.crumbs span{opacity:.5}

/* trust */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 0;background:#fff}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.trust-item strong{font-family:'Fraunces',serif;font-size:2rem;color:var(--green);display:block;line-height:1;margin-bottom:6px}
.trust-item span{font-size:.85rem;color:var(--muted)}

section{padding:90px 0}
.section-head{max-width:680px;margin:0 auto 56px;text-align:center}
.section-head .eyebrow{margin-bottom:16px}

/* services grid */
.services{background:var(--cream-soft)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border-radius:var(--radius);padding:32px;transition:transform .3s,box-shadow .3s;border:1px solid var(--line);display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .icon{width:48px;height:48px;border-radius:12px;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--green)}
.card .icon svg{width:24px;height:24px}
.card h3{margin-bottom:10px;color:var(--ink)}
.card p{font-size:.95rem;margin-bottom:16px;flex:1}
.card a.more{color:var(--green);font-weight:500;font-size:.9rem;display:inline-flex;align-items:center;gap:4px;margin-top:auto}
.card a.more::after{content:"→";transition:transform .2s}
.card a.more:hover::after{transform:translateX(4px)}

/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:var(--sage)}
.about-img img{width:100%;height:100%;object-fit:cover}
.about ul{list-style:none;padding:0;margin:24px 0 32px}
.about li{display:flex;gap:12px;padding:10px 0;font-size:.98rem;color:var(--ink)}
.about li::before{content:"";width:20px;height:20px;border-radius:50%;background:var(--cream);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%233F6B5E'%3E%3Cpath d='M16.7 5.3a1 1 0 010 1.4l-7 7a1 1 0 01-1.4 0l-4-4a1 1 0 011.4-1.4L9 11.6l6.3-6.3a1 1 0 011.4 0z'/%3E%3C/svg%3E");background-size:14px;background-repeat:no-repeat;background-position:center;flex-shrink:0;margin-top:2px}

/* approach block */
.approach{background:var(--green-dark);color:#fff;border-radius:24px;padding:80px 60px;margin:0 24px;text-align:center}
.approach h2{color:#fff}
.approach p{color:rgba(255,255,255,.8);max-width:640px;margin:0 auto 40px;font-size:1.05rem}
.approach .btn{background:var(--cream);color:var(--green-dark)}
.approach .btn:hover{background:#fff}

/* testimonials */
.testimonials{background:var(--cream-soft)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:#fff;padding:32px;border-radius:var(--radius);border:1px solid var(--line)}
.stars{color:#E5B23A;letter-spacing:2px;margin-bottom:14px;font-size:1rem}
.quote p{color:var(--ink);font-size:.98rem;margin-bottom:20px;line-height:1.55}
.quote .author{display:flex;align-items:center;gap:12px}
.quote .avatar{width:42px;height:42px;border-radius:50%;background:var(--sage);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-family:'Fraunces',serif}
.quote .author strong{display:block;font-size:.9rem}
.quote .author span{font-size:.8rem;color:var(--muted)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info{background:var(--cream);padding:48px;border-radius:var(--radius)}
.contact-info h2{margin-bottom:.3em}
.contact-block{display:flex;gap:16px;align-items:flex-start;margin:24px 0;padding-bottom:24px;border-bottom:1px solid rgba(31,42,38,.08)}
.contact-block:last-of-type{border:0}
.contact-block .ic{width:42px;height:42px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--green);flex-shrink:0}
.contact-block strong{display:block;color:var(--ink);font-weight:600;margin-bottom:2px}
.contact-block span,.contact-block a{color:var(--muted);font-size:.95rem}
.contact-block a:hover{color:var(--green)}
form{display:grid;gap:16px}
form label{font-size:.85rem;font-weight:500;color:var(--ink);margin-bottom:-10px}
form input,form textarea,form select{padding:14px 16px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:.95rem;background:#fff;transition:border .2s;width:100%}
form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--green)}
form textarea{resize:vertical;min-height:120px}
form button{justify-self:start}

/* article (treatment pages) */
.article{padding:70px 0 90px}
.article-grid{display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:start}
.article-body{font-size:1.05rem}
.article-body h2{margin-top:2em}
.article-body h3{margin-top:1.6em;color:var(--green-dark)}
.article-body p,.article-body li{color:var(--ink)}
.article-body ul{padding-left:1.2em}
.article-body li{margin-bottom:.5em}
.article-body strong{color:var(--ink);font-weight:600}
.article-body .lead{font-size:1.15rem;color:var(--muted);border-left:3px solid var(--green);padding-left:18px;margin:0 0 2em}
.sidebar{position:sticky;top:120px;display:flex;flex-direction:column;gap:20px}
.side-card{background:var(--cream-soft);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.side-card h4{margin:0 0 14px;font-size:1.1rem;color:var(--green-dark)}
.side-card ul{list-style:none;padding:0;margin:0}
.side-card li{margin-bottom:6px}
.side-card a{font-size:.92rem;color:var(--muted);display:block;padding:6px 10px;border-radius:6px;transition:.2s}
.side-card a:hover{background:#fff;color:var(--green)}
.side-card a.active{background:var(--green);color:#fff}
.side-cta{background:var(--green-dark);color:#fff;padding:28px;border-radius:var(--radius)}
.side-cta h4{color:#fff;margin-bottom:10px}
.side-cta p{color:rgba(255,255,255,.8);font-size:.92rem;margin-bottom:18px}
.side-cta .btn{background:var(--cream);color:var(--green-dark);width:100%;justify-content:center}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.team-card{background:var(--cream-soft);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.team-card .photo{aspect-ratio:3/4;background:var(--sage);overflow:hidden}
.team-card .photo img{width:100%;height:100%;object-fit:cover}
.team-card .info{padding:24px}
.team-card h3{margin-bottom:4px}
.team-card .role{font-size:.85rem;color:var(--green);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px;display:block}
.team-card ul{list-style:none;padding:0;margin:0;font-size:.9rem}
.team-card li{padding:4px 0;color:var(--muted);display:flex;gap:8px}
.team-card li::before{content:"–";color:var(--green)}

/* map */
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;background:var(--cream)}
.map-wrap iframe{width:100%;height:100%;border:0}

/* footer */
footer{background:var(--green-dark);color:rgba(255,255,255,.75);padding:60px 0 30px;font-size:.9rem}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
footer h4{font-family:'Fraunces',serif;color:#fff;font-size:1.1rem;font-weight:500;margin:0 0 16px}
footer ul{list-style:none;padding:0;margin:0}
footer li{margin-bottom:8px}
footer a:hover{color:#fff}
.f-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(255,255,255,.5)}

/* WA float */
.wa-float{position:fixed;bottom:24px;right:24px;background:#25D366;color:#fff;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -10px rgba(37,211,102,.6);z-index:100;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px}

/* responsive */
@media(max-width:900px){
  .hero{padding:60px 0 70px}
  .hero-grid,.about-grid,.contact-grid,.article-grid{grid-template-columns:1fr;gap:40px}
  .hero-img{aspect-ratio:4/3;max-height:400px}
  .grid,.t-grid,.team-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .f-grid{grid-template-columns:1fr 1fr;gap:32px}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:24px;border-bottom:1px solid var(--line);gap:18px;align-items:flex-start}
  .menu.open{display:flex}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0 0 0 16px;min-width:auto}
  .has-sub:hover .submenu{display:flex}
  .burger{display:block}
  section,.article{padding:60px 0}
  .approach{padding:50px 28px;margin:0 16px}
  .contact-info{padding:32px}
  .topbar .wrap{justify-content:center}
  .sidebar{position:static}
}
