/* ============================================================
   ALLEN ENTERPRISES & DEVELOPMENT  |  Shared stylesheet
   Brand: evergreen + brass  /  Fraunces + Public Sans
   ============================================================ */

:root{
  --ink:#14241C;
  --green:#1E3A2F;
  --green-700:#27493B;
  --brass:#B8893C;
  --brass-soft:#D4B074;
  --clay:#A85C44;
  --stone:#F4F0E8;
  --stone-2:#EAE3D6;
  --paper:#FBF9F4;
  --cream:#EFE9DD;
  --line:rgba(20,36,28,.14);
  --line-light:rgba(239,233,221,.18);
  --shadow:0 18px 50px -28px rgba(20,36,28,.45);
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;}

.wrap{max-width:1140px;margin:0 auto;padding:0 28px;}
.section{padding:92px 0;}
.on-dark{color:var(--cream);}

/* ---------- Type ---------- */
.eyebrow{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  color:var(--brass);margin:0 0 18px;display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);}
.on-dark .eyebrow{color:var(--brass-soft);}
.on-dark .eyebrow::before{background:var(--brass-soft);}
.eyebrow.center{justify-content:center;}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;letter-spacing:-.01em;line-height:1.1;}
.h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin:0 0 18px;color:var(--green);}
.on-dark .h2{color:var(--cream);}
.lead{font-size:1.08rem;max-width:62ch;color:rgba(20,36,28,.82);}
.on-dark .lead{color:rgba(239,233,221,.82);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-weight:700;
  font-size:.92rem;letter-spacing:.01em;text-decoration:none;padding:14px 26px;
  border-radius:2px;border:1px solid transparent;
  transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease;
}
.btn-primary{background:var(--brass);color:var(--ink);}
.btn-primary:hover{background:var(--brass-soft);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--cream);border-color:rgba(239,233,221,.4);}
.btn-ghost:hover{border-color:var(--brass-soft);color:var(--brass-soft);}
.btn-dark{background:var(--green);color:var(--cream);}
.btn-dark:hover{background:var(--green-700);transform:translateY(-2px);}

/* ---------- Header / nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;background:rgba(20,36,28,.96);
  backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--line-light);
}
.nav-inner{max-width:1140px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--cream);}
.brand-mark{width:32px;height:32px;flex:0 0 auto;}
.brand-name{font-family:var(--display);font-weight:600;font-size:1.16rem;line-height:1;}
.brand-sub{display:block;font-family:var(--body);font-weight:600;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-soft);margin-top:3px;}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0;}
.nav-links a{color:rgba(239,233,221,.82);text-decoration:none;font-size:.85rem;font-weight:500;transition:color .2s ease;}
.nav-links a:hover,.nav-links a.active{color:var(--brass-soft);}
.nav-cta{background:var(--brass);color:var(--ink)!important;padding:9px 17px;border-radius:2px;font-weight:700!important;}
.nav-cta:hover{background:var(--brass-soft);}
.nav-toggle{display:none;background:none;border:1px solid var(--line-light);border-radius:2px;width:42px;height:38px;cursor:pointer;color:var(--cream);}
.nav-toggle span{display:block;width:18px;height:2px;background:currentColor;margin:3px auto;}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;color:var(--cream);
  background:
    radial-gradient(120% 90% at 78% 8%, rgba(184,137,60,.16), transparent 55%),
    linear-gradient(160deg,#16291F 0%, #1E3A2F 55%, #14241C 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.32;pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(239,233,221,.07) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(239,233,221,.07) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), transparent 94%);
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), transparent 94%);
}
.hero-art{position:absolute;right:0;bottom:0;width:min(48%,640px);opacity:.9;pointer-events:none;z-index:1;}
.hero-inner{position:relative;z-index:2;padding:120px 0 108px;max-width:660px;}
.hero h1{font-weight:500;font-size:clamp(2.4rem,5.6vw,4.1rem);line-height:1.03;margin:0 0 24px;}
.hero h1 em{font-style:italic;color:var(--brass-soft);}
.hero p{font-size:1.14rem;color:rgba(239,233,221,.85);margin:0 0 34px;max-width:54ch;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;}
.loc{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--brass-soft);margin:0 0 22px;}
.loc::before{content:"";width:7px;height:7px;transform:rotate(45deg);background:var(--brass);}

/* page hero (smaller, for interior pages) */
.page-hero{position:relative;overflow:hidden;color:var(--cream);
  background:radial-gradient(120% 120% at 85% 0%, rgba(184,137,60,.16), transparent 55%),linear-gradient(160deg,#16291F,#1E3A2F 60%,#14241C);}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.28;
  background-image:linear-gradient(to right, rgba(239,233,221,.07) 1px, transparent 1px),linear-gradient(to bottom, rgba(239,233,221,.07) 1px, transparent 1px);
  background-size:46px 46px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),transparent);mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),transparent);}
