/*
Theme Name: Knoll Creative 2026
Theme URI: https://knollcreative.com
Author: Knoll Creative (Luke Knoll)
Description: Lightweight, hand-coded HTML theme for Knoll Creative — one brand, two paths (Professional Services + Worship Ministry). No page builder. Built for speed, SEO, and accessibility.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: knollcreative
*/

:root{
  --ink:#14181c;
  --ink-2:#1d242a;
  --paper:#ffffff;
  --mist:#eef4f6;
  --sky:#8fbfcc;
  --sky-deep:#3f7d8e;
  --pro:#2f6f7e;
  --pro-soft:#e6f0f2;
  --worship:#c2703d;
  --worship-soft:#f6eae2;
  --line:rgba(20,24,28,.10);
  --shadow:0 18px 50px -20px rgba(20,24,28,.45);
  --r:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.55;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,.wordmark{font-family:'Sora','Inter',sans-serif;line-height:1.05;letter-spacing:-.02em}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{overflow-wrap:break-word}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;color:#000;padding:8px 14px;border-radius:8px;z-index:200}

/* HEADER */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(140%) blur(10px);
  background:rgba(20,24,28,.86);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.bar{display:flex;align-items:center;justify-content:space-between;height:68px}
.wordmark{font-weight:800;font-size:20px;letter-spacing:.04em;display:flex;align-items:center;gap:11px}
.wordmark .glyph{width:26px;height:26px;color:var(--sky)}
.wordmark small{display:block;font-family:'Inter';font-weight:500;font-size:9.5px;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:2px}
nav.links{display:flex;gap:26px;align-items:center;font-size:14.5px;font-weight:500}
nav.links a{color:rgba(255,255,255,.82);transition:color .2s}
nav.links a:hover,nav.links a:focus{color:#fff}
.btn{display:inline-block;font-weight:600;font-size:14.5px;padding:11px 20px;border-radius:999px;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s;border:0}
.btn:hover{transform:translateY(-1px)}
.btn-sky{background:var(--sky);color:var(--ink)}
.btn-sky:hover{box-shadow:0 10px 24px -8px rgba(143,191,204,.7)}
.btn-pro{background:var(--pro);color:#fff}
.btn-worship{background:var(--worship);color:#fff}
.menu-toggle{display:none;background:none;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;padding:8px 12px;font-size:16px}

/* ROUTER / FRONT PAGE */
.router{min-height:calc(100vh - 68px);display:flex;flex-direction:column;
  background:radial-gradient(1100px 600px at 50% -10%, #20303a 0%, var(--ink) 60%);color:#fff}
.router .intro{text-align:center;padding:54px 28px 26px}
.router .icon-big{width:74px;height:74px;color:var(--sky);margin:0 auto 22px}
.router h1{font-size:clamp(32px,5vw,56px);font-weight:800}
.router h1 .shine{color:var(--sky)}
.router .sub{max-width:620px;margin:18px auto 0;color:rgba(255,255,255,.74);font-size:clamp(15px,1.6vw,18px)}
.doors{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:18px}
.door{position:relative;padding:54px 44px 64px;display:flex;flex-direction:column;justify-content:flex-end;
  min-height:360px;overflow:hidden;color:#fff}
.door:before{content:"";position:absolute;inset:0;opacity:.9;transition:transform .6s ease;z-index:0}
.door.pro:before{background:linear-gradient(160deg,#2f6f7e 0%,#1c4a55 100%)}
.door.worship:before{background:linear-gradient(160deg,#c2703d 0%,#8a4a23 100%)}
.door:hover:before{transform:scale(1.06)}
.door>*{position:relative;z-index:1}
.door .eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;opacity:.85}
.door h2{font-size:clamp(26px,3.2vw,38px);font-weight:800;margin:10px 0 12px}
.door p{color:rgba(255,255,255,.9);max-width:420px;font-size:15.5px}
.door .enter{margin-top:22px;display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15px}
.door .enter .arrow{transition:transform .25s}
.door:hover .enter .arrow{transform:translateX(6px)}
.door .watermark{position:absolute;right:-10px;top:-20px;width:200px;height:200px;opacity:.10;z-index:0}
.trust{background:var(--ink-2);color:rgba(255,255,255,.85);text-align:center;padding:20px 28px;
  font-size:14.5px;border-top:1px solid rgba(255,255,255,.07)}
.trust b{color:var(--sky);font-weight:700}

/* HUB PAGES */
.hubhero{padding-top:84px;padding-bottom:64px}
.hubhero .eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.hub-pro .eyebrow{color:var(--pro)}
.hub-worship .eyebrow{color:var(--worship)}
.hubhero h1{font-size:clamp(34px,4.6vw,52px);font-weight:800;margin:14px 0 16px;max-width:14ch}
.hubhero p.lead{font-size:clamp(16px,1.8vw,20px);color:#4a555c;max-width:60ch}
.hubhero .cta-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.section{padding-top:18px;padding-bottom:70px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;
  transition:transform .2s, box-shadow .25s, border-color .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.card .tag{display:inline-flex;width:42px;height:42px;border-radius:12px;align-items:center;justify-content:center;
  margin-bottom:16px;font-size:20px}
.hub-pro .card .tag{background:var(--pro-soft);color:var(--pro)}
.hub-worship .card .tag{background:var(--worship-soft);color:var(--worship)}
.card h3{font-size:21px;font-weight:700;margin-bottom:9px}
.card p{color:#525c63;font-size:15px}
.card .sub-list{margin-top:14px;display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:12.5px;font-weight:500;padding:5px 11px;border-radius:999px;background:var(--mist);color:#3a444a}
.card .more{margin-top:18px;font-weight:700;font-size:14.5px;display:inline-flex;gap:8px;align-items:center}
.hub-pro .card .more{color:var(--pro)}
.hub-worship .card .more{color:var(--worship)}
.band{border-radius:24px;padding:48px 40px;margin:8px 0 0;text-align:center;color:#fff}
.hub-pro .band{background:linear-gradient(160deg,#2f6f7e,#1c4a55)}
.hub-worship .band{background:linear-gradient(160deg,#c2703d,#8a4a23)}
.band h2{font-size:clamp(24px,3vw,34px);font-weight:800;margin-bottom:10px}
.band p{color:rgba(255,255,255,.88);margin-bottom:22px}
.quote{background:var(--mist);border-radius:var(--r);padding:30px 30px}
.quote p{font-size:17px;font-style:italic;color:#2b343a}
.quote .who{margin-top:14px;font-style:normal;font-weight:700;font-size:14.5px}
.quote .who span{font-weight:500;color:#69737a}
.sectionhead{margin:46px 0 22px}
.sectionhead .eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:#8a949b}
.sectionhead h2{font-size:clamp(24px,3vw,34px);font-weight:800;margin-top:8px}
.crosslink{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;
  padding:9px 16px;border-radius:999px;border:1px solid var(--line);color:#3a444a;transition:background .2s}
.crosslink:hover{background:var(--mist)}
.backhome{display:inline-flex;align-items:center;gap:8px;color:#69737a;font-weight:600;font-size:14px;margin-bottom:6px}
.backhome:hover{color:var(--ink)}
.resource{background:var(--worship-soft);border:1px dashed rgba(194,112,61,.5);border-radius:var(--r);
  padding:32px 30px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.resource h3{font-size:21px;font-weight:700;color:#8a4a23}
.resource p{color:#7a4f33;font-size:14.5px;margin-top:6px;max-width:50ch}
.resource form{display:flex;gap:10px;flex-wrap:wrap}
.resource input{padding:12px 16px;border-radius:999px;border:1px solid rgba(138,74,35,.3);min-width:220px;font-size:14.5px}

/* GENERIC PAGE / BLOG */
.page-hero{padding-top:72px;padding-bottom:24px}
.page-hero h1{font-size:clamp(30px,4vw,46px);font-weight:800}
.entry{padding-top:10px;padding-bottom:70px}
.entry-content{max-width:740px;font-size:17px;color:#2b343a}
.entry-content p{margin:0 0 18px}
.entry-content h2{font-size:28px;margin:34px 0 12px}
.entry-content h3{font-size:22px;margin:26px 0 10px}
.entry-content a{color:var(--pro);text-decoration:underline}

/* FOOTER */
.site-footer{background:var(--ink);color:rgba(255,255,255,.72);padding:54px 0 34px;margin-top:30px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.site-footer h4{color:#fff;font-family:'Sora';font-size:14px;letter-spacing:.04em;margin-bottom:14px}
.site-footer a{color:rgba(255,255,255,.72);font-size:14px;display:block;padding:4px 0;transition:color .2s}
.site-footer a:hover{color:var(--sky)}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:18px;font-size:12.5px;
  color:rgba(255,255,255,.5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

@media(max-width:860px){
  nav.links{display:none}
  nav.links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--ink);padding:10px 28px 18px}
  nav.links.open a{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}
  .menu-toggle{display:inline-flex}
  .doors{grid-template-columns:1fr}
  .grid3,.grid2{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .resource{flex-direction:column;align-items:flex-start;padding:26px 22px}
  .hubhero{padding-top:56px;padding-bottom:44px}
  .section{padding-bottom:50px}
  .band{padding:34px 22px}
  .door{padding:40px 26px 48px}
  .quote{padding:24px 22px}
}
@media(max-width:520px){
  .fgrid{grid-template-columns:1fr}
  .wrap{padding:0 22px}
  .resource form{width:100%}
  .resource input{min-width:0;width:100%}
}
