/* === TOKENS === */
:root {
  --navy:#0d1117; --ink:#1a1f2e; --slate:#3d4659; --mist:#8892a4;
  --silver:#d0d5df; --fog:#f0f2f5; --white:#fff;
  --blue:#2563eb; --blue-dim:#1d4ed8; --blue-pale:#eff6ff;
  --serif:'Shippori Mincho',serif; --sans:'Noto Sans JP',sans-serif; --en:'DM Sans',sans-serif;
  --nav-h:68px; --pad:clamp(20px,6vw,80px); --ease:cubic-bezier(.25,.46,.45,.94);
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block} a{color:inherit;text-decoration:none} ul{list-style:none} address{font-style:normal}

/* === TYPOGRAPHY === */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.45}
h1{font-size:clamp(28px,4.5vw,56px)} h2{font-size:clamp(22px,3vw,38px)}
h3{font-size:clamp(17px,2vw,22px)} h4{font-size:16px}
p{font-size:15px;color:var(--slate);line-height:1.9}
em{font-style:normal} strong{font-weight:500;color:var(--ink)}

/* === LAYOUT === */
.container{max-width:1200px;margin:0 auto;padding-inline:var(--pad)}
section,.s-pad{padding-block:88px}
.bg-tint{background:var(--fog)} .bg-dark{background:var(--navy)} .bg-blue{background:var(--blue)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr)}
.text-white{color:var(--white)} .text-dim{color:rgba(255,255,255,.75)}
.text-center{text-align:center}

/* === LABEL / SECTION HEAD === */
.label{font-family:var(--en);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:10px;margin-bottom:14px}
.label::before{content:'';width:22px;height:1px;background:currentColor}
.label-light{color:#60a5fa}
.section-head{margin-bottom:48px}
.section-head p{margin-top:12px;max-width:520px}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--en);font-size:13px;font-weight:500;padding:12px 22px;border-radius:7px;transition:all .22s var(--ease)}
.btn-primary{background:var(--blue);color:var(--white)}
.btn-primary:hover{background:var(--blue-dim);transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.3)}
.btn-outline{border:1px solid var(--silver);color:var(--slate)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-white{background:var(--white);color:var(--ink)}
.btn-white:hover{background:var(--fog);transform:translateY(-1px)}
.btn-ghost{color:var(--blue);font-family:var(--en);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:gap .18s}
.btn-ghost:hover{gap:10px}

/* === TAGS === */
.tag{font-family:var(--en);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--blue-pale);color:var(--blue);padding:4px 10px;border-radius:100px;display:inline-block}
.tag-dark{background:rgba(96,165,250,.14);color:#60a5fa;border:1px solid rgba(96,165,250,.24)}
.tag-dot::before{content:'';display:inline-block;width:7px;height:7px;border-radius:50%;background:currentColor;margin-right:7px;vertical-align:middle}
.tag-row{display:flex;flex-wrap:wrap;gap:6px}

/* === ICON CIRCLE (shared) === */
.ico-circle{display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}
.ico-circle--blue{background:var(--blue-pale)}.ico-circle--blue svg{color:var(--blue)}

/* === CARDS === */
.card{border:1px solid var(--fog);border-radius:14px;padding:28px;background:var(--white);transition:border-color .22s,box-shadow .22s,transform .22s}
.card:hover{border-color:var(--blue);box-shadow:0 10px 36px rgba(37,99,235,.08);transform:translateY(-3px)}
.card-icon{width:42px;height:42px;border-radius:10px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card-icon svg{width:19px;height:19px;color:var(--blue)}
.card-desc{font-size:13px;margin-top:6px}

/* === FADE === */
.fade{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade.on{opacity:1;transform:none}

/* === GLOBAL NAV === */
body>nav{position:fixed;inset:0 0 auto;height:var(--nav-h);padding-inline:var(--pad);display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,.06);z-index:100}
.nav-logo{display:flex;align-items:center;gap:9px}
.nav-logo svg{width:26px;height:26px;flex-shrink:0}
.nav-logo-text{font-family:var(--en);font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase}
body>nav>ul{display:flex;align-items:center;gap:28px}
body>nav>ul a{font-family:var(--en);font-size:13px;color:var(--slate);transition:color .18s}
body>nav>ul a:hover,body>nav>ul a.active{color:var(--blue)}
.nav-cta{background:var(--blue);color:var(--white)!important;padding:8px 18px;border-radius:6px}
.nav-cta:hover{background:var(--blue-dim)!important}

/* === BREADCRUMB === */
.breadcrumb{display:flex;gap:8px;align-items:center;font-family:var(--en);font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.7);margin-bottom:22px}
.breadcrumb a{color:inherit;transition:color .18s}
.breadcrumb-light{color:var(--mist)}
.breadcrumb-light a:hover{color:var(--blue)}

/* === PAGE HERO === */
.page-hero{padding:calc(var(--nav-h) + 72px) var(--pad) 72px;background:var(--navy);position:relative;overflow:hidden}
.page-hero::after{content:attr(data-word);position:absolute;bottom:-10px;right:-10px;font-family:var(--en);font-size:min(18vw,200px);font-weight:700;color:rgba(255,255,255,.03);line-height:1;pointer-events:none;white-space:nowrap}
.page-hero h1{color:var(--white);max-width:640px;margin-bottom:16px}
.page-hero h1 em{color:#60a5fa}
.page-hero>p{color:rgba(255,255,255,.75);max-width:500px}
.cta-row{margin-top:28px}

/* === FOOTER (single template, cloned via JS) === */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);padding:52px var(--pad) 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:44px}
.footer-brand p:first-child{font-family:var(--en);font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.footer-brand p:last-child{font-family:var(--serif);font-size:14px;color:rgba(255,255,255,.75)}
.footer-col h4{font-family:var(--en);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:14px;font-weight:500}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:13px;color:rgba(255,255,255,.7);transition:color .18s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;align-items:center;font-size:11px}
.footer-bottom nav{display:flex;gap:18px}
.footer-bottom nav a{font-size:11px;color:rgba(255,255,255,.7);transition:color .18s}
.footer-bottom nav a:hover{color:var(--white)}
/* Slim footer variant */
.site-footer.slim{padding:22px var(--pad)}
.site-footer.slim .footer-grid{display:none}
.site-footer.slim .footer-bottom{border:none;padding-top:0}