.page-hero-inner{position:relative;z-index:2;padding:84px 0 72px;}
.page-hero h1{font-weight:500;font-size:clamp(2.1rem,4.6vw,3.3rem);margin:0 0 16px;max-width:20ch;}
.page-hero p{font-size:1.1rem;color:rgba(239,233,221,.85);max-width:58ch;margin:0;}

/* ---------- Media / photo slot ---------- */
/* Swap to a real photo by setting: style="background-image:url('assets/img/yourphoto.jpg')" on .media,
   then add class .has-photo to hide the artwork overlay. */
.media{
  position:relative;border-radius:6px;overflow:hidden;min-height:340px;
  background:linear-gradient(150deg,#1E3A2F,#14241C);
  background-size:cover;background-position:center;border:1px solid var(--line);
}
.media .media-art{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.92;}
.media.has-photo .media-art{display:none;}
.media-tag{position:absolute;left:16px;bottom:16px;z-index:2;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--cream);background:rgba(20,36,28,.62);padding:7px 12px;border-radius:2px;backdrop-filter:blur(3px);}

/* ---------- Intro / split ---------- */
.split{display:grid;grid-template-columns:0.95fr 1.05fr;gap:56px;align-items:center;}
.split.tight{gap:44px;align-items:start;}
.statement{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,2.8vw,2.1rem);line-height:1.25;color:var(--green);margin:0;}
.statement span{color:var(--brass);}
.prose p{margin:0 0 16px;color:rgba(20,36,28,.84);}
.prose p:last-child{margin-bottom:0;}

/* ---------- Service pillars / cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px;}
.cards.two{grid-template-columns:1fr 1fr;}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:34px 30px;
  position:relative;overflow:hidden;display:flex;flex-direction:column;
}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--green);}
.card.alt::before{background:var(--brass);}
.card.clay::before{background:var(--clay);}
.card-ico{width:42px;height:42px;margin-bottom:16px;color:var(--brass);}
.card-kicker{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--brass);margin:0 0 10px;}
.card h3{font-size:1.4rem;color:var(--green);margin:0 0 12px;}
.card p{margin:0 0 18px;color:rgba(20,36,28,.8);font-size:.97rem;}
.card .more{margin-top:auto;font-weight:700;font-size:.85rem;letter-spacing:.02em;color:var(--green);text-decoration:none;display:inline-flex;align-items:center;gap:7px;}
.card .more:hover{color:var(--brass);}
.card .more::after{content:"\2192";}

/* ---------- Tick lists ---------- */
.tick{list-style:none;margin:0;padding:0;}
.tick li{position:relative;padding:8px 0 8px 26px;font-size:.96rem;border-top:1px solid var(--line);}
.tick li:first-child{border-top:none;}
.tick li::before{content:"";position:absolute;left:2px;top:15px;width:8px;height:8px;transform:rotate(45deg);background:var(--brass);}

/* ---------- Sequence tiers ---------- */
.tiers{margin-top:48px;border-top:1px solid var(--line-light);}
.tier{display:grid;grid-template-columns:84px 1fr 0.8fr;gap:30px;align-items:start;padding:36px 0;border-bottom:1px solid var(--line-light);}
.tier-num{font-family:var(--display);font-weight:500;font-size:2.3rem;line-height:1;color:var(--brass-soft);}
.tier h3{font-size:1.45rem;color:var(--cream);margin:0 0 10px;}
.tier p{margin:0 0 14px;color:rgba(239,233,221,.8);font-size:.96rem;max-width:54ch;}
.tags{display:flex;flex-wrap:wrap;gap:8px;}
.tag{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;border:1px solid var(--line-light);color:var(--brass-soft);padding:5px 11px;border-radius:2px;}
.tier-meta{border-left:1px solid var(--line-light);padding-left:22px;}
.tier-meta dt{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft);font-weight:700;margin:0 0 4px;}
.tier-meta dd{margin:0 0 14px;font-size:.93rem;color:rgba(239,233,221,.9);}
.tier-meta dd:last-child{margin-bottom:0;}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-light);border:1px solid var(--line-light);border-radius:6px;overflow:hidden;margin-top:46px;}
.stat{background:var(--ink);padding:30px 24px;}
.stat-num{font-family:var(--display);font-weight:600;font-size:2.3rem;line-height:1;color:var(--brass-soft);}
.stat-label{margin-top:10px;font-size:.82rem;color:rgba(239,233,221,.74);line-height:1.4;}

