/*
Theme Name: GeneratePress Child
Theme URI: https://softwaredeobras.es
Description: Tema hijo de GeneratePress para softwaredeobras.es / ay_obras®
Author: Amplya
Author URI: https://amplya.es
Template: generatepress
Version: 1.0.0
Text Domain: generatepress-child
*/

/* ── landing: reset ── */
#ay-obras-landing *{box-sizing:border-box;margin:0;padding:0}
#ay-obras-landing{font-family:'Inter',sans-serif;color:#1a1c1e;background:#f9f9fc;overflow-x:hidden}
#ay-obras-landing .ay-primary{color:#ef7b25}
#ay-obras-landing .ay-bg-primary{background-color:#ef7b25}
#ay-obras-landing .blueprint-grid{background-image:radial-gradient(circle,#ddc1b1 1px,transparent 1px);background-size:40px 40px}
#ay-obras-landing .font-headline{font-family:'Manrope',sans-serif}
#ay-obras-landing .material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;display:inline-block;line-height:1;text-transform:none;letter-spacing:normal;white-space:nowrap;direction:ltr;vertical-align:middle}

/* ── landing: layout ── */
#ay-obras-landing .ay-section{padding:5rem 1.5rem}
#ay-obras-landing .ay-container{max-width:1280px;margin:0 auto}
#ay-obras-landing .section-title{font-family:'Manrope',sans-serif;font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;line-height:1.2;color:#1a1c1e;margin-bottom:1rem}
#ay-obras-landing .section-divider{width:80px;height:4px;background:#ef7b25;margin:0 auto 3rem;border-radius:2px}

/* ── landing: buttons ── */
#ay-obras-landing .btn-primary{background:#ef7b25;color:#fff;padding:.6rem 1.5rem;border-radius:6px;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.08em;border:none;cursor:pointer;transition:opacity .2s,transform .15s;text-decoration:none;display:inline-block;box-shadow:0 4px 14px rgba(239,123,37,.25)}
#ay-obras-landing .btn-primary:hover{opacity:.9;transform:translateY(-1px);color:#fff}
#ay-obras-landing .btn-primary-lg{padding:.9rem 2rem;font-size:1rem;display:inline-flex;align-items:center;gap:.5rem}
#ay-obras-landing .btn-outline-white{background:transparent;color:#fff;border:2px solid #fff;padding:.9rem 2rem;border-radius:6px;font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:background .2s;text-decoration:none;display:inline-block}
#ay-obras-landing .btn-outline-white:hover{background:rgba(255,255,255,.12);color:#fff}
#ay-obras-landing .btn-link{color:#ef7b25;font-weight:700;display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:0;font-size:.95rem;text-decoration:none}

