/* ========================================
   MAIN CSS — Sites6 Elegancia Premium
   Below-the-fold. Escrito desde cero.
   ======================================== */

/* --- Sections --- */
.section--alt{background:var(--c-bg-alt)}
.section__title{font-size:clamp(1.5rem,3.5vw,2.25rem);margin-bottom:.75rem;color:var(--c-primary)}
.section__text{font-size:1.0625rem;color:var(--c-text-muted);max-width:760px;margin:0 auto 2.5rem;line-height:1.7}

/* --- Steps / How It Works --- */
.steps__grid{display:grid;gap:1.5rem;margin-top:2rem}
.step-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;padding:2rem 1.75rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}
.step-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.step-card__number{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--c-primary);color:#fff;font-weight:800;font-size:1.25rem;margin-bottom:1.25rem}
.step-card h3{font-size:1.125rem;margin-bottom:.5rem;color:var(--c-primary)}
.step-card p{font-size:.9375rem;color:var(--c-text-muted);line-height:1.6}
@media(min-width:768px){.steps__grid{grid-template-columns:repeat(2,1fr);gap:2rem}}
@media(min-width:1024px){.steps__grid{grid-template-columns:repeat(4,1fr)}}

/* --- Metrics --- */
.metrics__grid{display:grid;gap:1.5rem;text-align:center}
.metric{padding:2rem 1.5rem;background:var(--c-bg);border-radius:.5rem;border:1px solid var(--c-border)}
.metric__number{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:var(--heading-weight);color:var(--c-primary);line-height:1}
.metric__label{font-size:.9375rem;color:var(--c-text-muted);margin-top:.5rem}
@media(min-width:768px){.metrics__grid{grid-template-columns:repeat(3,1fr);gap:2rem}}

/* --- Service Cards --- */
.services__grid{display:grid;gap:1.5rem}
.service-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;padding:2rem;transition:transform .2s ease,box-shadow .2s ease}
.service-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.service-card__icon{width:48px;height:48px;margin-bottom:1.25rem;color:var(--c-secondary)}
.service-card h3{font-size:1.125rem;margin-bottom:.75rem;color:var(--c-primary)}
.service-card p{font-size:.9375rem;color:var(--c-text-muted);line-height:1.6;margin-bottom:1rem}
.service-card a{color:var(--c-secondary);font-weight:600;font-size:.9375rem;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease}
.service-card a:hover{border-bottom-color:var(--c-secondary)}
@media(min-width:768px){.services__grid{grid-template-columns:repeat(2,1fr);gap:2rem}}
@media(min-width:1024px){.services__grid{grid-template-columns:repeat(3,1fr)}}

