/* ==========================================================================
   Avalon theme — front-end styles
   Consumes the CSS variables set by inc/dynamic-css.php
   ========================================================================== */

:root{
	--av-primary:#68BF11;
	--av-secondary:#1B3668;
	--av-topbar-bg:#1B3668;
	--av-color-heading:#1B2433;
	--av-color-body:#3a4453;
	--av-color-nav:#3a4453;
	--av-color-link:#1B3668;
	--av-radius:12px;
	--av-clip:none;
	--av-font-head:"Space Grotesk",system-ui,sans-serif;
	--av-font-body:"Manrope",system-ui,sans-serif;
	--av-font-mono:"Space Mono",ui-monospace,monospace;
	--av-ink:#1B2433;
	--av-sub:#5b6573;
	--av-line:#e7e9ee;
	--av-soft:#f7f8fa;
}

*,*::before,*::after{box-sizing:border-box;}
body{
	margin:0;
	font-family:var(--av-font-body);
	color:var(--av-color-body,var(--av-ink));
	background:#fff;
	line-height:1.6;
	-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--av-font-head);letter-spacing:-.02em;line-height:1.1;margin:0;}

.av-container{max-width:1180px;margin:0 auto;padding:0 40px;width:100%;}
.av-eyebrow{
	font:700 12px/1 var(--av-font-mono);
	text-transform:uppercase;letter-spacing:.14em;color:var(--av-primary);
}
.av-ph{
	display:flex;align-items:center;justify-content:center;
	background-image:repeating-linear-gradient(135deg,#eef0f3 0 14px,#e4e7ec 14px 28px);
	font:400 12px/1 var(--av-font-mono);color:#9aa3b2;text-transform:uppercase;letter-spacing:.08em;
	border-radius:var(--av-radius);clip-path:var(--av-clip);min-height:120px;
}

/* ---------- Buttons (shape follows global setting) ---------- */
.av-btn{
	display:inline-flex;align-items:center;justify-content:center;gap:8px;
	font:700 15px/1 var(--av-font-body);padding:14px 24px;cursor:pointer;border:none;
	border-radius:var(--av-radius);clip-path:var(--av-clip);transition:transform .12s ease,filter .12s ease;
}
.av-btn:hover{filter:brightness(.96);transform:translateY(-1px);}
.av-btn--primary{background:var(--av-primary);color:var(--av-secondary);}
.av-btn--dark{background:var(--av-secondary);color:#fff;}
.av-btn--ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.28);}
.av-btn--small{padding:11px 18px;font-size:13px;}

/* ---------- Topbar ---------- */
.av-topbar{
	background:var(--av-topbar-bg,var(--av-secondary));color:#fff;
	font:500 12.5px/1 var(--av-font-body);
}
.av-topbar .av-container{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:9px;padding-bottom:9px;}
.av-topbar a{opacity:.85;}
.av-topbar .av-menu{display:flex;gap:18px;list-style:none;margin:0;padding:0;}

/* menu-below: hide in header, show once JS places it */
body.av-menu-below .av-site-header #av-below-nav{ opacity:0; pointer-events:none; }
#av-below-nav.av-placed{ opacity:1; pointer-events:auto; transition:opacity .15s ease; }