/* === CTA BAND (consolidated) === */
.cta-band{padding:80px var(--pad);text-align:center}
.cta-band h2{color:var(--white);margin-bottom:12px}
.cta-band p{color:rgba(255,255,255,.75);margin-bottom:28px}
.cta-green{background:linear-gradient(135deg,#064e3b,#065f46)}
.cta-brown{background:linear-gradient(135deg,#1c1409,#292013)}
.cta-purple{background:linear-gradient(135deg,#1e1040,#2e1065)}
.cta-teal{background:linear-gradient(135deg,#065f46,#059669)}

/* === SHARED COMPONENTS === */
/* Challenge */
.challenge-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}
.challenge-item{background:var(--white);border-radius:10px;padding:18px 22px;display:flex;gap:12px;align-items:flex-start}
.challenge-item svg{width:16px;height:16px;color:var(--blue);flex-shrink:0;margin-top:3px}
.challenge-item p{font-size:14px}
.challenge-note{background:var(--white);border-left:3px solid var(--blue);border-radius:0 10px 10px 0;padding:18px 24px}
.challenge-note p{font-family:var(--serif);font-size:17px;color:var(--navy)}

/* Chain */
.chain{background:var(--fog);border-radius:16px;padding:36px;display:flex;flex-direction:column;gap:8px}
.chain-node{background:var(--white);border:1px solid var(--fog);border-radius:10px;padding:14px 18px;display:flex;align-items:center;gap:12px}
.chain-node.active{border-color:var(--blue);background:var(--blue-pale)}
.chain-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0}
.chain-node p{font-size:13px;font-weight:500;color:var(--slate)}
.chain-node.active p{color:var(--navy)}
.chain-arrow{text-align:center;color:var(--mist);font-size:13px}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;margin-top:40px}
.step{padding:32px 26px;border-right:1px solid rgba(255,255,255,.06)}
.step:last-child{border-right:none}
.step-num{font-family:var(--en);font-size:30px;font-weight:700;color:rgba(255,255,255,.45);margin-bottom:16px;line-height:1}
.step h4{color:var(--white);margin-bottom:8px}
.step p{font-size:13px;color:rgba(255,255,255,.7)}

/* Outcomes */
.outcome-list{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px}
.outcome-item{display:flex;gap:16px;padding:26px;border:1px solid var(--fog);border-radius:12px}
.outcome-icon{width:36px;height:36px;border-radius:8px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.outcome-icon svg{width:16px;height:16px;color:var(--blue)}
.outcome-item h4{color:var(--navy);margin-bottom:4px}
.outcome-item p{font-size:13px}

/* Approach list */
.approach-list{border:1px solid var(--fog);border-radius:14px;overflow:hidden;margin-top:40px}
.approach-item{padding:22px 26px;border-bottom:1px solid var(--fog);display:flex;gap:18px}
.approach-item:last-child{border-bottom:none}
.approach-num{font-family:var(--en);font-size:12px;font-weight:500;color:var(--blue);flex-shrink:0;padding-top:2px}
.approach-item h4{color:var(--navy);margin-bottom:4px}
.approach-item p{font-size:13px}

/* Other services */
.other-strip{padding:56px var(--pad);background:var(--fog)}
.other-strip h3{font-size:20px;color:var(--navy);margin-bottom:22px}
.service-links{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.service-link{display:block;padding:20px 22px;background:var(--white);border:1px solid transparent;border-radius:11px;transition:all .22s}
.service-link:hover{border-color:var(--blue);transform:translateY(-2px)}
.service-link h4{font-size:14px;color:var(--navy);margin-bottom:6px}
.service-link span{font-family:var(--en);font-size:11px;color:var(--blue)}

/* Philosophy list (dark) */
.phi-list{border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden}
.phi-item{padding:28px 32px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;gap:18px}
.phi-item:last-child{border-bottom:none}
.phi-item>span{font-family:var(--en);font-size:12px;color:#60a5fa;flex-shrink:0}
.phi-item h4{color:var(--white);margin-bottom:6px}
.phi-item p{font-size:13.5px;color:rgba(255,255,255,.7)}

/* === HOME === */
#p-home>header{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;padding-top:var(--nav-h);background:linear-gradient(135deg,var(--fog) 0%,var(--white) 55%)}
.hero-body{padding:72px var(--pad);display:flex;flex-direction:column;justify-content:center}
.hero-eyebrow{font-family:var(--en);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:10px;margin-bottom:22px}
.hero-eyebrow::before{content:'';width:22px;height:1px;background:var(--blue)}
#p-home h1{font-size:clamp(32px,5vw,62px);color:var(--navy);margin-bottom:18px}
#p-home h1 em{color:var(--blue)}
.hero-body>p{max-width:400px;margin-bottom:32px}
.hero-actions{display:flex;gap:12px}
.hero-visual{background:var(--navy);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.hero-visual-img{position:absolute;inset:-20%;width:140%;height:140%;background-image:url('https://images.unsplash.com/photo-1558591710-4b4a1ae0f04d?w=1200&q=80');background-size:cover;background-position:center;will-change:transform}
.hero-visual-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,17,43,.5) 0%,rgba(30,58,138,.3) 100%);z-index:1}
.orb-wrap{position:absolute;inset:0;pointer-events:none;z-index:2}
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.35;animation:float 8s var(--ease) infinite alternate}
.orb-1{width:280px;height:280px;background:#1d4ed8;top:10%;left:5%}
.orb-2{width:200px;height:200px;background:#0891b2;top:40%;right:5%;animation-delay:-3s}
.orb-3{width:160px;height:160px;background:#7c3aed;bottom:10%;left:25%;animation-delay:-5s}
@keyframes float{to{transform:translate(14px,-14px) scale(1.06)}}

.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:40px}
.svc-card{display:block;border:1px solid var(--fog);border-radius:14px;overflow:hidden;transition:all .25s}
.svc-card:hover{border-color:var(--blue);box-shadow:0 12px 40px rgba(37,99,235,.08);transform:translateY(-3px)}
.svc-card-head{padding:26px 28px 20px;background:var(--fog);display:flex;justify-content:space-between;align-items:flex-start;transition:background .25s}
.svc-card:hover .svc-card-head{background:var(--blue-pale)}
.svc-card-num{font-family:var(--en);font-size:11px;letter-spacing:.15em;color:var(--blue);text-transform:uppercase}
.svc-icon{width:34px;height:34px;background:var(--white);border-radius:8px;display:flex;align-items:center;justify-content:center}
.svc-icon svg{width:15px;height:15px;color:var(--blue)}
.svc-card-body{padding:22px 28px 28px}
.svc-card-body h3{font-size:17px;color:var(--navy);margin-bottom:8px}
.svc-card-body p{font-size:13px}

/* === ABOUT === */
.deco-word{font-family:var(--en);font-size:clamp(64px,12vw,130px);font-weight:700;line-height:1;user-select:none;pointer-events:none}
.deco-word--light{color:var(--fog)}
.deco-word--dark{color:rgba(255,255,255,.04)}
.company-table{width:100%;border-collapse:collapse}
.company-table tr{border-bottom:1px solid rgba(255,255,255,.07)}
.company-table td{padding:15px 0;font-size:13px;vertical-align:top}
.company-table td:first-child{font-family:var(--en);font-size:11px;letter-spacing:.07em;color:rgba(255,255,255,.7);width:136px}
.company-table td:last-child{color:rgba(255,255,255,.7)}

/* === SERVICE LIST === */
.svc-full-list{display:flex;flex-direction:column;gap:24px}
.svc-full{display:grid;grid-template-columns:260px 1fr;border:1px solid var(--fog);border-radius:16px;overflow:hidden;transition:all .28s}
.svc-full:hover{border-color:var(--blue);box-shadow:0 12px 44px rgba(37,99,235,.09);transform:translateY(-2px)}
.svc-full-aside{background:var(--fog);padding:36px 32px;display:flex;flex-direction:column;justify-content:space-between;transition:background .28s}
.svc-full:hover .svc-full-aside{background:var(--blue-pale)}
.svc-full-body{padding:36px 44px}
.svc-full-body h3{color:var(--navy);margin-bottom:10px}
.svc-full-body>p{margin-bottom:20px}
.svc-full-body ul{display:flex;flex-direction:column;gap:8px;margin-bottom:28px}
.svc-full-body li{font-size:13.5px;color:var(--slate);display:flex;gap:10px}
.svc-full-body li::before{content:'→';color:var(--blue);flex-shrink:0}

/* === JOURNAL === */
.journal-hero{padding:calc(var(--nav-h) + 56px) var(--pad) 48px;border-bottom:1px solid var(--fog)}
.journal-hero h1{color:var(--navy);margin-bottom:10px}
.filter-bar{display:flex;gap:4px;padding:18px var(--pad);border-bottom:1px solid var(--fog)}
.filter-btn{font-family:var(--en);font-size:12px;padding:6px 14px;border-radius:100px;border:1px solid var(--fog);background:var(--white);color:var(--slate);cursor:pointer;transition:all .18s}
.filter-btn.active,.filter-btn:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}
.featured-article{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--fog);border-radius:16px;overflow:hidden;margin-bottom:40px;transition:all .28s}
.featured-article:hover{box-shadow:0 14px 44px rgba(0,0,0,.08);transform:translateY(-2px)}
.article-cover{min-height:260px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background-size:cover;background-position:center}
.article-cover-word{font-family:var(--en);font-size:88px;font-weight:700;opacity:.12;color:var(--white);text-shadow:0 2px 12px rgba(0,0,0,.3)}
.article-badge{position:absolute;top:18px;left:18px;background:#60a5fa;color:var(--navy);font-family:var(--en);font-size:10px;font-weight:500;letter-spacing:.1em;padding:3px 11px;border-radius:100px}
.featured-body{padding:44px 40px}
.article-meta{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.article-cat{font-family:var(--en);font-size:11px;font-weight:500;letter-spacing:.12em;color:var(--blue);text-transform:uppercase}
.article-date{font-size:12px;color:var(--mist)}
.featured-body h2{font-size:clamp(19px,2.4vw,26px);color:var(--navy);margin-bottom:12px}
.featured-body>p{font-size:13.5px;margin-bottom:24px}
.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.article-card{display:block;transition:transform .22s}
.article-card:hover{transform:translateY(-4px)}
.article-thumb{border-radius:10px;overflow:hidden;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background-size:cover;background-position:center}
.article-thumb-word{font-family:var(--en);font-size:32px;font-weight:700;opacity:.15;color:var(--white);text-shadow:0 2px 8px rgba(0,0,0,.3)}
.article-card h3{font-size:16px;color:var(--navy);margin-bottom:7px}
.article-card p{font-size:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pagination{display:flex;gap:5px;justify-content:center;padding-top:44px}
.pagination a{width:36px;height:36px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--en);font-size:13px;color:var(--slate);border:1px solid var(--fog);transition:all .18s}
.pagination a:hover,.pagination a.active{background:var(--blue);color:var(--white);border-color:var(--blue)}
.newsletter{background:var(--navy);padding:60px var(--pad);display:flex;align-items:center;justify-content:space-between;gap:36px}
.newsletter h3{font-family:var(--serif);font-size:21px;color:var(--white);margin-bottom:6px}
.newsletter p{color:rgba(255,255,255,.7)}
.newsletter-form{display:flex;gap:10px;flex-shrink:0}
.newsletter input{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.15);color:var(--white);width:220px}
.newsletter input::placeholder{color:rgba(255,255,255,.6)}
.newsletter input:focus{border-color:#60a5fa}

/* === JOURNAL DETAIL === */
#p-journal-detail article{max-width:740px;margin:0 auto;padding:calc(var(--nav-h) + 52px) var(--pad) 80px}
#p-journal-detail article header{background:none;padding:0;overflow:visible}
#p-journal-detail article header::after{display:none}
#p-journal-detail h1{color:var(--navy);margin-bottom:18px;font-size:clamp(24px,3.5vw,38px)}
.article-lead{font-size:16px;color:var(--slate);line-height:1.9;border-left:3px solid var(--blue);padding-left:18px;margin-bottom:36px}
.article-hero{width:100%;height:340px;border-radius:14px;background:linear-gradient(135deg,#1e3a8a,#1e40af);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:44px;background-size:cover;background-position:center}
.article-hero-word{font-family:var(--en);font-size:110px;font-weight:700;opacity:.1;color:var(--white);text-shadow:0 2px 12px rgba(0,0,0,.3)}
#p-journal-detail article h2{font-size:21px;color:var(--navy);border-left:3px solid var(--blue);padding-left:14px;margin:40px 0 14px}
#p-journal-detail article h3{font-size:17px;color:var(--navy);margin:28px 0 10px}
#p-journal-detail article>p{margin-bottom:20px}
blockquote{background:var(--navy);border-radius:12px;padding:28px 32px;margin:32px 0}
blockquote p{font-family:var(--serif);font-size:16px;color:var(--white);line-height:1.75}
blockquote cite{display:block;font-family:var(--en);font-size:12px;color:#60a5fa;margin-top:12px}
#p-journal-detail article ul{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
#p-journal-detail article li{display:flex;gap:10px;font-size:15px;color:var(--slate)}
#p-journal-detail article li::before{content:'›';color:var(--blue);font-size:17px;flex-shrink:0}

/* === RESOURCES === */
.resources-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.resource-card{border:1px solid var(--fog);border-radius:14px;overflow:hidden;display:block;transition:all .28s}
.resource-card:hover{border-color:var(--blue);box-shadow:0 12px 36px rgba(37,99,235,.08);transform:translateY(-4px)}
.resource-cover{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative}
.resource-cover-label{position:absolute;top:14px;left:14px}
.resource-cover-text{font-family:var(--en);font-size:19px;font-weight:700;color:var(--white);text-align:center;line-height:1.3;padding:18px}
.resource-body{padding:22px}
.resource-body h3{font-size:15px;color:var(--navy);margin-bottom:7px}
.resource-body p{font-size:13px;margin-bottom:16px}
.dl-btn{display:flex;align-items:center;gap:7px;font-family:var(--en);font-size:12px;font-weight:500;color:var(--blue);background:var(--blue-pale);border:1px solid rgba(37,99,235,.14);padding:8px 12px;border-radius:6px;transition:all .2s}
.resource-card:hover .dl-btn{background:var(--blue);color:var(--white);border-color:var(--blue)}
.dl-btn svg{width:12px;height:12px}

/* === RESOURCES DETAIL === */
.resource-detail{display:grid;grid-template-columns:1fr 400px;min-height:calc(100vh - var(--nav-h))}
.resource-info{padding:calc(var(--nav-h) + 52px) var(--pad) 80px}
.resource-info h1{font-size:clamp(22px,3vw,36px);margin-top:16px;margin-bottom:14px}
/* Mockup (shared) */
.mockup{border-radius:10px;overflow:hidden;box-shadow:0 14px 40px rgba(0,0,0,.13)}
.mockup-face{display:flex;flex-direction:column;justify-content:flex-end}
.mockup-title{font-family:var(--en);font-weight:700;color:var(--white);line-height:1.3}
.mockup-lines{display:flex;flex-direction:column}
.mockup-lines span{background:rgba(255,255,255,.2);border-radius:2px}
.mockup-foot{background:var(--white);display:flex;justify-content:space-between}
.mockup-foot span{color:var(--mist);font-family:var(--en);letter-spacing:.06em}
.mockup--lg{width:210px}.mockup--lg .mockup-face{height:280px;padding:22px;background:linear-gradient(135deg,#1e3a8a,#2563eb)}.mockup--lg .mockup-title{font-size:14px;margin-bottom:10px}.mockup--lg .mockup-lines{gap:5px}.mockup--lg .mockup-lines span{height:3px}.mockup--lg .mockup-foot{padding:9px 14px}.mockup--lg .mockup-foot span{font-size:8px}
.mockup--md{width:140px}.mockup--md .mockup-face{height:190px;padding:16px}.mockup--md .mockup-title{font-size:11px;margin-bottom:8px}.mockup--md .mockup-lines{gap:4px}.mockup--md .mockup-lines span{height:2.5px}.mockup--md .mockup-foot{padding:7px 10px}.mockup--md .mockup-foot span{font-size:7px}
.mockup--sm{width:110px}.mockup--sm .mockup-face{height:150px;padding:12px}.mockup--sm .mockup-title{font-size:9px;margin-bottom:6px}.mockup--sm .mockup-lines{gap:3px}.mockup--sm .mockup-lines span{height:2px}.mockup--sm .mockup-foot{padding:5px 8px}.mockup--sm .mockup-foot span{font-size:6px}
.inside-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;margin-bottom:36px}
.inside-item{display:flex;gap:11px;background:var(--fog);border-radius:9px;padding:13px 15px}
.inside-check{width:17px;height:17px;border-radius:50%;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.inside-check svg{width:8px;height:8px;color:var(--blue)}
.inside-item h4{font-size:12px;color:var(--navy);margin-bottom:2px}
.inside-item p{font-size:11px;color:var(--mist)}
.resource-form-col{background:var(--fog);padding:calc(var(--nav-h) + 52px) 48px 80px;border-left:1px solid var(--silver);position:sticky;top:0;height:100vh;overflow-y:auto}
.resource-form-col h2{font-size:21px;color:var(--navy);margin-bottom:7px}
.resource-form-col>p{margin-bottom:24px}

/* === FORMS === */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.form-check{flex-direction:row;align-items:center;gap:10px}
label{font-family:var(--en);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--slate)}
.form-check label{text-transform:none;font-size:12px;letter-spacing:0}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--silver);border-radius:7px;font-family:var(--sans);font-size:13.5px;color:var(--ink);background:var(--white);outline:none;transition:border-color .18s,box-shadow .18s}
input::placeholder,textarea::placeholder{color:var(--mist)}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-check input[type=checkbox]{width:auto}
textarea{resize:vertical;min-height:96px}
select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%238892a4' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
.submit-btn{width:100%;margin-top:4px;background:var(--blue);color:var(--white);padding:13px;border-radius:9px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .22s;display:flex;align-items:center;justify-content:center;gap:8px}
.submit-btn:hover{background:var(--blue-dim);transform:translateY(-1px);box-shadow:0 7px 22px rgba(37,99,235,.28)}
.submit-btn svg{width:14px;height:14px}
.form-note{font-size:11px;color:var(--mist);text-align:center;margin-top:8px;line-height:1.6}
.form-error{font-size:11px;color:#ef4444;margin-top:3px;display:none}
.form-group.has-error input,.form-group.has-error textarea{border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.1)}
.form-group.has-error .form-error{display:block}
.form-hint{font-size:11px;color:var(--mist);margin-top:2px}
.form-row-half{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group.has-error select{border-color:#ef4444}
@media(max-width:480px){.form-row-half{grid-template-columns:1fr}}
.cf-confirm,.cf-complete{display:none}
.cf-confirm.active,.cf-complete.active{display:block}
.cf-confirm-table{width:100%;margin-bottom:28px}
.cf-confirm-table tr{border-bottom:1px solid var(--fog)}
.cf-confirm-table th{font-size:12px;color:var(--mist);font-weight:500;padding:12px 0;width:130px;vertical-align:top;text-align:left}
.cf-confirm-table td{font-size:14px;color:var(--ink);padding:12px 0;white-space:pre-wrap;word-break:break-word}
.cf-btn-row{display:flex;gap:12px;margin-top:8px}
.cf-btn-row .btn-back{flex:1;background:var(--white);color:var(--slate);border:1px solid var(--silver);padding:13px;border-radius:9px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;text-align:center;transition:all .22s}
.cf-btn-row .btn-back:hover{background:var(--fog)}
.cf-btn-row .submit-btn{flex:2;margin-top:0}

.cf-complete h2{font-size:20px;color:var(--navy);text-align:center;margin-bottom:10px}
.cf-complete p{text-align:center;color:var(--slate);font-size:13.5px;margin-bottom:8px}
.cf-complete .btn-back{display:inline-block;margin-top:20px;background:var(--white);color:var(--slate);border:1px solid var(--silver);padding:11px 28px;border-radius:9px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;text-align:center;transition:all .22s}
.cf-complete .btn-back:hover{background:var(--fog)}
.required{color:#ef4444}

/* === CONTACT === */
.contact-layout{display:grid;grid-template-columns:1fr 1fr}
.contact-info{background:var(--navy);padding:calc(var(--nav-h) + 60px) var(--pad) 60px}
.contact-info h1{color:var(--white);margin-bottom:14px}
.contact-info>p{color:rgba(255,255,255,.75);margin-bottom:44px}
.promises{display:flex;flex-direction:column;gap:14px;margin-bottom:44px}
.promise{display:flex;gap:15px;align-items:flex-start;padding:18px 20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:11px}
.promise-icon{width:34px;height:34px;background:rgba(37,99,235,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.promise-icon svg{width:14px;height:14px;color:#60a5fa}
.promise h4{color:var(--white);font-size:14px;margin-bottom:2px}
.promise p{font-size:12px;color:rgba(255,255,255,.7)}
.contact-form-col{padding:calc(var(--nav-h) + 60px) var(--pad) 60px}
.contact-form-col h2{font-size:21px;color:var(--navy);margin-bottom:26px}

/* === PRIVACY POLICY === */
.policy-body{max-width:720px;margin:0 auto;padding:72px var(--pad) 88px}
.policy-lead{margin-bottom:52px}
.policy-section{margin-bottom:44px}
.policy-section h2{font-size:18px;color:var(--navy);border-left:3px solid var(--blue);padding-left:14px;margin-bottom:14px}
.policy-list{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.policy-list li{display:flex;gap:10px;font-size:15px;color:var(--slate)}
.policy-list li::before{content:'›';color:var(--blue);font-size:17px;flex-shrink:0}
.policy-contact{background:var(--fog);border-radius:12px;padding:24px 28px;margin-top:14px;display:flex;flex-direction:column;gap:8px}
.policy-contact p{color:var(--navy);font-weight:500;margin:0}
.policy-contact p:last-child{color:var(--slate);font-weight:400}
.policy-contact a{color:var(--blue)}
.policy-date{font-size:12px;color:var(--mist);text-align:right;border-top:1px solid var(--fog);padding-top:22px;margin-top:44px}

/* === HAMBURGER / MOBILE === */
.hamburger-btn{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;padding:0;background:none;border:none;cursor:pointer;border-radius:6px;transition:background .18s;-webkit-tap-highlight-color:transparent}
.hamburger-btn:hover{background:var(--fog)}
.hamburger-bar{display:block;width:22px;height:1.8px;background:var(--ink);border-radius:2px;transform-origin:center;transition:transform .24s ease,opacity .18s ease}
.hamburger-btn[aria-expanded="true"] .hamburger-bar:nth-child(1){transform:translateY(6.8px) rotate(45deg)}
.hamburger-btn[aria-expanded="true"] .hamburger-bar:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger-btn[aria-expanded="true"] .hamburger-bar:nth-child(3){transform:translateY(-6.8px) rotate(-45deg)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(13,17,23,.48);z-index:200;opacity:0;transition:opacity .24s ease}
.mobile-overlay.is-visible{display:block}
.mobile-overlay.is-open{opacity:1}
.mobile-drawer{position:fixed;inset:0 0 0 auto;width:min(320px,82vw);background:var(--white);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .26s ease-out;box-shadow:-8px 0 32px rgba(0,0,0,.12);overflow-y:auto;overscroll-behavior:contain}
.mobile-drawer.is-open{transform:translateX(0)}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding-inline:20px;height:var(--nav-h);border-bottom:1px solid var(--fog);flex-shrink:0}
.drawer-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;background:none;border:none;cursor:pointer;color:var(--slate);transition:background .18s,color .18s}
.drawer-close:hover{background:var(--fog);color:var(--ink)}
.drawer-nav{display:flex;flex-direction:column;padding:16px 0 32px}
.drawer-nav a{display:block;padding:14px 28px;font-family:var(--en);font-size:15px;color:var(--slate);border-bottom:1px solid var(--fog);transition:color .16s,background .16s}
.drawer-nav a:hover{color:var(--blue);background:var(--blue-pale)}
.drawer-nav a.active{color:var(--blue)}
.drawer-cta{margin:20px 24px 0!important;background:var(--blue)!important;color:var(--white)!important;border-radius:8px!important;border-bottom:none!important;text-align:center;font-weight:500!important;padding:14px 20px!important}
.drawer-cta:hover{background:var(--blue-dim)!important}
body.is-menu-open{overflow:hidden}

/* === SERVICE DL FORM === */
.svc-dl-section{background:var(--fog);padding:80px var(--pad)}
.svc-dl-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 420px;gap:56px;align-items:start}
.svc-dl-info .label{margin-bottom:14px}
.svc-dl-info h2{margin-bottom:14px}
.svc-dl-info>p{margin-bottom:28px}
.svc-dl-contents{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.svc-dl-contents li{display:flex;gap:10px;font-size:14px;color:var(--slate);align-items:flex-start}
.svc-dl-contents li::before{content:'';display:block;width:18px;height:18px;border-radius:50%;background:var(--blue-pale);flex-shrink:0;margin-top:2px;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 9 9' xmlns='http://www.w3.org/2000/svg' fill='none'%3E%3Cpath d='M1.5 4.5l2 2 4-4' stroke='%232563eb' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:9px}
.svc-dl-mockup{display:flex;gap:20px;align-items:flex-end;margin-bottom:20px}

.svc-dl-meta{display:flex;gap:16px}
.svc-dl-meta span{font-size:12px;color:var(--mist);display:flex;align-items:center;gap:5px}
.svc-dl-meta svg{width:13px;height:13px;color:var(--mist)}
.svc-dl-form-card{background:var(--white);border:1px solid var(--silver);border-radius:16px;padding:32px;box-shadow:0 4px 20px rgba(0,0,0,.04)}
.svc-dl-form-card h3{font-size:18px;color:var(--navy);margin-bottom:6px}
.svc-dl-form-card>p{font-size:13px;color:var(--mist);margin-bottom:22px}
.svc-dl-form-card .form-group{margin-bottom:11px}
.svc-dl-form-card .submit-btn{margin-top:8px}
.svc-dl-success{display:none;text-align:center;padding:24px 0}
.svc-dl-success.active{display:block}

.svc-dl-success h4{color:var(--navy);margin-bottom:6px}
.svc-dl-success p{font-size:13px;color:var(--slate)}
@media(max-width:767px){
  main:has(.hero-visual)>header{grid-template-columns:1fr;min-height:auto;position:relative;background:var(--navy)}
  .hero-visual{position:absolute;inset:0;z-index:0}
  .hero-body{position:relative;z-index:2;padding-top:calc(var(--nav-h) + 48px);padding-bottom:60px}
  .hero-body h1,.hero-body h1 em{color:var(--white)}
  .hero-body>p{color:rgba(255,255,255,.8)}
  .hero-eyebrow{color:#60a5fa}
  .hero-visual-overlay{background:linear-gradient(135deg,rgba(13,17,43,.75) 0%,rgba(30,58,138,.55) 100%)}
.hero-actions .btn-outline{background:var(--white);color:var(--ink);border-color:var(--white)}
}

/* === DOWNLOAD PAGE === */
.dl-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:80px var(--pad);background:var(--fog)}
.dl-page-inner{max-width:620px;width:100%;text-align:center}

.dl-page-inner h1{font-size:clamp(22px,3vw,28px);color:var(--navy);margin-bottom:10px}
.dl-page-inner .dl-page-sub{font-size:15px;color:var(--slate);margin-bottom:36px;line-height:1.7}
.dl-page-card{background:var(--white);border:1px solid var(--silver);border-radius:16px;padding:36px;text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.04);margin-bottom:28px}
.dl-page-card h3{font-size:15px;color:var(--mist);font-weight:500;margin-bottom:14px}
.dl-page-card .dl-page-title{font-size:18px;color:var(--navy);font-weight:700;margin-bottom:20px}
.dl-page-mockup{display:inline-flex;gap:4px;margin-bottom:24px}

.dl-btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--blue);color:var(--white);padding:14px 36px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:background .2s,transform .15s;text-decoration:none}
.dl-btn-primary:hover{background:#1d4ed8;transform:translateY(-1px)}
.dl-btn-primary svg{width:18px;height:18px}
.dl-page-meta{display:flex;justify-content:center;gap:18px;margin-bottom:24px}
.dl-page-meta span{font-size:12px;color:var(--mist);display:flex;align-items:center;gap:5px}
.dl-page-meta svg{width:13px;height:13px;color:var(--mist)}
.dl-page-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--blue);text-decoration:none;transition:opacity .18s}
.dl-page-back:hover{opacity:.7}
.dl-page-note{font-size:12px;color:var(--mist);margin-top:20px;line-height:1.6}

/* === MODAL === */
.modal-overlay{position:fixed;inset:0;background:rgba(13,17,23,.55);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .24s ease;padding:24px}
.modal-overlay.is-open{opacity:1;pointer-events:auto}
.modal{background:var(--white);border-radius:18px;max-width:640px;width:100%;max-height:85vh;overflow-y:auto;transform:translateY(20px) scale(.97);transition:transform .28s var(--ease);box-shadow:0 24px 80px rgba(0,0,0,.18)}
.modal-overlay.is-open .modal{transform:none}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:32px 36px 0;position:sticky;top:0;background:var(--white);z-index:1;border-radius:18px 18px 0 0}
.modal-header h3{font-size:clamp(18px,2.2vw,22px);color:var(--navy);margin:0}
.modal-close{width:36px;height:36px;border-radius:8px;background:var(--fog);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--slate);transition:background .18s,color .18s;flex-shrink:0;margin-left:16px}
.modal-close:hover{background:var(--blue-pale);color:var(--blue)}
.modal-sub{font-family:var(--serif);font-size:15px;color:var(--blue);padding:8px 36px 0;font-weight:600}
.modal-body{padding:20px 36px 36px}
.modal-body p{font-size:14px;color:var(--slate);line-height:1.85;margin-bottom:14px}
.modal-body p:last-child{margin-bottom:0}
.modal-body ul{display:flex;flex-direction:column;gap:8px;margin:14px 0;padding:0}
.modal-body li{display:flex;gap:10px;font-size:14px;color:var(--slate);line-height:1.7}
.modal-body li::before{content:'→';color:var(--blue);flex-shrink:0;font-weight:500}
.modal-body .modal-highlight{font-family:var(--serif);font-size:15px;color:var(--navy);line-height:1.75}
.sm-card-clickable{cursor:pointer;transition:border-color .22s,box-shadow .22s,transform .22s}
.sm-card-clickable:hover{border-color:var(--blue)!important;box-shadow:0 8px 28px rgba(37,99,235,.1);transform:translateY(-2px)}
.sm-card-more{font-family:var(--en);font-size:11px;color:var(--blue);margin-top:12px;display:flex;align-items:center;gap:4px;opacity:.7;transition:opacity .18s}
.sm-card-clickable:hover .sm-card-more{opacity:1}
@media(max-width:767px){
  .modal{max-width:100%;max-height:90vh;border-radius:14px}
  .modal-header{padding:24px 24px 0}
  .modal-sub{padding:8px 24px 0}
  .modal-body{padding:16px 24px 28px}
}

/* === SPA === */
/* .page display control removed — handled by PHP routing */

/* === COVER GRADIENTS === */
.bg-blue-grad{background:linear-gradient(135deg,#1e3a8a,#1e40af)}
.bg-blue-grad2{background:linear-gradient(135deg,#1e3a8a,#2563eb)}
.cover-purple{background:linear-gradient(135deg,#7c3aed,#a855f7)}
.cover-amber{background:linear-gradient(135deg,#b45309,#d97706)}
.cover-rose{background:linear-gradient(135deg,#be123c,#f43f5e)}
.cover-cyan{background:linear-gradient(135deg,#0e7490,#06b6d4)}
.cover-violet{background:linear-gradient(135deg,#4c1d95,#7c3aed)}
.cover-emerald{background:linear-gradient(135deg,#065f46,#10b981)}
.cover-ocean{background:linear-gradient(135deg,#0e7490,#0284c7)}

/* === RESPONSIVE === */
@media(max-width:767px){
  body>nav>ul{display:none}
  .hamburger-btn{display:flex}
  #p-home>header{grid-template-columns:1fr;min-height:auto}
  .hero-visual{display:none}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .svc-grid,.service-links{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .challenge-list,.outcome-list,.inside-grid,.form-row{grid-template-columns:1fr}
  .articles-grid,.resources-grid{grid-template-columns:1fr}
  .featured-article,.svc-full{grid-template-columns:1fr}
  .resource-detail{grid-template-columns:1fr}
  .resource-form-col{position:static;height:auto}
  .contact-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .newsletter{flex-direction:column;align-items:flex-start}
  .newsletter-form{flex-direction:column}
  .newsletter input{width:100%}
  .svc-full-aside{display:none}
}
@media(min-width:768px){
  .hamburger-btn{display:none!important}
  .mobile-drawer,.mobile-overlay{display:none!important}
}
@media(max-width:1023px){
  .svc-full{grid-template-columns:1fr}
  .svc-full-aside{display:none}
}
@media(prefers-reduced-motion:reduce){
  .mobile-drawer,.mobile-overlay,.hamburger-bar,.fade,.orb{transition:none!important;animation:none!important}
}
.fade{opacity:1!important;transform:none!important}
main:has(.hero-visual)>header{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;padding-top:var(--nav-h);background:linear-gradient(135deg,var(--fog) 0%,var(--white) 55%)}
@media(max-width:767px){
  main:has(.hero-visual)>header{grid-template-columns:1fr;min-height:auto}
  .hero-visual{min-height:50vw;display:flex}
}