/*
Theme Name: Northcrest Digital Group
Theme URI: https://northcrestdigital.com
Author: Northcrest Digital Group
Description: Bold, high-energy single-file digital agency theme for Northcrest Digital Group (Montgomery, AL). All pages route via ?page= so everything is visible immediately on activation.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: northcrest
Tags: business, agency, marketing, one-page, dark
*/
:root{--ink:#101223;--ink2:#181A33;--indigo:#3D3DF5;--indigo-d:#2A2AC9;--lime:#C9F24B;--paper:#fff;--soft:#F2F3FB;--muted:#5B5E78;--line:#E3E5F2;--r:18px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.65;font-size:17px;overflow-x:hidden}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}ul{list-style:none}
input,select,textarea{font-family:'Inter',sans-serif}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;line-height:1.1;letter-spacing:-.02em;font-weight:700}
h1{font-size:clamp(2.6rem,6vw,4.4rem)}h2{font-size:clamp(1.9rem,4vw,2.8rem)}h3{font-size:1.3rem}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-9999px}.skip-link:focus{left:10px;top:10px;background:var(--indigo);color:#fff;padding:10px 16px;z-index:9999}
/* nav */
.navbar{position:sticky;top:0;z-index:1000;background:var(--paper);border-bottom:1px solid var(--line);transition:.3s}
.navbar.scrolled{box-shadow:0 6px 24px rgba(16,18,35,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:24px}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{width:46px;height:46px;flex:none}
.logo-text b{font-family:'Space Grotesk',sans-serif;font-size:1.2rem;color:var(--ink);display:block;line-height:1}
.logo-text span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links li a{color:var(--ink);font-weight:600;font-size:.95rem;padding:8px 14px;border-radius:8px;transition:.2s}
.nav-links li a:hover,.nav-links li a.active{color:var(--indigo)}
.nav-cta{background:var(--indigo);color:#fff!important;border-radius:99px;padding:10px 20px!important}
.nav-cta:hover{background:var(--indigo-d)}
.hamburger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;z-index:1200}
.hamburger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px auto;transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* buttons */
.btn{display:inline-block;padding:15px 32px;border-radius:99px;font-weight:700;font-family:'Space Grotesk',sans-serif;transition:.25s;border:2px solid transparent;cursor:pointer;font-size:1rem}
.btn-lime{background:var(--lime);color:var(--ink)}
.btn-lime:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(201,242,75,.35)}
.btn-indigo{background:var(--indigo);color:#fff}
.btn-indigo:hover{background:var(--indigo-d);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.35);color:#fff;margin-left:14px}
.btn-ghost:hover{border-color:var(--lime);color:var(--lime)}
.full-width{width:100%;text-align:center}
/* hero */
.hero{background:var(--ink);color:#fff;padding:110px 0 90px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-180px;top:-180px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,var(--indigo) 0%,transparent 70%);opacity:.55}
.hero::before{content:"";position:absolute;left:-120px;bottom:-200px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,#1d1f3d 0%,transparent 72%)}
.hero .container{position:relative;z-index:2}
.hero h1{color:#fff}.hero h1 mark{background:none;color:var(--lime)}
.hero p.lead{max-width:600px;color:#C8CAE3;font-size:1.15rem;margin:24px 0 36px}
.kicker{display:inline-block;font-family:'Space Grotesk',sans-serif;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--lime);border:1px solid rgba(201,242,75,.4);padding:7px 16px;border-radius:99px;margin-bottom:24px}
.kicker.dark{color:var(--indigo);border-color:rgba(61,61,245,.3)}
.hero-stats{display:flex;gap:48px;margin-top:56px;flex-wrap:wrap}
.hero-stats b{font-family:'Space Grotesk',sans-serif;font-size:2.2rem;color:var(--lime);display:block}
.hero-stats span{color:#9FA2C4;font-size:.92rem}
/* page hero */
.page-hero{background:var(--ink);color:#fff;padding:96px 0 72px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-140px;top:-160px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,var(--indigo) 0%,transparent 70%);opacity:.5}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff}.page-hero p{color:#C8CAE3;max-width:640px;margin-top:16px;font-size:1.1rem}
/* sections */
.section{padding:96px 0}.section.soft{background:var(--soft)}
.section.dark{background:var(--ink);color:#C8CAE3}
.section.dark h2,.section.dark h3{color:#fff}
.section-head{max-width:660px;margin-bottom:56px}
.section-head.center{margin:0 auto 56px;text-align:center}
.section-head p{color:var(--muted);font-size:1.06rem}
.section.dark .section-head p{color:#9FA2C4}
.grid{display:grid;gap:28px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:36px 30px;transition:.3s}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(16,18,35,.1);border-color:var(--indigo)}
.card h3{margin:18px 0 12px}.card p{color:var(--muted);font-size:.99rem}
.card ul{margin:14px 0 0 18px;color:var(--muted);font-size:.96rem}.card ul li{margin-bottom:8px}
.section.dark .card{background:var(--ink2);border-color:#26284a}
.section.dark .card p,.section.dark .card ul{color:#9FA2C4}
.icon-chip{width:52px;height:52px;border-radius:14px;background:var(--soft);display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.section.dark .icon-chip{background:#222445}
.num{font-family:'Space Grotesk',sans-serif;font-size:2.6rem;font-weight:700;color:var(--indigo);opacity:.25}
/* portfolio */
.work-item{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--paper);transition:.3s}
.work-item:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(16,18,35,.12)}
.work-thumb{height:170px;display:flex;align-items:flex-end;padding:22px;font-family:'Space Grotesk',sans-serif;font-weight:700;color:#fff;font-size:1.1rem}
.work-body{padding:24px 26px 30px}.work-body p{color:var(--muted);font-size:.96rem;margin-top:8px}
.tag{display:inline-block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;background:var(--soft);color:var(--indigo);padding:5px 12px;border-radius:99px;margin:0 6px 8px 0;font-weight:700}
/* jobs */
.job{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px;margin-bottom:20px;flex-wrap:wrap}
.job h3{font-size:1.18rem}.job .meta{color:var(--muted);font-size:.9rem;margin-top:4px}.job p{color:var(--muted);flex-basis:100%;margin-top:8px}
/* cta */
.cta-band{background:linear-gradient(115deg,var(--indigo) 0%,#5b2af5 100%);color:#fff;padding:88px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;left:50%;bottom:-260px;width:560px;height:560px;margin-left:-280px;border-radius:50%;background:radial-gradient(circle,rgba(201,242,75,.35) 0%,transparent 70%)}
.cta-band h2{color:#fff;position:relative;z-index:2}
.cta-band p{color:#DDDDFA;margin:16px auto 30px;max-width:560px;position:relative;z-index:2}
.cta-band a.link{color:#fff;font-weight:700;text-decoration:underline}
.cta-band .btn{position:relative;z-index:2}
/* contact */
.contact-layout{display:grid;grid-template-columns:1fr 1.25fr;gap:48px}
.contact-info h2{margin-bottom:14px}
.cd-item{display:flex;gap:16px;margin-bottom:24px}
.cd-icon{font-size:1.4rem}.cd-item strong{display:block;font-family:'Space Grotesk',sans-serif}.cd-item span{color:var(--muted)}
.contact-form{background:var(--soft);border-radius:var(--r);padding:38px;border:1px solid var(--line)}
.contact-form h3{margin-bottom:8px}
.contact-form label{display:block;font-weight:600;margin:16px 0 7px;font-size:.92rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:11px;font:inherit;background:#fff}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:2px solid var(--indigo);border-color:var(--indigo)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form button{margin-top:24px}
.form-msg{margin-top:16px;border-radius:10px;display:none;font-weight:600}
.form-msg.ok{display:block;padding:14px 18px;background:#E7F7E2;color:#1F6B2D}
.form-msg.err{display:block;padding:14px 18px;background:#FBE9E9;color:#A33}
/* footer */
.footer{background:var(--ink);color:#9FA2C4;padding:72px 0 0}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.footer h4{color:#fff;font-size:1rem;margin-bottom:16px}
.footer a:hover{color:var(--lime)}.footer-col ul li{margin-bottom:10px}.footer-col p{margin-bottom:14px}
.footer-bottom{border-top:1px solid #26284a;padding:24px;text-align:center;font-size:.88rem}
/* reveal */
.animate-on-scroll{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.animate-on-scroll.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
@media (prefers-reduced-motion:reduce){.animate-on-scroll{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
@media (max-width:960px){.grid-3{grid-template-columns:1fr 1fr}.footer-inner{grid-template-columns:1fr 1fr}}
@media (max-width:760px){
.grid-3,.grid-2,.contact-layout,.footer-inner,.form-row{grid-template-columns:1fr}
.hamburger{display:block}
.nav-links{position:fixed;inset:0;background:var(--ink);transform:translateX(100%);transition:.35s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px}
.nav-links.open{transform:none}
.nav-links li a{color:#fff;font-size:1.3rem}
.nav-cta{background:var(--lime)!important;color:var(--ink)!important}
.hero{padding:80px 0 64px}.btn-ghost{margin-left:0;margin-top:12px}
}