/* ---------- Scope columns ---------- */
.scope-cols{columns:3;column-gap:40px;margin-top:40px;}
.scope-cols li{break-inside:avoid;list-style:none;position:relative;padding:11px 0 11px 24px;border-top:1px solid var(--line);font-size:.93rem;color:rgba(20,36,28,.85);}
.scope-cols li::before{content:"";position:absolute;left:0;top:18px;width:11px;height:1px;background:var(--brass);}

/* ---------- Project list ---------- */
.projects{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:46px;}
.project{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--paper);display:flex;flex-direction:column;}
.project .media{min-height:230px;border:none;border-radius:0;}
.project-body{padding:26px 26px 30px;}
.project-body h3{font-size:1.3rem;color:var(--green);margin:0 0 8px;}
.project-meta{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--brass);margin:0 0 12px;}
.project-body p{margin:0;color:rgba(20,36,28,.8);font-size:.95rem;}

/* ---------- Term cards ---------- */
.terms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px;}
.term-card{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:28px 26px;}
.term-card h4{font-size:1.12rem;color:var(--green);margin:0 0 10px;}
.term-card p{margin:0;font-size:.92rem;color:rgba(20,36,28,.8);}

/* ---------- CTA band ---------- */
.cta{background:radial-gradient(110% 120% at 15% 10%, rgba(184,137,60,.18), transparent 55%),linear-gradient(150deg,#1E3A2F,#14241C);color:var(--cream);text-align:center;}
.cta h2{font-weight:500;font-size:clamp(2rem,4.4vw,3.1rem);margin:0 auto 18px;max-width:20ch;color:var(--cream);}
.cta p{max-width:52ch;margin:0 auto 32px;color:rgba(239,233,221,.85);font-size:1.05rem;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-card{background:var(--green);color:var(--cream);border-radius:8px;padding:38px 34px;}
.contact-card h3{color:var(--cream);font-size:1.5rem;margin:0 0 6px;}
.contact-card .role{color:var(--brass-soft);font-weight:600;font-size:.9rem;letter-spacing:.04em;margin:0 0 22px;}
.contact-line{display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--line-light);}
.contact-line:first-of-type{border-top:none;}
.contact-line .ico{width:20px;height:20px;color:var(--brass-soft);flex:0 0 auto;}
.contact-line a,.contact-line span{color:var(--cream);text-decoration:none;font-size:.98rem;}
.contact-line a:hover{color:var(--brass-soft);}
.form label{display:block;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--green);margin:0 0 7px;}
.form .field{margin-bottom:18px;}
.form input,.form textarea,.form select{
  width:100%;font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:12px 14px;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass);}
.form textarea{min-height:130px;resize:vertical;}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:rgba(239,233,221,.7);padding:58px 0 40px;border-top:1px solid var(--line-light);}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
.footer h5{font-family:var(--display);font-size:1.15rem;color:var(--cream);margin:0 0 6px;}
.footer .tagline{font-size:.9rem;color:rgba(239,233,221,.6);max-width:34ch;}
.footer-col-title{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--brass-soft);margin:0 0 14px;}
.footer ul{list-style:none;margin:0;padding:0;}
.footer li{margin:0 0 9px;}
.footer a{color:rgba(239,233,221,.78);text-decoration:none;font-size:.92rem;}
.footer a:hover{color:var(--brass-soft);}
.footer-base{margin-top:42px;padding-top:22px;border-top:1px solid var(--line-light);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.8rem;color:rgba(239,233,221,.5);}

/* ---------- Reveal (only hides when JS is active) ---------- */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease;}
.js .reveal.in{opacity:1;transform:none;}

a:focus-visible,button:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:2px;}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .cards,.cards.two{grid-template-columns:1fr;}
  .split,.split.tight,.contact-grid{grid-template-columns:1fr;gap:34px;}
  .stats{grid-template-columns:1fr 1fr;}
  .projects{grid-template-columns:1fr;}
  .terms-grid{grid-template-columns:1fr;}
  .scope-cols{columns:2;}
  .hero-art{display:none;}
  .tier{grid-template-columns:56px 1fr;gap:18px;}
  .tier-meta{grid-column:1 / -1;border-left:none;border-top:1px solid var(--line-light);padding:16px 0 0;margin-top:4px;display:grid;grid-template-columns:1fr 1fr;gap:0 22px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--green);border-bottom:1px solid var(--line-light);padding:8px 0;display:none;
  }
  .nav-links.open{display:flex;}
  .nav-links li{padding:0 28px;}
  .nav-links a{display:block;padding:13px 0;border-top:1px solid var(--line-light);}
  .nav-links li:first-child a{border-top:none;}
  .nav-cta{display:inline-block;margin:10px 0;text-align:center;}
  .nav-toggle{display:block;}
}
@media (max-width:560px){
  .section{padding:64px 0;}
  .scope-cols{columns:1;}
  .stats{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .tier-meta{grid-template-columns:1fr;}
  .wrap{padding:0 20px;}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}