/* ---------- Header / main menu ---------- */
.av-header{background:#fff;border-bottom:1px solid #f0f1f4;}
.av-header .av-container{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:18px;padding-bottom:18px;}
.av-brand{display:flex;align-items:center;gap:9px;}
.av-brand img{max-height:38px;width:auto;}
.av-brand__mark{width:32px;height:32px;background:var(--av-primary);color:var(--av-secondary);display:flex;align-items:center;justify-content:center;font:800 18px/1 var(--av-font-head);border-radius:var(--av-radius);clip-path:var(--av-clip);}
.av-brand__name{font:700 20px/1 var(--av-font-head);color:var(--av-secondary);letter-spacing:-.02em;}
.av-nav .av-menu{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0;font:600 14px/1 var(--av-font-body);color:var(--av-color-nav,#3a4453);}
.av-nav .av-menu a:hover{color:var(--av-primary);}
.av-header__cta{flex:none;}

/* logo position right */
body.av-logo-right .av-header .av-container{flex-direction:row;}
body.av-logo-right .av-brand{order:3;}
body.av-logo-right .av-nav{order:1;}
body.av-logo-right .av-header__cta{order:2;}

/* menu over the hero (transparent overlay) */
body.av-menu-hero .av-site-header{position:absolute;left:0;right:0;top:0;z-index:20;}
body.av-menu-hero .av-header{background:transparent;border-bottom:1px solid rgba(255,255,255,.16);}
body.av-menu-hero .av-header .av-brand__name{color:#fff;}
body.av-menu-hero .av-nav .av-menu{color:rgba(255,255,255,.92);}
body.av-menu-hero.av-has-topbar .av-topbar{background:transparent;}
body.av-menu-hero .av-hero{padding-top:140px;}

/* ---------- Hero ---------- */
.av-hero{
	background:var(--av-secondary);color:#fff;position:relative;overflow:hidden;
	padding-top:104px;padding-bottom:104px;
}
.av-hero--compact{padding-top:60px;padding-bottom:60px;}
.av-hero--full{padding-top:48px;padding-bottom:48px;min-height:calc(100vh - var(--av-header-h,70px));display:flex;align-items:center;}
body.av-menu-hero .av-hero--full,body.av-menu-below .av-hero--full{min-height:100vh;}
.av-hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;width:100%;}
.av-hero--compact .av-hero__inner{grid-template-columns:1fr;}
.av-hero__content{display:flex;flex-direction:column;align-items:flex-start;gap:20px;}
.av-hero__title{font-size:52px;color:#fff;text-wrap:balance;}
.av-hero--compact .av-hero__title{font-size:40px;}
.av-hero--full .av-hero__title{font-size:64px;}
.av-hero__text{font:500 17px/1.55 var(--av-font-body);color:rgba(255,255,255,.78);max-width:460px;margin:0;}
.av-hero__buttons{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px;}
.av-hero__media{
	aspect-ratio:4/3;width:100%;
	background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.08) 0 12px,rgba(255,255,255,.03) 12px 24px);
	border:1px solid rgba(255,255,255,.18);
	border-radius:var(--av-radius);clip-path:var(--av-clip);
	display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.av-hero__media img{width:100%;height:100%;object-fit:cover;}
.av-hero__media .av-ph{background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.08) 0 12px,rgba(255,255,255,.03) 12px 24px);color:rgba(255,255,255,.55);width:100%;height:100%;border:none;}

/* ---------- Columns block (50/50, 30/70 …) ---------- */
.av-columns{padding-top:84px;padding-bottom:84px;}
.av-columns__grid{display:grid;gap:56px;align-items:center;}
.av-col{min-width:0;}
.av-col h2,.av-col h3{color:var(--av-secondary);margin:0 0 14px;font-size:32px;}
.av-col p{font:500 16px/1.6 var(--av-font-body);color:var(--av-sub);margin:0 0 10px;}
.av-col__img{aspect-ratio:4/3;border-radius:var(--av-radius);clip-path:var(--av-clip);overflow:hidden;}
.av-col__img img{width:100%;height:100%;object-fit:cover;}

/* ---------- Quote ---------- */
.av-quote{background:var(--av-secondary);color:#fff;text-align:center;padding-top:90px;padding-bottom:90px;}
.av-quote__inner{max-width:920px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:24px;}
.av-quote__mark{font:700 56px/1 var(--av-font-head);color:var(--av-primary);}
.av-quote__text{font:600 30px/1.35 var(--av-font-head);letter-spacing:-.01em;margin:0;text-wrap:balance;}
.av-quote__author{display:flex;align-items:center;gap:12px;margin-top:4px;}
.av-quote__avatar{width:46px;height:46px;border-radius:50%;background:var(--av-primary);color:var(--av-secondary);display:flex;align-items:center;justify-content:center;font:700 16px/1 var(--av-font-body);overflow:hidden;}
.av-quote__avatar img{width:100%;height:100%;object-fit:cover;}
.av-quote__name{font:700 15px/1.2 var(--av-font-body);}
.av-quote__role{font:500 13px/1.2 var(--av-font-body);color:rgba(255,255,255,.6);}

/* ---------- FAQ (native details/summary, works without JS) ---------- */
.av-faq{padding-top:84px;padding-bottom:84px;}
.av-faq__inner{max-width:860px;margin:0 auto;}
.av-faq__heading{text-align:center;color:var(--av-secondary);font-size:32px;margin-bottom:32px;}
.av-faq__list{display:flex;flex-direction:column;gap:10px;}
.av-faq__item{border:1px solid var(--av-line);border-radius:var(--av-radius);clip-path:var(--av-clip);overflow:hidden;background:#fff;}
.av-faq__q{
	list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
	padding:18px 22px;font:600 16px/1.35 var(--av-font-body);color:var(--av-secondary);
}
.av-faq__q::-webkit-details-marker{display:none;}
.av-faq__q::after{content:"+";flex:none;width:26px;height:26px;border-radius:50%;background:var(--av-primary);color:#fff;display:flex;align-items:center;justify-content:center;font:400 20px/1 var(--av-font-body);transition:transform .2s ease;}
.av-faq__item[open] .av-faq__q::after{transform:rotate(45deg);}
.av-faq__a{padding:0 22px 18px;font:500 15px/1.6 var(--av-font-body);color:var(--av-sub);margin:0;}

/* ---------- News & Blog cards ---------- */
.av-news{background:var(--av-soft);padding-top:84px;padding-bottom:84px;}
.av-blogs{padding-top:84px;padding-bottom:84px;}
.av-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:32px;}
.av-section-head h2{color:var(--av-secondary);font-size:30px;margin-top:10px;}
.av-section-head__link{font:700 14px/1 var(--av-font-body);color:var(--av-secondary);}
.av-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}

.av-card{background:#fff;border:1px solid #eceef1;border-radius:var(--av-radius);clip-path:var(--av-clip);overflow:hidden;display:flex;flex-direction:column;}
.av-card__media{aspect-ratio:16/10;background-image:repeating-linear-gradient(135deg,#eef0f3 0 12px,#e4e7ec 12px 24px);overflow:hidden;}
.av-card__media img{width:100%;height:100%;object-fit:cover;}
.av-card__body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1;}
.av-card__date{font:400 11px/1 var(--av-font-mono);color:var(--av-primary);text-transform:uppercase;letter-spacing:.06em;}
.av-card__title{font:700 18px/1.25 var(--av-font-head);color:var(--av-color-heading,var(--av-secondary));}
.av-card__excerpt{font:500 13.5px/1.5 var(--av-font-body);color:var(--av-color-body,#7a8494);margin:0;}

/* blog variant: no border card */
.av-blog-card{display:flex;flex-direction:column;gap:14px;}
.av-blog-card__media{aspect-ratio:16/11;background-image:repeating-linear-gradient(135deg,#eef0f3 0 12px,#e4e7ec 12px 24px);border-radius:var(--av-radius);clip-path:var(--av-clip);overflow:hidden;}
.av-blog-card__media img{width:100%;height:100%;object-fit:cover;}
.av-blog-card__meta{display:flex;align-items:center;gap:8px;}
.av-tag{font:700 11px/1 var(--av-font-body);color:#fff;background:var(--av-primary);padding:4px 9px;border-radius:var(--av-radius);clip-path:var(--av-clip);}
.av-read{font:500 12px/1 var(--av-font-body);color:#9aa3b2;}
.av-blog-card__title{font:700 19px/1.25 var(--av-font-head);color:var(--av-color-heading,var(--av-secondary));}

/* ---------- Footer ---------- */
.av-footer{background:var(--av-secondary);color:#fff;}
.av-footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-top:64px;padding-bottom:30px;}
.av-footer__about{display:flex;flex-direction:column;gap:16px;}
.av-footer__about p{font:500 14px/1.6 var(--av-font-body);color:rgba(255,255,255,.6);margin:0;max-width:240px;}
.av-footer .av-brand__name{color:#fff;}
.av-footer__col h4{font:700 12px/1 var(--av-font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--av-primary);margin-bottom:12px;}
.av-footer__col .av-menu{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0;font:500 14px/1 var(--av-font-body);color:rgba(255,255,255,.72);}
.av-footer__col .av-menu a:hover{color:#fff;}
.av-footer__bottom{border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:16px;padding-top:20px;padding-bottom:20px;font:500 12px/1 var(--av-font-body);color:rgba(255,255,255,.5);}

/* ---------- Generic single/page content ---------- */
.av-page{padding-top:64px;padding-bottom:84px;}
.av-page__title{color:var(--av-secondary);font-size:42px;margin-bottom:24px;}
.av-entry{font-size:17px;color:var(--av-color-body,#3a4453);}
.av-entry a{color:var(--av-color-link,var(--av-secondary));}
.av-entry h2{color:var(--av-secondary);margin:34px 0 12px;}
.av-entry img{border-radius:var(--av-radius);clip-path:var(--av-clip);}
.av-meta{font:600 12px/1 var(--av-font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--av-primary);margin-bottom:14px;}

/* ---------- Page content + block alignment (full-width pages) ----------
   Pages render their blocks inside .av-content. Normal text blocks stay
   centred and readable; Avalon sections and align-wide/full break out. */
.av-content{ width:100%; }
.av-content > *{
	max-width:720px;
	margin-left:auto;
	margin-right:auto;
	padding-left:22px;
	padding-right:22px;
}
.av-content > * + *{ margin-top:26px; }
.av-content > .alignwide{ max-width:1180px; }
.av-content > .alignfull{ max-width:none; padding-left:0; padding-right:0; }

/* Avalon block sections always span the full width (they have their own
   inner .av-container for readability). */
.av-content > .av-hero,
.av-content > .av-header,
.av-content > .av-columns,
.av-content > .av-quote,
.av-content > .av-faq,
.av-content > .av-news,
.av-content > .av-blogs{
	max-width:none;
	padding-left:0;
	padding-right:0;
	margin-top:0;
}

/* Breathing room only when a page starts with normal content (not a section). */
.av-content > *:first-child:not(.av-hero):not(.av-columns):not(.av-quote):not(.av-faq):not(.av-news):not(.av-blogs){
	margin-top:48px;
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
	.av-container{padding:0 22px;}
	.av-hero__inner,.av-columns__grid{grid-template-columns:1fr !important;}
	.av-cards{grid-template-columns:1fr;}
	.av-footer__top{grid-template-columns:1fr 1fr;}
	.av-hero__title{font-size:38px;}
	.av-nav{display:none;}
}
