/*
Theme Name: InnoSight Financial
Theme URI: https://innosightfinancial.com
Author: InnoSight Financial
Description: Custom retirement-planning theme for InnoSight Financial. Two-navy + gold system, gold edge stripes, RIA publish-and-hold gating. Vanilla PHP, no page builder.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: innosight
*/

:root{
  /* Two-navy + gold system */
  --deep-navy:#0F1B33;
  --navy:#1B2A4A;
  --gold:#C9A84C;
  --gold-dark:#B8942F;
  --white:#FFFFFF;
  --light-navy:#E8F0F8;
  --light-gold:#F8F4EA;
  --text:#333333;
  --text-muted:#666666;
  --maxw:1080px;
  --stripe-pad:48px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Urbanist',Arial,sans-serif;
  color:var(--text);
  background:var(--white);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;}

h1,h2,h3{margin:0;line-height:1.15;text-wrap:balance;}
h1{font-size:clamp(34px,5vw,52px);font-weight:800;}
h2{font-size:clamp(27px,3.4vw,34px);font-weight:700;color:var(--navy);}
h3{font-size:clamp(20px,2.4vw,22px);font-weight:600;color:var(--navy);}
p{margin:0 0 1.1em;text-wrap:pretty;}
.lead{font-size:clamp(19px,2.1vw,21px);font-weight:400;}
.caption{font-size:14px;color:var(--text-muted);}

/* ---------- Section + gold edge stripes ---------- */
.section{position:relative;}
.frame{
  position:relative;
  max-width:var(--maxw);
  margin:0 auto;
  padding:88px var(--stripe-pad);
}
/* gold vertical rules at the far left/right EDGE of every section,
   so nothing sits beyond them — they frame the full page height */
.section::before,
.section::after{
  content:"";
  position:absolute;
  top:0;bottom:0;
  width:4px;
  background:var(--gold);
  z-index:2;
}
.section::before{left:0;}
.section::after{right:0;}
.impact::before,
.impact::after{background:rgba(201,168,76,0.5);}

.impact{background:var(--deep-navy);color:var(--white);}
.impact h2{color:var(--white);}
.bg-white{background:var(--white);}
.bg-lightnavy{background:var(--light-navy);}

.eyebrow{
  font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--gold);margin:0 0 18px;
}
.bg-white .eyebrow,.bg-lightnavy .eyebrow{color:var(--gold-dark);}

.rule-gold{width:64px;height:4px;background:var(--gold);border:0;margin:22px 0 28px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:inherit;font-weight:600;font-size:17px;
  text-decoration:none;cursor:pointer;border-radius:6px;
  padding:16px 28px;line-height:1;white-space:nowrap;
  transition:background .18s ease,border-color .18s ease,color .18s ease;
}
.btn-primary{background:var(--gold);color:var(--deep-navy);border:1.5px solid var(--gold);}
.btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark);}
.btn-ghost-light{background:transparent;border:1.5px solid var(--navy);color:var(--navy);}
.btn-ghost-light:hover{background:var(--navy);color:var(--white);}
.btn-ghost-dark{background:transparent;border:1.5px solid var(--gold);color:var(--white);}
.btn-ghost-dark:hover{background:var(--gold);color:var(--deep-navy);}
.btn .sub{font-weight:400;opacity:.8;}

:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:var(--white);
  border-bottom:1px solid rgba(27,42,74,0.10);
  box-shadow:0 1px 0 rgba(0,0,0,0.02);
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px var(--stripe-pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{display:flex;align-items:center;text-decoration:none;}
.logo img{height:42px;width:auto;}
.logo .wordmark{font-weight:800;font-size:20px;color:var(--navy);letter-spacing:-.01em;white-space:nowrap;}
.logo .wordmark span{color:var(--gold);}
.nav{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0;}
.nav a{
  text-decoration:none;color:var(--navy);font-weight:600;font-size:16px;
  padding:6px 0;position:relative;white-space:nowrap;
}
.nav li.cta a,.nav a.btn{white-space:nowrap;}
.nav a:not(.btn):after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:var(--gold);transition:right .2s ease;
}
.nav a:not(.btn):hover:after{right:0;}
.nav-toggle{display:none;}

