/*
Theme Name: Oluma
Theme URI: https://olumadigital.com
Author: Oluma Team
Author URI: https://olumadigital.com
Description: A modern, accessible cyber security awareness theme for Oluma. Navy & gold brand styling matched to the Oluma logo, an animated daily security quiz, a high-impact animated shield visual, and beginner-friendly content sections. Template built by the Oluma Team.
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: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: oluma
Tags: education, blog, news, custom-logo, custom-menu, featured-images, full-width-template, threaded-comments, translation-ready, two-columns, right-sidebar
*/

/* ========== Design tokens (matched to Oluma logo) ========== */
:root{
  --navy-900:#081735;
  --navy-800:#0b1f47;
  --navy-700:#0f295e;
  --navy-600:#16386f;
  --navy-500:#1e4a8f;
  --gold:#f6c50b;
  --gold-300:#ffd84d;
  --gold-700:#cfa400;
  --paper:#f5f7fb;
  --paper-2:#eaeef6;
  --ink:#0c1a30;
  --text:#eaf0fb;
  --mist:#9fb2d4;
  --ok:#3ddc97;
  --bad:#f1616b;
  --line:rgba(255,255,255,.10);
  --line-d:#e4e9f2;
  --radius:18px;
  --maxw:1180px;
  --f-display:'Space Grotesk',system-ui,-apple-system,sans-serif;
  --f-body:'Inter',system-ui,-apple-system,sans-serif;
  --f-script:'Pacifico',cursive;
  --f-mono:'JetBrains Mono',ui-monospace,monospace;
}