/* --- Benefits --- */
.benefits{display:grid;gap:2rem;align-items:center}
.benefits__image{border-radius:.5rem;overflow:hidden;box-shadow:0 12px 36px rgba(0,0,0,.08)}
.benefits__list{background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;padding:2rem}
.benefits__list ul{display:flex;flex-direction:column;gap:.875rem}
.benefits__list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9375rem;line-height:1.6}
.benefits__list li::before{content:"\2713";display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;border-radius:50%;background:var(--c-secondary);color:#fff;font-weight:700;font-size:.75rem;margin-top:2px}
@media(min-width:768px){.benefits{grid-template-columns:1fr 1fr}}

/* --- FAQ --- */
.faq__list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:.5rem}
.faq-item{border:1px solid var(--c-border);border-radius:.375rem;overflow:hidden;transition:border-color .2s ease}
.faq-item:hover{border-color:var(--c-secondary)}
.faq-item summary{padding:1.125rem 1.25rem;font-weight:600;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;list-style:none;transition:background .2s ease;color:var(--c-text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"\FF0B";font-size:1.25rem;color:var(--c-secondary);transition:transform .3s ease}
.faq-item[open] summary::after{content:"\FF0D"}
.faq-item[open] summary{background:var(--c-bg-alt)}
.faq-item .faq-answer{padding:0 1.25rem 1.25rem;font-size:.9375rem;line-height:1.7;color:var(--c-text-muted)}
.faq-item .faq-answer a{color:var(--c-secondary);text-decoration:underline;text-underline-offset:2px}

/* --- Cases --- */
.cases-list{display:flex;flex-direction:column;gap:.625rem}
.cases-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9375rem;line-height:1.55}
.cases-list li::before{content:"\2713";display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:50%;background:var(--c-secondary);color:#fff;font-weight:700;font-size:.7rem}
.cases-faq__grid{display:grid;gap:2rem}
.panel{background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;padding:2rem}
.panel--accent{background:var(--c-bg-alt)}
.panel h2{font-size:clamp(1.25rem,2.5vw,1.5rem);margin-bottom:1.25rem}
@media(min-width:768px){.cases-faq__grid{grid-template-columns:1fr 1fr}}

/* --- Contact Form --- */
.form-section{background:var(--c-bg-alt)}
.form-grid{display:grid;gap:2rem;align-items:start}
.form-grid__info h2{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:1rem;color:var(--c-primary)}
.form-grid__info p{color:var(--c-text-muted);margin-bottom:1.5rem;line-height:1.7}
.form-grid__info ul{display:flex;flex-direction:column;gap:.75rem}
.form-grid__info li a{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:var(--c-text);transition:color .2s ease}
.form-grid__info li a:hover{color:var(--c-secondary)}
@media(min-width:768px){.form-grid{grid-template-columns:1fr 1fr;gap:3rem}}

.form{display:flex;flex-direction:column;gap:1rem}
.form__group{display:flex;flex-direction:column;gap:.375rem}
.form__label{font-size:.875rem;font-weight:600;color:var(--c-text)}
.form__input,.form__textarea{width:100%;padding:.875rem 1rem;border:1.5px solid var(--c-border);border-radius:.375rem;font-size:.9375rem;background:var(--c-bg);transition:border-color .2s ease,box-shadow .2s ease}
.form__input:focus,.form__textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(27,58,92,.08)}
.form__textarea{min-height:120px;resize:vertical}
.form__checkbox{display:flex;align-items:flex-start;gap:.625rem;font-size:.8125rem;color:var(--c-text-muted);line-height:1.4}
.form__checkbox input[type="checkbox"]{margin-top:3px;width:16px;height:16px;accent-color:var(--c-primary);flex-shrink:0}
.form__checkbox a{color:var(--c-secondary);text-decoration:underline;text-underline-offset:2px}
.form__error{color:#c53030;font-size:.8125rem;display:none}
.form__success{padding:1rem;background:#f0faf0;color:#1a6b3c;border:1px solid #c6e6c6;border-radius:.375rem;text-align:center;display:none}
.form__success.show,.form__error.show{display:block}

/* --- Calculator --- */
.calculator-section .container{max-width:960px}
.calculator-iframe-wrap{border-radius:.5rem;overflow:hidden;border:1px solid var(--c-border);background:var(--c-bg)}
.calculator-iframe-wrap iframe{width:100%;min-height:600px;border:none;display:block}

/* --- Reviews --- */
.reviews-section .container{max-width:960px}
.reviews-placeholder{text-align:center;padding:2rem;color:var(--c-text-muted);font-size:.9375rem}

/* --- CTA --- */
.cta-section{background:var(--c-primary);color:#fff;text-align:center}
.cta-section h2{color:#fff;font-size:clamp(1.5rem,3.5vw,2.25rem);margin-bottom:.75rem}
.cta-section p{color:rgba(255,255,255,.85);margin-bottom:1.75rem;font-size:1.0625rem}
.cta-section .btn--primary{background:var(--c-secondary);color:#fff;border-color:var(--c-secondary)}
.cta-section .btn--primary:hover{background:#fff;color:var(--c-primary);border-color:#fff}

/* --- Google Maps --- */
.map-section{padding:0}
.map-container{position:relative;width:100%;padding-top:56.25%;background:var(--c-bg-alt);border-radius:.5rem;overflow:hidden}
.map-container iframe,.map-container img{position:absolute;top:0;left:0;width:100%;height:100%;border:none;object-fit:cover}
.map-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--c-bg-alt)}
.map-placeholder span{padding:.75rem 1.5rem;background:var(--c-primary);color:#fff;border-radius:.375rem;font-weight:600}

/* --- Testimonials --- */
.testimonials__grid{display:grid;gap:1.5rem}
.testimonial-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;padding:2rem;text-align:center}
.testimonial-card .stars{color:#d4a017;font-size:1.25rem;margin-bottom:.75rem;letter-spacing:3px}
.testimonial-card blockquote{font-size:.9375rem;color:var(--c-text-muted);line-height:1.65;font-style:italic;margin-bottom:.75rem}
.testimonial-card .author{font-weight:700;font-size:.875rem;color:var(--c-text)}
@media(min-width:768px){.testimonials__grid{grid-template-columns:repeat(3,1fr)}}

/* --- Footer --- */
.footer{background:var(--c-primary);color:#fff;padding:3.5rem 0 1.5rem}
.footer__grid{display:grid;gap:2rem;margin-bottom:2rem}
.footer__heading{font-size:.875rem;font-weight:700;margin-bottom:.75rem;color:#fff;letter-spacing:.05em;text-transform:uppercase}
.footer__col p,.footer__col li,.footer__col a{font-size:.875rem;color:rgba(255,255,255,.75);line-height:1.65}
.footer__col a:hover{color:#fff}
.footer__col ul{display:flex;flex-direction:column;gap:.375rem}
.footer__logo img{height:42px;width:auto;margin-bottom:1rem}
.footer__social{display:flex;gap:.75rem;margin-bottom:1rem}
.footer__social a{color:rgba(255,255,255,.7);transition:color .2s ease}
.footer__social a:hover{color:#fff}
.footer__copyright{font-size:.8125rem;color:rgba(255,255,255,.5)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.5rem;text-align:center;font-size:.8125rem;color:rgba(255,255,255,.5)}
@media(min-width:768px){.footer__grid{grid-template-columns:repeat(4,1fr)}}

/* --- WhatsApp Float --- */
.whatsapp-float{position:fixed;bottom:1.5rem;right:1.5rem;width:56px;height:56px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(37,211,102,.3);z-index:9990;transition:transform .2s ease}
.whatsapp-float:hover{transform:scale(1.08)}
.whatsapp-float svg{width:28px;height:28px;fill:#fff}

/* --- Cookie Banner --- */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:rgba(26,26,26,.95);color:#fff;padding:1rem;z-index:9999;transform:translateY(100%);transition:transform .4s ease}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner__content{max-width:1140px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem;align-items:center;text-align:center}
.cookie-banner__content p{font-size:.8125rem;line-height:1.5}
.cookie-banner__content a{color:var(--c-secondary);text-decoration:underline}
.cookie-banner__actions{display:flex;gap:.5rem}
@media(min-width:768px){.cookie-banner__content{flex-direction:row;text-align:left;gap:1.5rem}}

/* --- Blog / Articles --- */
.articles__grid{display:grid;gap:1.5rem}
.article-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}
.article-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.article-card img{width:100%;height:200px;object-fit:cover}
.article-card__body{padding:1.5rem}
.article-card h3{font-size:1.125rem;margin-bottom:.5rem}
.article-card h3 a{color:var(--c-primary);transition:color .2s ease}
.article-card h3 a:hover{color:var(--c-secondary)}
.article-card time{font-size:.8125rem;color:var(--c-text-muted)}
.article-card p{font-size:.9375rem;color:var(--c-text-muted);margin-top:.5rem;line-height:1.6}
@media(min-width:768px){.articles__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.articles__grid{grid-template-columns:repeat(3,1fr)}}

/* --- Article single --- */
.article-single{max-width:760px;margin:0 auto}
.article-single h1{margin-bottom:1rem}
.article-single time{display:block;font-size:.875rem;color:var(--c-text-muted);margin-bottom:2rem}
.article-single .article-body{font-size:1.0625rem;line-height:1.8;color:var(--c-text)}
.article-single .article-body h2{font-size:1.5rem;margin:2.5rem 0 1rem;color:var(--c-primary)}
.article-single .article-body h3{font-size:1.25rem;margin:2rem 0 .75rem;color:var(--c-primary)}
.article-single .article-body p{margin-bottom:1.25rem}
.article-single .article-body ul,.article-single .article-body ol{margin:1rem 0 1.25rem 1.5rem;list-style:disc}
.article-single .article-body ol{list-style:decimal}
.article-single .article-body li{margin-bottom:.5rem}
.article-single .article-body a{color:var(--c-secondary);text-decoration:underline;text-underline-offset:2px}
.article-single .article-body img{border-radius:.375rem;margin:1.5rem 0}

.article-intro{font-size:1.125rem;line-height:1.7;color:var(--c-text-muted);border-left:3px solid var(--c-secondary);padding-left:1.25rem;margin-bottom:1.5rem}
.article-video{background:var(--c-bg-alt);border-radius:.5rem;overflow:hidden;margin:2rem 0}
.article-video__embed{position:relative;padding-bottom:56.25%;height:0}
.article-video__embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.article-video__text{padding:1.25rem}
.article-video__text h3,.article-video__text h4{font-size:1.1rem;margin-bottom:.5rem}
.article-video__text p{font-size:.9375rem;color:var(--c-text-muted);margin-bottom:.75rem}
.article-callout{background:var(--c-bg-alt);border-left:3px solid var(--c-secondary);border-radius:0 .375rem .375rem 0;padding:1.25rem 1.5rem;margin:1.5rem 0}
.article-callout h3{font-size:1rem;color:var(--c-secondary);margin-bottom:.5rem}
.article-callout p{margin-bottom:0}
.article-faq{margin:1.5rem 0}
.article-faq details{border:1px solid var(--c-border);border-radius:.375rem;margin-bottom:.75rem;overflow:hidden}
.article-faq summary{padding:1rem 1.25rem;cursor:pointer;font-size:1rem;font-weight:600;list-style:none;background:var(--c-bg-alt);color:var(--c-text)}
.article-faq summary::-webkit-details-marker{display:none}
.article-faq summary::before{content:'+';font-weight:700;margin-right:.75rem;color:var(--c-secondary)}
.article-faq details[open] summary::before{content:'\2212'}
.article-faq details div{padding:1rem 1.25rem}
.blog-clear{clear:both}
.article-card__body .btn{margin-top:.75rem}

/* --- Guide blocks --- */
.guide-block{margin-bottom:2rem}
.guide-block h3{font-size:1.125rem;margin-bottom:.75rem;color:var(--c-primary)}

/* --- Steps 3-col --- */
.steps__grid--3col{max-width:900px;margin-left:auto;margin-right:auto}
@media(min-width:768px){.steps__grid--3col{grid-template-columns:repeat(3,1fr)!important}}

/* --- About --- */
.about-hero{background:var(--c-primary);color:#fff;padding:4rem 0 5rem;text-align:center}
.about-hero__title{font-size:clamp(1.75rem,4.5vw,2.75rem);color:#fff;margin-bottom:1rem;line-height:1.15;max-width:800px;margin-left:auto;margin-right:auto}
.about-hero__title .text-secondary{color:var(--c-secondary)}
.about-hero__text{font-size:1.0625rem;color:rgba(255,255,255,.85);max-width:700px;margin:0 auto 1.5rem;line-height:1.7}
.about-hero__badges{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:1.5rem}
.about-hero__badge{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:2rem;font-size:.8125rem;font-weight:600;color:#fff}
.about-hero__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}
.btn--whatsapp{background:#25d366;color:#fff;border-color:#25d366}
.btn--whatsapp:hover{opacity:.9;transform:translateY(-1px)}

.about-founder{display:grid;gap:2.5rem;align-items:start}
.about-founder__photo{text-align:center}
.about-founder__photo img{width:200px;height:200px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;border:3px solid var(--c-border)}
.about-founder__name{font-size:1.5rem;font-weight:800;margin-bottom:.25rem;color:var(--c-primary)}
.about-founder__role{font-size:.9375rem;color:var(--c-secondary);font-weight:600;margin-bottom:1rem}
.about-founder__bio{font-size:.9375rem;color:var(--c-text-muted);line-height:1.7;max-width:400px;margin:0 auto}
.about-founder__process h2{font-size:clamp(1.25rem,3vw,1.75rem);margin-bottom:1.25rem}
.about-process-list{display:flex;flex-direction:column;gap:1rem}
.about-process-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9375rem;line-height:1.6}
.about-process-list__icon{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;border-radius:50%;background:var(--c-secondary);color:#fff;font-weight:700;font-size:.75rem;margin-top:2px}
@media(min-width:768px){.about-founder{grid-template-columns:1fr 1fr;gap:3rem}}

.about-team__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:2rem}
.about-team__grid--lawyers{max-width:900px;margin-left:auto;margin-right:auto}
.about-team__grid--support{max-width:600px;margin-left:auto;margin-right:auto}
.about-team__card{text-align:center;background:var(--c-bg);border:1px solid var(--c-border);border-radius:.5rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}
.about-team__card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.about-team__card img{width:140px;height:140px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;border:3px solid var(--c-border)}
.about-team__card h3{font-size:1.0625rem;margin-bottom:.25rem;color:var(--c-primary)}
.about-team__role{font-size:.8125rem;color:var(--c-secondary);font-weight:600;margin-bottom:.75rem}
.about-team__desc{font-size:.8125rem;color:var(--c-text-muted);line-height:1.55}
@media(min-width:768px){.about-team__grid--lawyers{grid-template-columns:repeat(3,1fr);gap:2rem}.about-team__grid--support{grid-template-columns:repeat(2,1fr);gap:2rem}}

.about-results{background:var(--c-primary);color:#fff;padding:3.5rem 0;text-align:center}
.about-results__title{font-size:clamp(1.25rem,3vw,1.75rem);color:#fff;margin-bottom:2rem}
.about-results__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:700px;margin:0 auto}
.about-results__number{display:block;font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:var(--heading-weight);color:#fff;line-height:1}
.about-results__label{display:block;font-size:.875rem;color:rgba(255,255,255,.75);margin-top:.5rem}
@media(max-width:480px){.about-results__grid{grid-template-columns:1fr}}

/* --- 404 --- */
.error-page{text-align:center;padding:5rem 0}
.error-page h1{font-size:clamp(3rem,8vw,6rem);color:var(--c-primary);margin-bottom:.5rem}
.error-page p{font-size:1.125rem;color:var(--c-text-muted);margin-bottom:2rem}

/* --- Gracias --- */
.thanks-page{text-align:center;padding:5rem 0}
.thanks-page h1{color:var(--c-primary);margin-bottom:1rem}
.thanks-page p{font-size:1.125rem;color:var(--c-text-muted);margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}

/* --- Animations --- */
.animate-on-scroll{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.animate-on-scroll.visible{opacity:1;transform:translateY(0)}

/* --- Print --- */
@media print{.header,.footer,.whatsapp-float,.cookie-banner,.calculator-iframe-wrap{display:none!important}body{color:#000;background:#fff}a{color:#000;text-decoration:underline}}

/* --- Legal pages --- */
.legal-content{max-width:760px;margin:0 auto;font-size:.9375rem;line-height:1.8}
.legal-content h2{font-size:1.375rem;margin:2rem 0 1rem;color:var(--c-primary)}
.legal-content p{margin-bottom:1rem}
.legal-content ul{margin:1rem 0 1rem 1.5rem;list-style:disc}
.legal-content li{margin-bottom:.5rem}
.legal-content a{color:var(--c-secondary);text-decoration:underline;text-underline-offset:2px}
