/*
Theme Name: OKgestión Modern
Theme URI: https://www.okgestion.es/
Author: OKgestión / ChatGPT
Author URI: https://www.okgestion.es/
Description: Tema moderno, responsive y editable para OKgestión - Administrador de Fincas Zaragoza. Incluye páginas iniciales, formulario de contacto propio, reparación de menús y páginas SEO limpias.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: okgestion-modern
Tags: responsive-layout, custom-logo, custom-menu, block-styles, accessibility-ready
*/

:root{
  --okg-red:#be123c;
  --okg-red-dark:#8f0e2e;
  --okg-teal:#0f9f9a;
  --okg-ink:#111827;
  --okg-muted:#667085;
  --okg-soft:#f7f8fb;
  --okg-card:#ffffff;
  --okg-border:#e6e9ef;
  --okg-shadow:0 18px 50px rgba(17,24,39,.10);
  --okg-radius:24px;
  --okg-radius-sm:16px;
  --okg-max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--okg-ink);
  background:#fff;
  line-height:1.65;
  font-size:17px;
}
img{max-width:100%; height:auto}
a{color:var(--okg-red); text-decoration:none}
a:hover{text-decoration:underline}
.skip-link{position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip-link:focus{left:16px; top:16px; width:auto; height:auto; z-index:10000; background:#fff; padding:10px 14px; border-radius:8px}

.okg-container,
.site-main > .page-content,
.entry-header,
.entry-content > .wp-block-group:not(.alignfull),
.entry-content > .wp-block-columns:not(.alignfull),
.entry-content > .wp-block-cover:not(.alignfull),
.entry-content > .wp-block-query:not(.alignfull){
  width:min(100% - 32px, var(--okg-max));
  margin-inline:auto;
}
.alignwide{max-width:var(--okg-max); margin-left:auto; margin-right:auto}
.alignfull{max-width:none; width:100%}

/* Header */
.site-header{position:sticky; top:0; z-index:999; background:rgba(255,255,255,.94); backdrop-filter:blur(12px); border-bottom:1px solid rgba(230,233,239,.9)}
.okg-topbar{background:var(--okg-ink); color:#fff; font-size:14px}
.okg-topbar-inner{width:min(100% - 32px,var(--okg-max)); margin:auto; display:flex; justify-content:space-between; gap:16px; align-items:center; padding:7px 0; flex-wrap:wrap}
.okg-topbar a{color:#fff; opacity:.95; margin-left:14px}
.okg-topbar a:hover{opacity:1}
.okg-header-inner{width:min(100% - 32px,var(--okg-max)); margin:auto; display:flex; align-items:center; justify-content:space-between; gap:24px; min-height:82px}
.site-branding{display:flex; align-items:center; gap:12px; min-width:210px}
.site-branding img{display:block; max-height:58px; width:auto}
.site-title{font-size:22px; line-height:1.1; margin:0; font-weight:800}
.site-description{margin:0; font-size:13px; color:var(--okg-muted)}
.okg-default-logo{display:block; max-width:350px}
.main-navigation{display:flex; align-items:center; gap:18px}
.main-navigation ul{display:flex; flex-wrap:wrap; justify-content:flex-end; gap:4px; list-style:none; margin:0; padding:0}
.main-navigation li{position:relative}
.main-navigation a{display:block; color:var(--okg-ink); font-weight:700; font-size:15px; padding:10px 12px; border-radius:999px; text-decoration:none}
.main-navigation a:hover,.main-navigation .current-menu-item > a{background:rgba(190,18,60,.08); color:var(--okg-red)}
.main-navigation .sub-menu{position:absolute; top:100%; left:0; min-width:250px; display:none; background:#fff; padding:8px; border:1px solid var(--okg-border); border-radius:16px; box-shadow:var(--okg-shadow); justify-content:flex-start; z-index:999}
.main-navigation li:hover > .sub-menu,.main-navigation li:focus-within > .sub-menu{display:block}
.main-navigation .sub-menu a{border-radius:12px; white-space:nowrap}
.okg-nav-cta{display:inline-flex; align-items:center; justify-content:center; background:var(--okg-red); color:#fff !important; padding:10px 15px; border-radius:999px; box-shadow:0 10px 25px rgba(190,18,60,.22); text-decoration:none; font-weight:800; white-space:nowrap}
.okg-nav-cta:hover{background:var(--okg-red-dark); text-decoration:none}
.menu-toggle{display:none; border:1px solid var(--okg-border); background:#fff; color:var(--okg-ink); border-radius:999px; padding:10px 14px; font-weight:800}

/* Content */
.site-main{min-height:55vh}
.entry-header{padding:58px 0 18px}
.entry-title{font-size:clamp(2rem,5vw,4rem); line-height:1.05; margin:0 0 12px; letter-spacing:-.04em}
.entry-content{padding-bottom:60px}
.entry-content h1,.entry-content h2,.entry-content h3{line-height:1.12; letter-spacing:-.03em; color:var(--okg-ink)}
.entry-content h2{font-size:clamp(2rem,4vw,3.25rem); margin-top:0}
.entry-content h3{font-size:1.35rem}
.entry-content p{color:#3f4857}

/* Home sections */
.okg-hero{position:relative; overflow:hidden; min-height:660px; display:flex; align-items:center; isolation:isolate; background:#111827}
.okg-hero:before{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(15,23,42,.88), rgba(15,23,42,.68) 46%, rgba(15,23,42,.18)); z-index:-1}
.okg-hero .wp-block-cover__inner-container{width:min(100% - 32px,var(--okg-max)); margin:auto; color:#fff}
.okg-hero h1{color:#fff; font-size:clamp(2.65rem,6vw,5.7rem); line-height:.98; max-width:900px; margin:0 0 22px; letter-spacing:-.065em}
.okg-hero p{color:rgba(255,255,255,.90); max-width:720px; font-size:clamp(1.05rem,2vw,1.3rem)}
.okg-eyebrow{display:inline-flex; align-items:center; gap:8px; margin:0 0 18px; color:#fff; font-weight:800; letter-spacing:.08em; text-transform:uppercase; font-size:13px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.2); padding:8px 12px; border-radius:999px}
.okg-hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:28px}
.okg-button,.wp-block-button__link{display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:12px 20px; border-radius:999px; background:var(--okg-red); color:#fff !important; font-weight:850; text-decoration:none; border:0; box-shadow:0 12px 30px rgba(190,18,60,.24)}
.okg-button:hover,.wp-block-button__link:hover{background:var(--okg-red-dark); text-decoration:none}
.okg-button.secondary,.is-style-outline .wp-block-button__link{background:#fff; color:var(--okg-ink)!important; box-shadow:none; border:1px solid var(--okg-border)}
.okg-button.ghost{background:rgba(255,255,255,.14); color:#fff!important; border:1px solid rgba(255,255,255,.35); box-shadow:none}
.okg-stats{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin-top:42px; max-width:800px}
.okg-stat{background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); border-radius:18px; padding:18px; color:#fff}
.okg-stat strong{display:block; font-size:1.5rem; line-height:1.1}
.okg-stat span{display:block; color:rgba(255,255,255,.78); font-size:14px}

.okg-section{padding:90px 0}
.okg-section-soft{background:var(--okg-soft)}
.okg-section-dark{background:var(--okg-ink); color:#fff}
.okg-section-dark h2,.okg-section-dark h3{color:#fff}.okg-section-dark p{color:rgba(255,255,255,.78)}
.okg-section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:30px; margin-bottom:34px}
.okg-section-head > *{max-width:780px}
.okg-kicker{color:var(--okg-red); text-transform:uppercase; letter-spacing:.12em; font-size:13px; font-weight:850; margin-bottom:10px}
.okg-lead{font-size:1.2rem; color:#4b5563; max-width:760px}

.okg-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:20px}
.okg-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.okg-card{background:var(--okg-card); border:1px solid var(--okg-border); border-radius:var(--okg-radius); padding:28px; box-shadow:0 1px 0 rgba(17,24,39,.03); transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.okg-card:hover{transform:translateY(-4px); box-shadow:var(--okg-shadow); border-color:rgba(190,18,60,.2)}
.okg-card h3{margin-top:0}.okg-card p{margin-bottom:0}
.okg-icon{width:50px; height:50px; display:flex; align-items:center; justify-content:center; border-radius:16px; background:rgba(190,18,60,.10); color:var(--okg-red); font-size:24px; margin-bottom:18px; font-weight:900}
.okg-card-link{display:inline-flex; margin-top:18px; font-weight:850}

.okg-feature{display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center}
.okg-feature-media{border-radius:var(--okg-radius); overflow:hidden; box-shadow:var(--okg-shadow); min-height:360px; background:#ddd}
.okg-feature-media img{width:100%; height:100%; object-fit:cover; display:block}
.okg-list{list-style:none; padding:0; margin:24px 0 0}
.okg-list li{position:relative; padding-left:34px; margin:14px 0; color:#3f4857}
.okg-list li:before{content:"✓"; position:absolute; left:0; top:0; width:24px; height:24px; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; background:rgba(15,159,154,.12); color:var(--okg-teal); font-weight:900; font-size:14px}
.okg-section-dark .okg-list li{color:rgba(255,255,255,.84)}

.okg-cta{background:linear-gradient(135deg,var(--okg-red),#7f1d1d); color:#fff; border-radius:32px; padding:44px; display:grid; grid-template-columns:1.3fr auto; gap:24px; align-items:center; box-shadow:0 24px 70px rgba(190,18,60,.25)}
.okg-cta h2,.okg-cta h3{color:#fff; margin-top:0}.okg-cta p{color:rgba(255,255,255,.88); margin-bottom:0}
.okg-cta .okg-button{background:#fff; color:var(--okg-red)!important; box-shadow:none}

/* Forms */
.okg-form{background:#fff; border:1px solid var(--okg-border); border-radius:var(--okg-radius); padding:26px; box-shadow:var(--okg-shadow)}
.okg-form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px}.okg-form-full{grid-column:1/-1}
.okg-form label{display:block; font-weight:800; color:var(--okg-ink); font-size:14px; margin-bottom:6px}
.okg-form input,.okg-form textarea,.okg-form select{width:100%; border:1px solid var(--okg-border); border-radius:14px; padding:13px 14px; font:inherit; background:#fff; color:var(--okg-ink)}
.okg-form textarea{min-height:140px; resize:vertical}
.okg-form input:focus,.okg-form textarea:focus{outline:3px solid rgba(190,18,60,.14); border-color:var(--okg-red)}
.okg-form .okg-check{display:flex; gap:10px; align-items:flex-start; font-weight:500; color:var(--okg-muted)}
.okg-form .okg-check input{width:auto; margin-top:6px}.okg-hp{position:absolute; left:-9999px}
.okg-form-message{border-radius:16px; padding:14px 16px; margin-bottom:18px; font-weight:800}
.okg-form-message.ok{background:#ecfdf3; color:#027a48}.okg-form-message.error{background:#fff1f3; color:#be123c}

/* Blog */
.okg-post-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:20px; margin-top:28px}
.okg-post-card{background:#fff; border:1px solid var(--okg-border); border-radius:20px; padding:22px}
.okg-post-card h3{font-size:1.1rem; margin:.2rem 0 .6rem}.okg-post-card time{color:var(--okg-muted); font-size:14px}

/* Footer */
.site-footer{background:#0b1020; color:#fff; margin-top:40px}
.okg-footer-main{width:min(100% - 32px,var(--okg-max)); margin:auto; padding:58px 0; display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:38px}
.site-footer h2,.site-footer h3{color:#fff; margin-top:0}.site-footer p,.site-footer li{color:rgba(255,255,255,.76)}.site-footer a{color:#fff}
.okg-footer-logo{max-width:330px; background:#fff; border-radius:18px; padding:10px; margin-bottom:14px}
.okg-footer-links{list-style:none; padding:0; margin:0}.okg-footer-links li{margin:8px 0}
.okg-footer-bottom{border-top:1px solid rgba(255,255,255,.1); padding:18px 0; color:rgba(255,255,255,.7); font-size:14px}
.okg-footer-bottom-inner{width:min(100% - 32px,var(--okg-max)); margin:auto; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap}

/* Utilities and WP blocks */
.wp-block-separator{border:none; border-top:1px solid var(--okg-border); margin:48px auto}
.wp-block-quote{border-left:4px solid var(--okg-red); padding-left:18px; color:#475467}
.wp-caption-text,.wp-block-image figcaption{color:var(--okg-muted); font-size:14px; text-align:center}
.has-small-font-size{font-size:14px}.has-large-font-size{font-size:1.35rem}.has-x-large-font-size{font-size:2rem}

@media (max-width: 1000px){
  .menu-toggle{display:inline-flex; align-items:center; gap:8px}
  .main-navigation{position:absolute; top:100%; left:16px; right:16px; display:none; flex-direction:column; align-items:stretch; background:#fff; border:1px solid var(--okg-border); border-radius:20px; box-shadow:var(--okg-shadow); padding:14px; z-index:1000}
  .main-navigation.is-open{display:flex}
  .main-navigation ul{display:block}.main-navigation a{border-radius:12px}.main-navigation .sub-menu{position:static; display:block; box-shadow:none; border:0; padding:0 0 0 14px; min-width:0}
  .okg-nav-cta{display:none}
  .okg-grid,.okg-post-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .okg-feature,.okg-cta{grid-template-columns:1fr}
  .okg-footer-main{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  body{font-size:16px}.okg-header-inner{min-height:72px}.site-branding img,.okg-default-logo{max-height:46px; max-width:235px}
  .okg-topbar-inner{display:block}.okg-topbar a{margin-left:0; margin-right:12px}
  .okg-hero{min-height:620px}.okg-hero:before{background:linear-gradient(0deg, rgba(15,23,42,.92), rgba(15,23,42,.72))}
  .okg-stats,.okg-grid,.okg-grid.two,.okg-post-grid,.okg-form-grid{grid-template-columns:1fr}
  .okg-section{padding:64px 0}.okg-section-head{display:block}.okg-card{padding:22px}.okg-cta{padding:28px; border-radius:22px}.okg-footer-main{grid-template-columns:1fr; padding:42px 0}
}