/* ── landing: hero ── */
#ay-hero{min-height:88vh;display:flex;align-items:center;padding:4rem 1.5rem 5rem}
.hero-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;max-width:1280px;margin:0 auto;width:100%}
@media(min-width:1024px){.hero-grid{grid-template-columns:7fr 5fr}}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .85rem;border-radius:9999px;background:rgba(239,123,37,.1);color:#ef7b25;font-weight:700;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem}
.hero-h1{font-family:'Manrope',sans-serif;font-size:clamp(2.2rem,6vw,4.2rem);font-weight:900;line-height:1.08;letter-spacing:-.04em;margin-bottom:1.5rem;color:#1a1c1e}
.hero-h1 .gradient-text{background:linear-gradient(90deg,#c45e00,#ef7b25);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-p{font-size:1.1rem;color:#5f5e5e;max-width:520px;line-height:1.75;margin-bottom:2rem}
.hero-img-wrap{border-radius:14px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.15);border:4px solid #fff;outline:1px solid #e4e4e7}
.hero-img-wrap img{width:100%;height:auto;display:block}

/* ── landing: cards ── */
.cards-grid-3{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.cards-grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.cards-grid-3{grid-template-columns:repeat(3,1fr)}}
.feature-card{padding:1.75rem;background:#f3f3f6;border-radius:12px;border-bottom:4px solid #ef7b25;box-shadow:0 1px 4px rgba(0,0,0,.05);transition:box-shadow .2s}
.feature-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.1)}
.feature-card .icon{font-size:2.25rem;color:#ef7b25;margin-bottom:1rem;display:block}
.feature-card h3{font-family:'Manrope',sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:.6rem;color:#1a1c1e}
.feature-card p{font-size:.875rem;color:#5f5e5e;line-height:1.6}

/* ── landing: two col ── */
.two-col{display:grid;grid-template-columns:1fr;gap:3.5rem;align-items:center}
@media(min-width:1024px){.two-col{grid-template-columns:1fr 1fr}}
.two-col-img-frame{border-radius:14px;padding:4px;background:#ef7b25;box-shadow:0 20px 50px rgba(0,0,0,.2)}
.two-col-img-frame .inner{background:#18181b;border-radius:10px;padding:6px}
.two-col-img-frame img{width:100%;border-radius:6px;display:block}
.check-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.85rem}
.check-list li{display:flex;align-items:center;gap:.65rem;font-weight:600;color:#1a1c1e;font-size:.95rem}
.check-list li .material-symbols-outlined{color:#ef7b25;font-size:1.3rem;flex-shrink:0}
.icon-list{display:flex;flex-direction:column;gap:1.25rem}
.icon-list-item{display:flex;gap:.9rem}
.icon-box{width:44px;height:44px;border-radius:10px;background:rgba(239,123,37,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-box .material-symbols-outlined{color:#ef7b25}
.icon-list-item h4{font-weight:700;color:#1a1c1e;margin-bottom:.2rem;font-size:.95rem}
.icon-list-item p{font-size:.85rem;color:#5f5e5e;line-height:1.5}

/* ── landing: cards 2 col ── */
.cards-grid-2{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.cards-grid-2{grid-template-columns:1fr 1fr}}
.card-white{background:#fff;padding:2rem;border-radius:14px;box-shadow:0 1px 4px rgba(0,0,0,.06);border:1px solid rgba(138,114,101,.15)}
.card-white .icon{font-size:2.25rem;color:#ef7b25;margin-bottom:1rem;display:block}
.card-white h3{font-family:'Manrope',sans-serif;font-size:1.3rem;font-weight:700;margin-bottom:.85rem;color:#1a1c1e}
.card-white p{color:#5f5e5e;line-height:1.65;margin-bottom:1.25rem;font-size:.9rem}
.sub-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}
.sub-list li{display:flex;gap:.4rem;align-items:flex-start;font-size:.875rem;color:#5f5e5e}
.sub-list li .material-symbols-outlined{color:#ef7b25;font-size:.95rem;margin-top:2px;flex-shrink:0}

/* ── landing: flip cards ── */
.flip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(min-width:640px){.flip-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.flip-grid{grid-template-columns:repeat(4,1fr)}}
.flip-card{perspective:1000px;cursor:pointer;min-height:240px}
.flip-inner{position:relative;width:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;height:100%}
.flip-card:hover .flip-inner,.flip-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-front,.flip-back{border-radius:12px;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem;text-align:center}
.flip-front{background:#fff;border:1px solid rgba(239,123,37,.15);box-shadow:0 1px 4px rgba(0,0,0,.05);min-height:160px}
.flip-back{background:#ef7b25;transform:rotateY(180deg);justify-content:flex-start;padding:1.1rem;align-items:flex-start;text-align:left;position:absolute;inset:0;overflow:hidden}
.flip-icon{font-size:2rem;color:#ef7b25;margin-bottom:.5rem;display:block}
.flip-title{font-family:'Manrope',sans-serif;font-weight:700;font-size:.85rem;color:#1a1c1e;line-height:1.3}
.flip-hint{font-size:.7rem;color:#aaa;margin-top:.35rem}
.flip-icon-sm{font-size:1.2rem;color:rgba(255,255,255,.8);margin-bottom:.3rem;display:block;flex-shrink:0}
.flip-back h4{font-family:'Manrope',sans-serif;font-weight:700;font-size:.82rem;color:#fff;margin-bottom:.35rem;line-height:1.3;flex-shrink:0}
.flip-back p{font-size:.72rem;color:rgba(255,255,255,.92);line-height:1.45;overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical}
.flip-btn{display:inline-block;margin-top:auto;padding-top:.4rem;background:#fff;color:#ef7b25;font-weight:700;font-size:.72rem;padding:.3rem .75rem;border-radius:4px;text-decoration:none;flex-shrink:0;align-self:flex-start}
.flip-btn:hover{background:#fff3e8;color:#ef7b25}

/* ── landing: videos ── */
.videos-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.videos-grid{grid-template-columns:repeat(2,1fr)}}
.video-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.06);border:1px solid rgba(138,114,101,.1)}
.video-card .yt-thumb{position:relative;aspect-ratio:16/9;cursor:pointer;overflow:hidden;background:#18181b}
.video-card .yt-thumb img{width:100%;height:100%;object-fit:cover;opacity:.85;transition:transform .4s}
.video-card .yt-thumb:hover img{transform:scale(1.04)}
.video-card .play-sm{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.video-card .play-sm-btn{width:52px;height:52px;background:#ef7b25;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(239,123,37,.5)}
.video-card .play-sm-btn .material-symbols-outlined{color:#fff;font-size:1.6rem}
.video-card .vc-info{padding:1rem}
.video-card .vc-info h4{font-family:'Manrope',sans-serif;font-weight:700;font-size:.95rem;color:#1a1c1e;margin-bottom:.3rem}
.video-card .vc-info p{font-size:.8rem;color:#5f5e5e}

/* ── landing: faq ── */
.faq-item{border-bottom:1px solid #e4e4e7;padding-bottom:1.25rem;margin-bottom:1.25rem}
#ay-obras-landing .faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;text-align:left;background:#f3f3f6!important;border:none!important;border-radius:6px;cursor:pointer;padding:.75rem 1rem;outline:none!important;box-shadow:none!important;transition:background .2s}
#ay-obras-landing .faq-question .q-text{font-size:1rem;font-weight:700;color:#1a1c1e;line-height:1.4;padding-right:1rem;transition:color .2s}
#ay-obras-landing .faq-question:hover,#ay-obras-landing .faq-question:focus{background:#ef7b25!important;color:#fff!important}
#ay-obras-landing .faq-question:hover .q-text,#ay-obras-landing .faq-question:focus .q-text{color:#fff!important}
#ay-obras-landing .faq-question .material-symbols-outlined{color:#ef7b25;transition:transform .3s,color .2s;flex-shrink:0}
#ay-obras-landing .faq-question:hover .material-symbols-outlined,#ay-obras-landing .faq-question:focus .material-symbols-outlined{color:#fff!important}
#ay-obras-landing .faq-question[aria-expanded="true"] .material-symbols-outlined{transform:rotate(180deg)}
#ay-obras-landing button:hover,#ay-obras-landing button:focus{background:none!important;color:inherit}
.faq-answer{display:none;padding-top:.85rem;color:#5f5e5e;line-height:1.7;font-size:.9rem}
.faq-answer.open{display:block}

/* ── landing: cta ── */
.cta-box{background:#ef7b25;border-radius:18px;padding:4rem 2rem;position:relative;overflow:hidden;box-shadow:0 20px 50px rgba(239,123,37,.3);text-align:center}
@media(min-width:768px){.cta-box{padding:5rem 4rem}}
.cta-box h2{font-family:'Manrope',sans-serif;font-size:clamp(1.6rem,4vw,2.8rem);font-weight:900;color:#fff;margin-bottom:1.25rem;line-height:1.15}
.cta-box p{color:rgba(255,255,255,.9);font-size:1rem;margin-bottom:2.5rem;max-width:480px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.cta-deco{position:absolute;top:-2rem;right:-2rem;opacity:.07}
.contact-info{display:flex;gap:1.25rem;flex-wrap:wrap;justify-content:center;margin-top:1.75rem}
.contact-info a{color:rgba(255,255,255,.9);font-weight:600;text-decoration:none;display:flex;align-items:center;gap:.35rem;font-size:.9rem}
.contact-info a:hover{color:#fff;text-decoration:underline}
