/* =====================================================
   SoFlo Wellness Field — style.css
   Paleta:
   --sf-cyan       #38b6ff (azul agua marca)
   --sf-blue       #1d3a5e (azul profundo)
   --sf-blue-dark  #0b1a2c
   --sf-green      #2ecc71 (verde wellness)
   --sf-green-dark #27ae60
   --sf-green-soft #5cd65c
   --sf-bg         #f7fbfd
   --sf-text       #1a2740
   ===================================================== */

:root {
    --sf-cyan: #38b6ff;
    --sf-cyan-soft: #79ccff;
    --sf-blue: #1d3a5e;
    --sf-blue-dark: #0b1a2c;
    --sf-green: #2ecc71;
    --sf-green-dark: #27ae60;
    --sf-green-soft: #5cd65c;
    --sf-bg: #f7fbfd;
    --sf-text: #1a2740;
    --sf-text-soft: #5c6c8a;
    --sf-border: #e5eef5;
    --sf-shadow: 0 10px 30px -10px rgba(11, 26, 44, .15);
}

/* ===== Base ===== */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
    font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    color: var(--sf-text);
    background: var(--sf-bg);
    line-height: 1.6;
    padding-top: 78px; /* compensar navbar fixed */
}
h1, h2, h3, h4, h5, h6, .display-1, .display-2, .display-3, .display-4 {
    font-family: 'Poppins', sans-serif;
    color: var(--sf-blue-dark);
    font-weight: 700;
    letter-spacing: -.01em;
}
p { color: var(--sf-text-soft); }
a { color: var(--sf-cyan); text-decoration: none; transition: color .2s; }
a:hover { color: var(--sf-blue); }
.page-main { min-height: 60vh; }