/* ========== Base ========== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--f-body);color:var(--text);background:var(--navy-800);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--gold-300)}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4,h5{font-family:var(--f-display);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0 0 .4em}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:var(--gold);color:var(--navy-900);padding:10px 16px;border-radius:8px;z-index:999}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

.eyebrow{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--gold);opacity:.8}
.section{padding:88px 0}
.section-head{max-width:680px;margin:0 auto 48px;text-align:center}
.section-head.left{text-align:left;margin-left:0}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.6rem);margin:14px 0 12px}
.section-head .eyebrow{justify-content:center}
.section-head.left .eyebrow{justify-content:flex-start}
.section-head p{color:var(--mist);font-size:1.08rem}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.96rem;padding:14px 28px;border-radius:999px;border:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,border-color .25s ease}
.btn .arw{transition:transform .25s ease}
.btn:hover .arw{transform:translateX(4px)}
.btn-gold{background:var(--gold);color:var(--navy-900);box-shadow:0 12px 30px -10px rgba(246,197,11,.55)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 20px 44px -12px rgba(246,197,11,.7);color:var(--navy-900)}
.btn-ghost{background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--text)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--gold);color:#fff}

/* ========== Header / nav ========== */
.site-header{position:sticky;top:0;z-index:60;background:rgba(8,23,53,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{max-height:46px;width:auto}
.brand .wordmark{font-family:var(--f-script);font-size:1.6rem;color:var(--gold);line-height:1}
.brand .sub{display:block;font-family:var(--f-mono);font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);margin-top:2px}
.nav-menu{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-menu a{color:#cdd9ec;font-size:.92rem;padding:9px 13px;border-radius:9px;transition:color .2s,background .2s}
.nav-menu a:hover,.nav-menu .current-menu-item>a{color:#fff;background:rgba(255,255,255,.06)}
.nav-cta{margin-left:8px}
.nav-toggle{display:none;width:44px;height:44px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.03);align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:18px;height:2px;background:#eaf0fb;position:relative}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}
.mobile-menu{display:none;flex-direction:column;background:var(--navy-700);border-bottom:1px solid var(--line);padding:8px 24px 16px}
.mobile-menu.open{display:flex}
.mobile-menu a{color:#cdd9ec;padding:13px 6px;border-bottom:1px solid var(--line);font-size:.96rem}
.mobile-menu a:last-child{border-bottom:none}

/* ========== Hero + animated shield ========== */
.hero{position:relative;overflow:hidden;padding:84px 0 78px;background:radial-gradient(ellipse 70% 80% at 50% 0%,var(--navy-600),var(--navy-800) 70%)}
.hero-grid-bg{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(ellipse 75% 60% at 50% 18%,#000 30%,transparent 78%);
          mask-image:radial-gradient(ellipse 75% 60% at 50% 18%,#000 30%,transparent 78%)}
.hero-in{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.3rem,4.8vw,3.7rem);margin:22px 0 18px}
.hero h1 .g{color:var(--gold)}
.hero h1 .grad{background:linear-gradient(120deg,var(--gold-300),var(--gold) 60%,var(--gold-700));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.14rem;color:#c7d3e8;max-width:50ch}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-trust{margin-top:26px;display:flex;align-items:center;gap:12px;color:var(--mist);font-family:var(--f-mono);font-size:.8rem}
.hero-trust .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(246,197,11,.2)}

/* animated shield visual */
.shield-stage{position:relative;display:grid;place-items:center;min-height:400px}
.shield-rings{position:absolute;inset:0;display:grid;place-items:center}
.shield-rings .ring{position:absolute;border:1px solid rgba(246,197,11,.18);border-radius:50%;animation:ringPulse 4s ease-out infinite}
.ring.r1{width:200px;height:200px;animation-delay:0s}
.ring.r2{width:300px;height:300px;animation-delay:1s}
.ring.r3{width:400px;height:400px;animation-delay:2s}
@keyframes ringPulse{0%{transform:scale(.7);opacity:0}40%{opacity:.7}100%{transform:scale(1.05);opacity:0}}
.shield-orb{position:relative;width:230px;height:230px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 35%,var(--navy-600),var(--navy-900));border:2px solid var(--gold);
  box-shadow:0 0 60px -8px rgba(246,197,11,.5),inset 0 0 40px rgba(8,23,53,.8)}
.shield-orb svg{width:120px;height:120px}
.shield-sweep{position:absolute;inset:0;border-radius:50%;overflow:hidden}
.shield-sweep::before{content:"";position:absolute;top:50%;left:50%;width:50%;height:50%;transform-origin:top left;
  background:conic-gradient(from 0deg,rgba(246,197,11,.35),transparent 30%);animation:sweep 4s linear infinite}
@keyframes sweep{to{transform:rotate(360deg)}}
.shield-sat{position:absolute;top:50%;left:50%;width:10px;height:10px;margin:-5px;border-radius:50%;background:var(--gold);transform-origin:-115px 0;animation:orbit 11s linear infinite;box-shadow:0 0 12px var(--gold)}
.shield-sat.s2{background:#fff;transform-origin:-150px 0;animation-duration:17s;width:7px;height:7px;margin:-3px}
@keyframes orbit{to{transform:rotate(360deg)}}

/* ========== Daily quiz console ========== */
.quiz-section{background:var(--navy-900);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.quiz-shell{max-width:760px;margin:0 auto}
.quiz-console{position:relative;background:linear-gradient(160deg,var(--navy-700),var(--navy-900));border:1px solid var(--line);border-radius:22px;padding:30px;overflow:hidden;box-shadow:0 50px 90px -40px rgba(0,0,0,.8)}
.quiz-console::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(transparent 50%,rgba(246,197,11,.035) 50%);background-size:100% 6px;opacity:.6}
.q-top{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1;flex-wrap:wrap;gap:10px}
.q-status{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.04em;color:var(--gold);display:inline-flex;align-items:center;gap:9px}
.q-status .blip{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(246,197,11,.6);animation:blip 1.6s ease-out infinite}
@keyframes blip{0%{box-shadow:0 0 0 0 rgba(246,197,11,.55)}100%{box-shadow:0 0 0 12px rgba(246,197,11,0)}}
.q-date{font-family:var(--f-mono);font-size:.66rem;color:var(--mist);border:1px solid var(--line);padding:5px 11px;border-radius:999px}
.q-meter{position:relative;z-index:1;margin:18px 0 6px;height:7px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden}
.q-meter span{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--gold-700),var(--gold),var(--gold-300));transition:width .6s cubic-bezier(.2,.7,.2,1)}
.q-meter-label{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist);margin-bottom:14px;display:block}
.q-question{position:relative;z-index:1;font-family:var(--f-display);font-size:1.22rem;line-height:1.35;margin:6px 0 16px}
.q-opts{position:relative;z-index:1;display:grid;gap:10px}
.q-opt{display:flex;align-items:center;gap:13px;text-align:left;width:100%;padding:14px 16px;border-radius:13px;border:1px solid var(--line);background:rgba(255,255,255,.02);color:#dce6f5;font-size:.94rem;transition:border-color .2s,background .2s,transform .12s}
.q-opt:hover:not(:disabled){border-color:var(--gold);background:rgba(246,197,11,.07)}
.q-opt:active:not(:disabled){transform:scale(.99)}
.q-opt .k{flex:none;width:26px;height:26px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--line);font-family:var(--f-mono);font-size:.74rem;color:var(--mist)}
.q-opt.correct{border-color:var(--ok);background:rgba(61,220,151,.14);color:#eafff6}
.q-opt.correct .k{background:var(--ok);color:#04231a;border-color:var(--ok)}
.q-opt.wrong{border-color:var(--bad);background:rgba(241,97,107,.12)}
.q-opt.wrong .k{background:var(--bad);color:#2a0608;border-color:var(--bad)}
.q-opt:disabled{cursor:default}
.q-feedback{position:relative;z-index:1;margin-top:16px;max-height:0;opacity:0;overflow:hidden;transition:max-height .45s ease,opacity .4s ease}
.q-feedback.show{max-height:320px;opacity:1}
.q-verdict{font-family:var(--f-mono);font-size:.82rem;font-weight:700;letter-spacing:.02em;display:flex;align-items:center;gap:8px;margin-bottom:10px}
.q-verdict.good{color:var(--ok)}
.q-verdict.bad{color:var(--bad)}
.q-explain{font-size:.9rem;color:#c7d3e8;border-left:2px solid var(--gold);padding:2px 0 2px 14px;background:rgba(246,197,11,.05);border-radius:0 8px 8px 0}
.q-explain b{color:var(--gold-300)}
.q-cheer{margin-top:14px;font-size:.92rem;color:#dbe6f6}
.q-actions{position:relative;z-index:1;display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.q-again{font-family:var(--f-mono);font-size:.8rem;color:var(--gold);display:inline-flex;align-items:center;gap:7px;background:none;border:none;padding:0}
.q-again:hover{color:var(--gold-300)}

/* ========== Light content sections ========== */
.light{background:var(--paper);color:var(--ink)}
.light .eyebrow{color:var(--gold-700)}
.light .eyebrow::before{background:var(--gold-700)}
.light .section-head p{color:#46566f}
.alt{background:var(--paper-2)}

/* who we are / why we exist split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split .lead-q{font-family:var(--f-display);font-weight:500;font-size:clamp(1.3rem,2.4vw,1.7rem);line-height:1.4;color:var(--ink);margin-bottom:16px}
.split p{color:#46566f;font-size:1.02rem}
.split .accent{color:var(--gold-700);font-weight:600}
.figure-card{position:relative;border-radius:var(--radius);overflow:hidden;min-height:300px;display:grid;place-items:center;padding:36px;text-align:center;background:linear-gradient(160deg,var(--navy-700),var(--navy-900));border:1px solid var(--line)}
.figure-card .scan{position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(246,197,11,.045) 50%);background-size:100% 6px;opacity:.5}
.figure-card .big{position:relative;font-family:var(--f-display);font-weight:700;font-size:clamp(2.6rem,6vw,4rem);line-height:1;color:var(--gold)}
.figure-card .cap{position:relative;color:#c7d3e8;margin-top:14px;max-width:30ch}

/* drives + vision cards */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.duo-card{background:linear-gradient(160deg,var(--navy-700),var(--navy-900));border:1px solid var(--line);border-radius:var(--radius);padding:34px}
.duo-card .ico{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:rgba(246,197,11,.13);color:var(--gold);margin-bottom:18px}
.duo-card h3{font-size:1.32rem;margin-bottom:10px}
.duo-card p{color:#c7d3e8;margin:0}

/* principles */
.principles{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.principle{position:relative;background:#fff;border:1px solid var(--line-d);border-radius:var(--radius);padding:28px;overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s}
.principle::after{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-300));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.principle:hover{transform:translateY(-7px);box-shadow:0 30px 60px -30px rgba(13,29,52,.4);border-color:#dfe6f2}
.principle:hover::after{transform:scaleX(1)}
.principle .p-ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--navy-700);color:var(--gold);margin-bottom:18px;transition:transform .3s}
.principle:hover .p-ico{transform:rotate(-6deg) scale(1.07)}
.principle .num{position:absolute;top:20px;right:22px;font-family:var(--f-mono);font-size:.74rem;color:#9aa7bd}
.principle h3{font-size:1.12rem;margin-bottom:8px;color:var(--ink)}
.principle p{color:#52617a;font-size:.92rem;margin:0}

/* quote */
.quote-band{position:relative;overflow:hidden;background:radial-gradient(ellipse 60% 100% at 50% 0%,var(--navy-600),var(--navy-900))}
.quote-in{position:relative;z-index:1;max-width:840px;margin:0 auto;text-align:center}
.quote-in .mark{font-family:var(--f-display);font-size:3.6rem;line-height:.5;color:var(--gold);opacity:.85}
.quote-in blockquote{font-family:var(--f-display);font-weight:500;font-size:clamp(1.35rem,2.7vw,1.95rem);line-height:1.42;color:#fff;margin:16px 0 0}
.quote-in cite{display:block;margin-top:22px;font-family:var(--f-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-style:normal}

/* cta band */
.cta-band{background:linear-gradient(150deg,var(--navy-700),var(--navy-900));border-radius:26px;padding:58px;text-align:center;position:relative;overflow:hidden;box-shadow:0 40px 90px -40px rgba(13,29,52,.55)}
.cta-band::after{content:"";position:absolute;width:440px;height:440px;border-radius:50%;background:rgba(246,197,11,.16);filter:blur(110px);bottom:-200px;left:50%;transform:translateX(-50%)}
.cta-band .eyebrow{justify-content:center}
.cta-band h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin:16px 0 12px;position:relative;z-index:1;color:#fff}
.cta-band p{color:#c7d3e8;max-width:52ch;margin:0 auto;position:relative;z-index:1}
.cta-btns{display:flex;gap:14px;justify-content:center;margin-top:28px;flex-wrap:wrap;position:relative;z-index:1}

/* ========== Blog / generic content ========== */
.page-hero{padding:64px 0 10px;background:radial-gradient(ellipse 70% 80% at 50% 0%,var(--navy-600),var(--navy-800) 70%)}
.page-hero h1{font-size:clamp(2rem,4vw,2.8rem)}
.content-area{padding:56px 0}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{background:var(--navy-700);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(0,0,0,.6)}
.post-card .thumb{aspect-ratio:16/9;background:var(--navy-600);overflow:hidden}
.post-card .thumb img{width:100%;height:100%;object-fit:cover}
.post-card .body{padding:22px;display:flex;flex-direction:column;flex:1}
.post-card .cat{font-family:var(--f-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.post-card h3{font-size:1.1rem;margin-bottom:8px}
.post-card h3 a{color:#fff}
.post-card h3 a:hover{color:var(--gold)}
.post-card .excerpt{color:#c7d3e8;font-size:.9rem;flex:1}
.post-card .more{margin-top:14px;font-family:var(--f-mono);font-size:.74rem;color:var(--gold)}
.entry{max-width:760px;margin:0 auto}
.entry h1,.entry h2,.entry h3{color:#fff}
.entry a{text-decoration:underline}
.entry img{border-radius:12px;margin:1.4em 0}
.meta{font-family:var(--f-mono);font-size:.74rem;color:var(--mist);margin-bottom:18px}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.pagination .page-numbers{padding:9px 15px;border-radius:10px;border:1px solid var(--line);color:#cdd9ec;font-family:var(--f-mono);font-size:.85rem}
.pagination .current{background:var(--gold);color:var(--navy-900);border-color:var(--gold)}

/* ========== Footer ========== */
.site-footer{background:var(--navy-900);border-top:1px solid var(--line);padding:54px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:34px}
.foot-brand .wordmark{font-family:var(--f-script);font-size:1.7rem;color:var(--gold)}
.foot-brand p{color:var(--mist);font-size:.92rem;margin-top:12px;max-width:38ch}
.site-footer h5{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist);margin-bottom:14px}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.site-footer ul a{color:#c7d3e8;font-size:.92rem}
.site-footer ul a:hover{color:var(--gold)}
.foot-bottom{border-top:1px solid var(--line);margin-top:38px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--mist);font-family:var(--f-mono);font-size:.78rem}
.foot-bottom .badge{color:var(--gold)}

/* ========== Reveal animation ========== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ========== Responsive ========== */
@media(max-width:980px){
  .nav-menu,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .hero-in,.split,.duo{grid-template-columns:1fr;gap:40px}
  .principles{grid-template-columns:repeat(2,1fr)}
  .post-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .section{padding:60px 0}
  .principles,.post-grid,.foot-grid{grid-template-columns:1fr}
  .cta-band{padding:40px 26px}
  .quiz-console{padding:22px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