/* ---------- Hero (text-forward, no photo) ---------- */
.hero .frame{padding-top:104px;padding-bottom:104px;}
.hero-content{max-width:880px;}
.hero h1{margin-bottom:0;text-wrap:pretty;font-size:clamp(32px,4.4vw,48px);line-height:1.12;}
.hero .rule-gold{margin-top:30px;}
.hero .lead{margin:26px 0 8px;color:rgba(255,255,255,0.86);max-width:48ch;}
.hero .tagline{font-size:15px;color:var(--gold);font-weight:600;max-width:42ch;margin:26px 0 32px;line-height:1.5;}

/* ---------- Generic content blocks ---------- */
.measure{max-width:62ch;}
.stack-lg > * + *{margin-top:30px;}

/* ---------- Stats (Section 3) ---------- */
.stats{display:flex;gap:56px;flex-wrap:wrap;margin:36px 0 8px;}
.stat .num{font-size:clamp(40px,7vw,64px);font-weight:700;color:var(--gold);line-height:1;}
.stat .lbl{font-size:16px;color:rgba(255,255,255,0.8);margin-top:8px;max-width:30ch;}

/* ---------- Callout (Light Gold) ---------- */
.callout{
  background:var(--light-gold);border-left:4px solid var(--gold);
  padding:26px 30px;border-radius:0 6px 6px 0;margin:8px 0;
}
.callout p:last-child{margin-bottom:0;}

/* ---------- Services (Section 5) ---------- */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-top:48px;}
.service .ico{width:30px;height:30px;color:var(--gold);margin-bottom:16px;}
.service h3{margin-bottom:0;}
.service .div{width:46px;height:3px;background:var(--gold);margin:14px 0 16px;}
.service p{margin-bottom:0;}

/* ---------- Process (Section 6) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:48px;}
.step .badge{
  width:54px;height:54px;border-radius:12px;background:var(--navy);color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;margin-bottom:20px;
}
.step h3{margin-bottom:10px;}
.step p{margin-bottom:0;}

/* ---------- Segments (Section 7) ---------- */
.segments{display:grid;grid-template-columns:repeat(2,1fr);gap:36px 48px;margin-top:44px;}
.segment{display:flex;gap:18px;}
.segment .ico{flex:0 0 auto;width:26px;height:26px;color:var(--gold-dark);margin-top:4px;}
.segment p{margin-bottom:0;}

/* ---------- Meet Jun (Section 8) ---------- */
.jun-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start;}
.jun-photo{aspect-ratio:4/5;border-radius:8px;overflow:hidden;border:1px solid rgba(27,42,74,0.12);}
.jun-photo img{width:100%;height:100%;object-fit:cover;}
.video-ph{
  aspect-ratio:16/9;border-radius:8px;overflow:hidden;margin-bottom:40px;
  position:relative;border:1px solid rgba(27,42,74,0.12);
}
.video-ph .play{
  position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;
  background:rgba(201,168,76,0.95);display:flex;align-items:center;justify-content:center;
}
.video-ph iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.play svg{width:24px;height:24px;color:var(--deep-navy);margin-left:4px;}
.creds{list-style:none;padding:0;margin:8px 0 28px;}
.creds li{padding:14px 0;border-top:1px solid rgba(27,42,74,0.12);}
.creds li:last-child{border-bottom:1px solid rgba(27,42,74,0.12);}
.creds strong{color:var(--navy);}

/* ---------- Articles (Section 9) ---------- */
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:18px;}
.card{
  background:var(--white);border:1px solid rgba(27,42,74,0.12);border-radius:8px;overflow:hidden;
  text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(15,27,51,0.10);}
.card .thumb{aspect-ratio:16/10;background:var(--light-navy);}
.card .thumb img{width:100%;height:100%;object-fit:cover;}
.card .body{padding:22px 24px;}
.card .kicker{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dark);}
.card h3{font-size:19px;margin-top:10px;line-height:1.3;}
.card .more{margin-top:16px;font-weight:600;color:var(--navy);font-size:15px;}

/* ---------- Close (Section 11) ---------- */
.close-sec .frame{text-align:center;padding:96px var(--stripe-pad);}
.close-sec h2{font-size:clamp(30px,4.4vw,46px);font-weight:800;}
.close-sec .btn{margin:30px 0 22px;}
.close-sec p{color:rgba(255,255,255,0.78);max-width:40ch;margin:0 auto;}