/* ===== Brand mark (SF) ===== */
.brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--sf-cyan) 0%, var(--sf-green) 100%);
    color: #fff;
    font-family: 'Poppins', sans-serif;
    font-weight: 800;
    font-size: 1.15rem;
    box-shadow: 0 6px 18px -6px rgba(56,182,255,.6);
}
.brand-mark .bm-s { color: #fff; }
.brand-mark .bm-f { color: #d8ffe6; margin-left: 1px; }
.brand-text { display: inline-flex; flex-direction: column; line-height: 1; }
.bt-name { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 1.1rem; color: var(--sf-green-dark); }
.bt-name .bt-s { color: var(--sf-cyan); }
.bt-tag { font-size: .7rem; color: var(--sf-text-soft); letter-spacing: .12em; text-transform: uppercase; margin-top: 2px; }

/* ===== Navbar ===== */
.sf-navbar {
    background: rgba(255,255,255,.92);
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--sf-border);
    transition: box-shadow .2s;
}
.sf-navbar.scrolled { box-shadow: var(--sf-shadow); }
.sf-navbar .nav-link {
    color: var(--sf-text);
    font-weight: 500;
    padding: .6rem 1rem;
    border-radius: 8px;
    transition: all .2s;
}
.sf-navbar .nav-link:hover { color: var(--sf-cyan); background: rgba(56,182,255,.08); }
.sf-navbar .nav-link.active { color: var(--sf-cyan); font-weight: 600; }

/* ===== Buttons ===== */
.btn-sf-primary {
    background: linear-gradient(135deg, var(--sf-cyan) 0%, var(--sf-green) 100%);
    color: #fff;
    border: none;
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-weight: 600;
    letter-spacing: .01em;
    box-shadow: 0 8px 20px -8px rgba(46,204,113,.55);
    transition: transform .15s, box-shadow .2s, filter .2s;
}
.btn-sf-primary:hover { color:#fff; transform: translateY(-2px); box-shadow: 0 12px 28px -10px rgba(46,204,113,.7); filter: brightness(1.05); }
.btn-sf-outline {
    background: transparent;
    color: var(--sf-blue);
    border: 2px solid var(--sf-blue);
    padding: .55rem 1.3rem;
    border-radius: 999px;
    font-weight: 600;
    transition: all .2s;
}
.btn-sf-outline:hover { background: var(--sf-blue); color: #fff; }

/* ===== Hero ===== */
.hero {
    position: relative;
    padding: 5rem 0 4rem;
    background:
        radial-gradient(ellipse at top left, rgba(56,182,255,.18), transparent 50%),
        radial-gradient(ellipse at bottom right, rgba(46,204,113,.18), transparent 50%),
        linear-gradient(180deg, #ffffff 0%, var(--sf-bg) 100%);
    overflow: hidden;
}
.hero h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); line-height: 1.1; margin-bottom: 1.2rem; }
.hero h1 .accent { background: linear-gradient(135deg, var(--sf-cyan), var(--sf-green)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero p.lead { font-size: 1.15rem; color: var(--sf-text-soft); max-width: 560px; }
.hero .hero-actions { margin-top: 1.8rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-art {
    position: relative;
    aspect-ratio: 1/1;
    max-width: 460px;
    margin: 0 auto;
    background: linear-gradient(135deg, var(--sf-cyan) 0%, var(--sf-green) 100%);
    border-radius: 50%;
    box-shadow: 0 30px 60px -20px rgba(56,182,255,.5);
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-family: 'Poppins',sans-serif; font-weight: 800; font-size: 7rem;
}
.hero-art::before, .hero-art::after {
    content: ''; position: absolute; border-radius: 50%;
}
.hero-art::before { width: 110%; height:110%; border: 1px dashed rgba(255,255,255,.4); top:-5%; left:-5%; }
.hero-art::after { width: 130%; height:130%; border: 1px dashed rgba(255,255,255,.2); top:-15%; left:-15%; animation: spin 40s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ===== Section base ===== */
.section { padding: 4.5rem 0; }
.section-title { text-align: center; margin-bottom: 3rem; }
.section-title .eyebrow { display: inline-block; font-size: .8rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--sf-cyan); margin-bottom: .8rem; }
.section-title h2 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); }
.section-title p { max-width: 620px; margin: .8rem auto 0; }

/* ===== Pillar cards (Mind/Body/Energy/Balance) ===== */
.pillar-card {
    background: #fff;
    border: 1px solid var(--sf-border);
    border-radius: 20px;
    padding: 2rem 1.5rem;
    text-align: center;
    transition: transform .25s, box-shadow .25s, border-color .25s;
    height: 100%;
}
.pillar-card:hover { transform: translateY(-6px); box-shadow: var(--sf-shadow); border-color: transparent; }
.pillar-icon {
    width: 64px; height: 64px;
    border-radius: 16px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.7rem; color: #fff;
    margin-bottom: 1.1rem;
}
.pillar-mind   .pillar-icon { background: linear-gradient(135deg,#38b6ff,#79ccff); }
.pillar-body   .pillar-icon { background: linear-gradient(135deg,#2ecc71,#5cd65c); }
.pillar-energy .pillar-icon { background: linear-gradient(135deg,#1d3a5e,#38b6ff); }
.pillar-balance.pillar-card .pillar-icon { background: linear-gradient(135deg,#27ae60,#38b6ff); }
.pillar-card h3 { font-size: 1.2rem; margin-bottom: .5rem; }
.pillar-card p  { font-size: .95rem; margin-bottom: 0; }

/* ===== Blog cards ===== */
.post-card {
    background: #fff;
    border: 1px solid var(--sf-border);
    border-radius: 18px;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
    height: 100%;
    display: flex; flex-direction: column;
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--sf-shadow); }
.post-cover {
    aspect-ratio: 16/9;
    background: linear-gradient(135deg, var(--sf-cyan), var(--sf-green));
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size: 2.5rem;
}
.post-body { padding: 1.4rem; flex: 1; display: flex; flex-direction: column; }
.post-meta { font-size: .8rem; color: var(--sf-text-soft); text-transform: uppercase; letter-spacing: .08em; margin-bottom: .6rem; }
.post-title { font-size: 1.15rem; margin-bottom: .6rem; color: var(--sf-blue-dark); }
.post-title a { color: inherit; }
.post-title a:hover { color: var(--sf-cyan); }
.post-excerpt { font-size: .95rem; flex:1; }
.post-read { font-weight: 600; color: var(--sf-cyan); margin-top: 1rem; }
.post-read i { transition: transform .2s; }
.post-card:hover .post-read i { transform: translateX(4px); }

/* ===== Booking ===== */
.booking-wrap { background: #fff; border-radius: 22px; padding: 2.2rem; box-shadow: var(--sf-shadow); border: 1px solid var(--sf-border); }
.calendar {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
}
.calendar .cal-head {
    text-align: center;
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--sf-text-soft);
    padding: .5rem 0;
}
.calendar .cal-day {
    aspect-ratio: 1/1;
    border: 1px solid var(--sf-border);
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s;
    background: #fff;
    color: var(--sf-text);
}
.calendar .cal-day:hover:not(.disabled):not(.empty) { border-color: var(--sf-cyan); color: var(--sf-cyan); background: rgba(56,182,255,.05); }
.calendar .cal-day.empty { border: none; cursor: default; }
.calendar .cal-day.disabled { color: #c5cfd9; background: #f3f6f9; cursor: not-allowed; }
.calendar .cal-day.today { border-color: var(--sf-green); color: var(--sf-green-dark); }
.calendar .cal-day.selected { background: linear-gradient(135deg,var(--sf-cyan),var(--sf-green)); color:#fff; border-color: transparent; box-shadow: 0 6px 14px -6px rgba(46,204,113,.6); }
.slot-list { display:flex; flex-wrap: wrap; gap: .6rem; }
.slot-btn {
    border: 1px solid var(--sf-border);
    background: #fff;
    padding: .55rem 1rem;
    border-radius: 10px;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s;
    font-size: .9rem;
    color: var(--sf-blue);
}
.slot-btn:hover { border-color: var(--sf-cyan); color: var(--sf-cyan); }
.slot-btn.selected { background: linear-gradient(135deg,var(--sf-cyan),var(--sf-green)); color:#fff; border-color: transparent; }
.slot-btn.disabled { color:#c5cfd9; background:#f3f6f9; cursor: not-allowed; }

/* ===== Forms ===== */
.form-control, .form-select {
    border-radius: 12px;
    border: 1px solid var(--sf-border);
    padding: .65rem .9rem;
    font-size: .95rem;
}
.form-control:focus, .form-select:focus {
    border-color: var(--sf-cyan);
    box-shadow: 0 0 0 4px rgba(56,182,255,.15);
}
.form-label { font-weight: 600; color: var(--sf-blue); font-size: .9rem; }

/* ===== Footer ===== */
.sf-footer {
    background: var(--sf-blue-dark);
    color: #cdd6e2;
    padding: 3.5rem 0 1.5rem;
    margin-top: 5rem;
}
.sf-footer h6.footer-title { color: #fff; font-family:'Poppins',sans-serif; font-weight:600; font-size:.85rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom: 1rem; }
.sf-footer .footer-links li { margin-bottom: .5rem; }
.sf-footer .footer-links a { color: #cdd6e2; }
.sf-footer .footer-links a:hover { color: var(--sf-cyan); }
.sf-footer .text-light-50 { color: #94a3b8; font-size: .95rem; }
.sf-footer .brand-text .bt-tag { color: #94a3b8; }
.sf-footer .footer-divider { border-color: rgba(255,255,255,.08); margin: 2.5rem 0 1.2rem; }
.sf-footer .text-muted-soft { color: #7c8aa1; }
.social-links a { color: #cdd6e2; font-size: 1.3rem; margin-right: .8rem; transition: color .2s; }
.social-links a:hover { color: var(--sf-cyan); }

/* ===== Utilities ===== */
.text-cyan { color: var(--sf-cyan) !important; }
.text-green { color: var(--sf-green) !important; }
.bg-soft { background: var(--sf-bg); }
.rounded-xl { border-radius: 20px; }

/* ===== Responsive ===== */
@media (max-width: 991px) {
    .sf-navbar .navbar-collapse { background: #fff; border-radius: 12px; margin-top: .6rem; padding: 1rem; box-shadow: var(--sf-shadow); }
    .hero { padding: 3rem 0; text-align: center; }
    .hero .hero-actions { justify-content: center; }
    .hero-art { max-width: 280px; margin-top: 2rem; font-size: 4.5rem; }
}



/* ===== Logo SoFlo (imagen) ===== */
.sf-logo {
      height: 56px;
        width: auto;
          display: block;
}
.hero-logo {
      max-width: 420px;
        width: 100%;
          height: auto;
            display: block;
              margin: 0 auto;
                filter: drop-shadow(0 18px 30px rgba(56,182,255,.25));
}
.about-logo {
      max-width: 320px;
        width: 100%;
          height: auto;
            display: inline-block;
              filter: drop-shadow(0 12px 22px rgba(56,182,255,.2));
}
@media (max-width: 991px) {
      .sf-logo { height: 46px; }
        .hero-logo { max-width: 280px; margin-top: 1.5rem; }
}
}
}
}
}

/* ----- Logos redondos (override v2 nitidez) ----- */
.sf-logo{ border-radius:50%; object-fit:contain; aspect-ratio:1/1; background:transparent; padding:0; box-shadow:0 4px 10px rgba(29,58,94,.15); image-rendering:-webkit-optimize-contrast; }
.sf-logo--sm{ width:48px; height:48px; }
.hero-logo{ border-radius:50%; object-fit:contain; aspect-ratio:1/1; width:min(420px,80vw); height:auto; background:transparent; padding:0; box-shadow:0 18px 45px rgba(29,58,94,.18); filter:none; image-rendering:-webkit-optimize-contrast; }
.about-logo{ border-radius:50%; object-fit:contain; aspect-ratio:1/1; width:min(320px,70vw); height:auto; background:transparent; padding:0; display:block; margin:0 auto 2rem; box-shadow:0 14px 38px rgba(29,58,94,.18); filter:none; image-rendering:-webkit-optimize-contrast; }


/* ====== Footer ====== */
.sf-footer{background:linear-gradient(135deg,#0b1f33,#1d3a5e);color:#cdd6df;padding:3.5rem 0 1.5rem;margin-top:4rem;}
.sf-footer__brand strong{font-family:Poppins,sans-serif;font-size:1.05rem;}
.sf-footer__tag{color:#9fb3c8;font-size:.95rem;margin-bottom:0;}
.sf-footer__h{color:#fff;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:600;margin-bottom:.9rem;}
.sf-footer__links li{margin-bottom:.4rem;}
.sf-footer__links a{color:#9fb3c8;text-decoration:none;font-size:.95rem;transition:color .2s;}
.sf-footer__links a:hover{color:#38b6ff;}
.sf-footer__social{display:flex;gap:.8rem;}
.sf-footer__social a{color:#9fb3c8;font-size:1.3rem;transition:color .2s,transform .2s;}
.sf-footer__social a:hover{color:#38b6ff;transform:translateY(-2px);}
.sf-footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.2rem;margin-top:2.5rem;text-align:center;color:#9fb3c8;}

/* ====== Forms (booking, contact) ====== */
.sf-form{max-width:640px;margin:0 auto;}
.sf-form label{font-family:Inter,sans-serif;font-weight:500;color:var(--sf-blue-dark);font-size:.92rem;margin-bottom:.35rem;display:block;}
.sf-form .form-control,.sf-form .form-select{border-radius:12px;border:1px solid #d8e3ec;padding:.65rem .9rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s;}
.sf-form .form-control:focus,.sf-form .form-select:focus{border-color:var(--sf-cyan);box-shadow:0 0 0 4px rgba(56,182,255,.12);outline:none;}


/* ====== Hero ====== */
.sf-hero{padding:4rem 0 5rem;background:linear-gradient(160deg,#eaf6ff 0%,#e8f7ee 100%);position:relative;overflow:hidden;}
.sf-hero__eyebrow{color:var(--sf-blue);font-family:Inter,sans-serif;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;margin-bottom:1rem;}
.sf-hero__title{font-family:Poppins,sans-serif;font-weight:700;font-size:clamp(2rem,4.8vw,3.4rem);line-height:1.08;color:var(--sf-blue-dark);}
.sf-hero__title .sf-accent{background:linear-gradient(120deg,var(--sf-cyan),var(--sf-green));-webkit-background-clip:text;background-clip:text;color:transparent;}
.sf-hero__lead{color:var(--sf-text-soft);font-size:1.05rem;max-width:34rem;margin:1.2rem 0 1.8rem;}
.sf-hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;}

/* ====== Buttons ====== */
.sf-btn{display:inline-flex;align-items:center;justify-content:center;font-family:Inter,sans-serif;font-weight:600;font-size:.95rem;padding:.65rem 1.3rem;border-radius:999px;border:none;transition:transform .15s,box-shadow .2s;text-decoration:none;}
.sf-btn:hover{transform:translateY(-1px);}
.sf-btn--primary{background:linear-gradient(135deg,var(--sf-cyan),var(--sf-green));color:#fff;box-shadow:0 6px 18px rgba(56,182,255,.35);}
.sf-btn--primary:hover{color:#fff;box-shadow:0 10px 24px rgba(56,182,255,.45);}
.sf-btn--ghost{background:#fff;color:var(--sf-blue-dark);border:1px solid #d8e3ec;}
.sf-btn--ghost:hover{border-color:var(--sf-cyan);color:var(--sf-blue);}

/* ====== Lang switcher ====== */
.sf-lang{display:inline-flex;align-items:center;font-family:Inter,sans-serif;font-weight:600;font-size:.85rem;margin-left:.5rem;}
.sf-lang__btn{color:var(--sf-text-soft);text-decoration:none;padding:.2rem .4rem;letter-spacing:.05em;}
.sf-lang__btn:hover{color:var(--sf-blue);}
.sf-lang__btn.is-active{color:var(--sf-blue);text-decoration:underline;}
.sf-lang__sep{color:#cdd6df;}

/* ====== Sections ====== */
.sf-section{padding:4rem 0;}
.sf-section__eyebrow{color:var(--sf-blue);font-family:Inter,sans-serif;font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;text-align:center;}
.sf-section__title{font-family:Poppins,sans-serif;font-weight:700;font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--sf-blue-dark);text-align:center;margin:.5rem auto 1rem;max-width:36rem;}
.sf-section__intro{color:var(--sf-text-soft);text-align:center;max-width:38rem;margin:0 auto 2.5rem;}

/* ====== Service cards ====== */
.sf-svc-card{background:#fff;border-radius:18px;padding:1.8rem 1.5rem;border:1px solid #eaf0f6;box-shadow:0 8px 24px rgba(29,58,94,.06);height:100%;transition:transform .2s,box-shadow .25s;display:flex;flex-direction:column;}
.sf-svc-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(29,58,94,.12);}
.sf-svc-card__icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;margin-bottom:1rem;}
.sf-svc-card__icon.is-hbot{background:linear-gradient(135deg,#38b6ff,#1d3a5e);}
.sf-svc-card__icon.is-red{background:linear-gradient(135deg,#ff6b6b,#c0392b);}
.sf-svc-card__icon.is-wellness{background:linear-gradient(135deg,#2ecc71,#27ae60);}
.sf-svc-card__icon.is-holistic{background:linear-gradient(135deg,#a78bfa,#6d28d9);}
.sf-svc-card__name{font-family:Poppins,sans-serif;font-weight:600;color:var(--sf-blue-dark);font-size:1.15rem;margin-bottom:.25rem;}
.sf-svc-card__short{color:var(--sf-blue);font-weight:600;font-size:.85rem;margin-bottom:.7rem;text-transform:uppercase;letter-spacing:.05em;}
.sf-svc-card__desc{color:var(--sf-text-soft);font-size:.95rem;line-height:1.55;}


/* ===== Override final logos redondos v3 ===== */
.sf-logo, img.sf-logo{ border-radius:50% !important; aspect-ratio:1/1 !important; width:56px !important; height:56px !important; object-fit:contain !important; background:#ffffff !important; padding:2px !important; box-shadow:0 4px 12px rgba(29,58,94,.18) !important; image-rendering:auto !important; filter:none !important; }
.sf-logo--sm, img.sf-logo--sm{ width:48px !important; height:48px !important; }
.sf-footer .sf-logo{ background:#ffffff !important; }
.hero-logo, img.hero-logo{ border-radius:50% !important; aspect-ratio:1/1 !important; width:min(420px,80vw) !important; height:auto !important; object-fit:contain !important; background:#ffffff !important; padding:6px !important; box-shadow:0 18px 45px rgba(29,58,94,.22) !important; filter:none !important; }
.about-logo, img.about-logo{ border-radius:50% !important; aspect-ratio:1/1 !important; width:min(320px,70vw) !important; height:auto !important; object-fit:contain !important; background:#ffffff !important; padding:6px !important; display:block !important; margin:0 auto 2rem !important; box-shadow:0 14px 38px rgba(29,58,94,.22) !important; filter:none !important; }


/* ===== Booking slots ===== */
.sf-slot-hint{font-family:Inter,sans-serif;font-size:.9rem;color:var(--sf-text-soft);padding:.55rem .8rem;background:#fff;border:1px dashed #cfd9e4;border-radius:10px;display:inline-block;}
.sf-slots{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0 1.25rem;}
.sf-slot{font-family:Inter,sans-serif;font-weight:600;font-size:.9rem;padding:.55rem .9rem;border-radius:999px;border:1px solid #cfd9e4;background:#fff;color:var(--sf-blue);cursor:pointer;transition:all .2s;}
.sf-slot:hover{border-color:var(--sf-cyan);color:var(--sf-cyan);box-shadow:0 4px 12px rgba(56,182,255,.18);}
.sf-slot.is-active{background:linear-gradient(135deg,var(--sf-cyan),var(--sf-green));color:#fff;border-color:transparent;box-shadow:0 6px 16px rgba(56,182,255,.35);}
.sf-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
@media(max-width:640px){.sf-form__grid{grid-template-columns:1fr;}}