/* ---------- Footer ---------- */
.site-footer{background:var(--deep-navy);color:rgba(255,255,255,0.82);border-top:1px solid var(--gold);}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:64px var(--stripe-pad) 40px;}
.site-footer img.flogo{height:40px;width:auto;margin-bottom:20px;}
.footer-top{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:48px;}
.site-footer .wordmark{font-weight:800;font-size:19px;color:var(--white);white-space:nowrap;}
.site-footer .wordmark span{color:var(--gold);}
.site-footer .cred{color:var(--white);font-weight:600;font-size:17px;margin-top:16px;}
.site-footer .tag{color:var(--gold);font-size:15px;margin-top:4px;}
.site-footer h4{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 16px;font-weight:700;}
.site-footer ul{list-style:none;margin:0;padding:0;}
.site-footer li{margin-bottom:10px;}
.site-footer a{color:rgba(255,255,255,0.82);text-decoration:none;}
.site-footer a:hover{color:var(--white);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.12);margin-top:44px;padding-top:24px;
  font-size:13px;color:rgba(255,255,255,0.55);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.ria-block{margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.12);font-size:13px;color:rgba(255,255,255,0.6);max-width:70ch;}

/* ---------- Generic page template ---------- */
.page-hero{background:var(--deep-navy);color:var(--white);}
.page-hero .frame{padding:72px var(--stripe-pad);}
.page-body .frame .entry-content > *{max-width:62ch;}
.page-body .frame .entry-content p{margin-bottom:1.1em;}

/* ---------- Placeholder art (used until real assets dropped in) ---------- */
.ph{position:relative;width:100%;height:100%;background-repeat:repeat;}
.ph-label{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font:600 12px/1.4 ui-monospace,SFMono-Regular,Menlo,monospace;
  color:rgba(255,255,255,0.92);text-align:center;letter-spacing:.04em;
  background:rgba(15,27,51,0.55);padding:8px 12px;border-radius:5px;white-space:nowrap;
}
.ph.dark{background-color:#16243f;background-image:repeating-linear-gradient(45deg,rgba(201,168,76,0.10) 0 10px,transparent 10px 20px);}
.ph.light{background-color:#d9e4f1;background-image:repeating-linear-gradient(45deg,rgba(27,42,74,0.10) 0 10px,transparent 10px 20px);}
.ph.light .ph-label{background:rgba(27,42,74,0.78);}
.video-ph .ph-label{top:auto;bottom:14px;left:14px;transform:none;}

/* ---------- Skip link (a11y) ---------- */
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--deep-navy);padding:10px 16px;font-weight:700;z-index:200;}
.skip-link:focus{left:8px;top:8px;}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .jun-grid{grid-template-columns:1fr;gap:36px;}
  .services-grid,.steps,.segments,.articles{grid-template-columns:1fr;gap:28px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:768px){
  :root{--stripe-pad:22px;}
  .frame{padding:56px var(--stripe-pad);}
  /* degrade gold edge stripes to a top accent */
  .section::before{left:0;right:0;top:0;bottom:auto;width:auto;height:3px;}
  .section::after{display:none;}
  .nav{display:none;}
  .nav.is-open{
    display:flex;flex-direction:column;align-items:flex-start;gap:8px;
    position:absolute;top:100%;left:0;right:0;background:var(--white);
    padding:16px var(--stripe-pad);box-shadow:0 12px 24px rgba(15,27,51,0.10);
  }
  .nav.is-open a{padding:10px 0;min-height:44px;display:flex;align-items:center;}
  .nav.is-open li.cta{width:100%;}
  .nav.is-open li.cta a{width:100%;text-align:center;}
  .nav-toggle{display:inline-flex;}
  .header-inner{position:relative;}
  .stats{gap:36px;}
  .footer-top{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto;}}


/* Learning Hub: wider article grid (page-id-1280) */
.page-id-1280 .entry-content .kb-row-layout-wrap,
.page-id-1280 .entry-content .kt-row-column-wrap { max-width: 100% !important; }
.page-id-1280 .wp-block-kadence-posts.kb-posts { grid-template-columns: repeat(3, minmax(0,1fr)) !important; gap: 28px; align-items: start; }
