/* ============================================================
   patrickalbert.com — Desert Editorial design system
   Display: Fraunces  |  Body: Hanken Grotesk
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,500&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

:root{
  --ink:#152229;          /* deep navy-slate (Navy nod) */
  --ink-soft:#2b3b43;
  --sand:#f6ede0;         /* warm paper */
  --sand-deep:#ece0cd;
  --cream:#fdf8f0;
  --clay:#c0512e;         /* terracotta sunset accent */
  --clay-deep:#9c3d1f;
  --sun:#e0a23a;          /* desert gold */
  --sage:#5f7d6f;         /* muted desert sage */
  --line:rgba(21,34,41,.14);
  --shadow:0 24px 60px -28px rgba(21,34,41,.45);
  --maxw:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  color:var(--ink);
  background:var(--sand);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* subtle paper grain */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
main, header, footer{position:relative; z-index:1;}

img{max-width:100%; display:block;}
a{color:inherit;}

h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif; font-weight:600; line-height:1.06; letter-spacing:-.01em; margin:0;}
p{margin:0 0 1rem;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px,5vw,48px);}
.eyebrow{
  font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--clay);
  display:inline-flex; align-items:center; gap:.6rem;
}
.eyebrow::before{content:""; width:28px; height:2px; background:var(--clay); display:inline-block;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:.85rem 1.5rem; border-radius:999px; text-decoration:none;
  border:1.5px solid var(--ink); transition:.25s ease; cursor:pointer;
}
.btn-primary{background:var(--ink); color:var(--cream);}
.btn-primary:hover{background:var(--clay); border-color:var(--clay); transform:translateY(-2px);}
.btn-ghost{background:transparent; color:var(--ink);}
.btn-ghost:hover{background:var(--ink); color:var(--cream); transform:translateY(-2px);}
.btn-light{background:var(--cream); color:var(--ink); border-color:var(--cream);}
.btn-light:hover{background:var(--sun); border-color:var(--sun);}

/* ---------- nav ---------- */
header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(246,237,224,.82); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:.9rem 0;}
.brand{display:flex; align-items:center; gap:.7rem; text-decoration:none; color:var(--ink);}
.brand .mark{
  width:42px; height:42px; border-radius:50%; flex:0 0 auto;
  background:var(--ink); color:var(--sun); display:grid; place-items:center;
  font-family:'Fraunces',serif; font-weight:600; font-size:1.15rem;
  box-shadow:inset 0 0 0 2px var(--sun);
}
.brand .bn{font-family:'Fraunces',serif; font-weight:600; font-size:1.25rem; line-height:1;}
.brand .bt{font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--clay); font-weight:700;}
.navlinks{display:flex; gap:1.4rem; align-items:center; list-style:none; margin:0; padding:0;}
.navlinks a{text-decoration:none; font-weight:600; font-size:.92rem; padding:.3rem 0; position:relative; color:var(--ink-soft);}
.navlinks a::after{content:""; position:absolute; left:0; bottom:-3px; height:2px; width:0; background:var(--clay); transition:.25s;}
.navlinks a:hover, .navlinks a.active{color:var(--ink);}
.navlinks a:hover::after, .navlinks a.active::after{width:100%;}
.nav-cta{margin-left:.4rem;}
.menu-toggle{display:none; background:none; border:0; cursor:pointer; padding:6px; }
.menu-toggle span{display:block; width:26px; height:2.5px; background:var(--ink); margin:5px 0; transition:.3s;}

@media(max-width:920px){
  .menu-toggle{display:block;}
  .navlinks{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:var(--sand); padding:1rem clamp(20px,5vw,48px) 2rem;
    border-bottom:1px solid var(--line); transform:translateY(-130%);
    transition:transform .35s ease; box-shadow:var(--shadow);
  }
  .navlinks.open{transform:translateY(0);}
  .navlinks a{padding:.9rem 0; width:100%; border-bottom:1px solid var(--line); font-size:1.05rem;}
  .navlinks a::after{display:none;}
  .nav-cta{margin:1rem 0 0;}
}

/* ---------- hero ---------- */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(224,162,58,.20), transparent 55%),
    radial-gradient(90% 80% at -10% 110%, rgba(95,125,111,.22), transparent 50%),
    linear-gradient(170deg,#16242c 0%,#1c2f38 55%,#24414a 100%);
  color:var(--cream);
}
.hero .wrap{display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(28px,5vw,64px); align-items:center; padding-top:clamp(48px,7vw,92px); padding-bottom:clamp(56px,8vw,104px);}
.hero .eyebrow{color:var(--sun);} .hero .eyebrow::before{background:var(--sun);}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem); margin:1.2rem 0; }
.hero h1 em{font-style:italic; color:var(--sun);}
.hero p.lead{font-size:clamp(1.05rem,1.8vw,1.28rem); color:rgba(253,248,240,.82); max-width:46ch; margin-bottom:2rem;}
.hero-cta{display:flex; flex-wrap:wrap; gap:.9rem;}
.hero .btn-ghost{color:var(--cream); border-color:rgba(253,248,240,.45);}
.hero .btn-ghost:hover{background:var(--cream); color:var(--ink); border-color:var(--cream);}
.hero-card{
  background:rgba(253,248,240,.06); border:1px solid rgba(253,248,240,.16);
  border-radius:22px; padding:1.8rem; backdrop-filter:blur(4px);
}
.hero-card h3{font-size:1.05rem; color:var(--sun); font-weight:600; margin-bottom:1rem; font-family:'Hanken Grotesk',sans-serif; letter-spacing:.04em; text-transform:uppercase; font-size:.78rem;}
.hero-card .row{display:flex; gap:1rem; padding:.8rem 0; border-top:1px solid rgba(253,248,240,.12); align-items:baseline;}
.hero-card .row:first-of-type{border-top:0;}
.hero-card .num{font-family:'Fraunces',serif; font-size:2rem; color:var(--cream); line-height:1; min-width:2.6ch;}
.hero-card .lbl{font-size:.9rem; color:rgba(253,248,240,.75);}
@media(max-width:840px){ .hero .wrap{grid-template-columns:1fr;} .hero-card{order:2;} }

/* ---------- sections ---------- */
section{padding:clamp(56px,8vw,104px) 0;}
.section-head{max-width:62ch;}
.section-head h2{font-size:clamp(1.9rem,4vw,3rem); margin:1rem 0 1rem;}
.section-head p{font-size:1.1rem; color:var(--ink-soft);}
.alt{background:var(--cream);}
.dark{background:var(--ink); color:var(--cream);}
.dark .eyebrow{color:var(--sun);} .dark .eyebrow::before{background:var(--sun);}
.dark .section-head p{color:rgba(253,248,240,.78);}

/* ---------- stat band ---------- */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-radius:18px; overflow:hidden; margin-top:2.5rem;}
.stats .stat{background:var(--sand); padding:1.8rem 1.4rem;}
.alt .stats .stat{background:var(--cream);}
.stats .num{font-family:'Fraunces',serif; font-size:clamp(2.2rem,4vw,3rem); color:var(--clay); line-height:1;}
.stats .lbl{font-size:.9rem; color:var(--ink-soft); margin-top:.4rem;}
@media(max-width:720px){ .stats{grid-template-columns:repeat(2,1fr);} }

/* ---------- cards grid ---------- */
.grid{display:grid; gap:1.4rem; margin-top:2.6rem;}
.grid.cols-3{grid-template-columns:repeat(3,1fr);}
.grid.cols-2{grid-template-columns:repeat(2,1fr);}
@media(max-width:900px){ .grid.cols-3{grid-template-columns:repeat(2,1fr);} }
@media(max-width:640px){ .grid.cols-3,.grid.cols-2{grid-template-columns:1fr;} }

.card{
  background:var(--cream); border:1px solid var(--line); border-radius:18px;
  padding:1.8rem; position:relative; overflow:hidden; transition:.3s ease;
}
.alt .card{background:var(--sand);}
.card::before{content:""; position:absolute; top:0; left:0; right:0; height:4px; background:var(--clay); transform:scaleX(0); transform-origin:left; transition:.35s;}
.card:hover{transform:translateY(-5px); box-shadow:var(--shadow);}
.card:hover::before{transform:scaleX(1);}
.card .ico{font-size:1.4rem; width:48px; height:48px; border-radius:12px; background:var(--sand-deep); display:grid; place-items:center; margin-bottom:1.1rem;}
.alt .card .ico{background:var(--sand-deep);}
.card h3{font-size:1.3rem; margin-bottom:.6rem;}
.card p{color:var(--ink-soft); font-size:.98rem; margin:0;}
.card .tag{display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--sage); margin-bottom:.7rem;}

/* ---------- split feature ---------- */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px); align-items:center;}
.split.flip > .split-media{order:2;}
.split-media{border-radius:20px; overflow:hidden; box-shadow:var(--shadow); background:var(--ink);}
.split-media .panel{aspect-ratio:4/3; display:grid; place-items:center; padding:2rem;
  background:radial-gradient(120% 120% at 30% 20%, rgba(224,162,58,.25), transparent 60%),linear-gradient(160deg,#1c2f38,#24414a); color:var(--cream); text-align:center;}
.split-media .panel .big{font-family:'Fraunces',serif; font-size:clamp(2.4rem,5vw,3.6rem); color:var(--sun); line-height:1;}
.split-media .panel small{display:block; letter-spacing:.18em; text-transform:uppercase; font-size:.72rem; margin-top:.6rem; color:rgba(253,248,240,.8);}
@media(max-width:820px){ .split{grid-template-columns:1fr;} .split.flip > .split-media{order:0;} }

/* ---------- list rows ---------- */
.rows{margin-top:2.4rem; border-top:1px solid var(--line);}
.rows .r{display:grid; grid-template-columns:auto 1fr; gap:1.6rem; padding:1.6rem 0; border-bottom:1px solid var(--line); align-items:start;}
.rows .r .k{font-family:'Fraunces',serif; font-size:1.4rem; color:var(--clay); min-width:3ch;}
.rows .r h3{font-size:1.25rem; margin-bottom:.4rem;}
.rows .r p{color:var(--ink-soft); margin:0;}

/* ---------- flipbook embed ---------- */
.flip-shell{margin-top:2.6rem; display:grid; grid-template-columns:1fr; gap:1.5rem;}
.flip-frame{
  width:100%; height:840px; border:0; border-radius:20px; overflow:hidden;
  box-shadow:var(--shadow); background:var(--ink);
}
.flip-note{font-size:.9rem; color:var(--ink-soft); text-align:center;}
@media(max-width:560px){ .flip-frame{height:680px;} }

/* ---------- CTA band ---------- */
.cta-band{background:var(--clay); color:var(--cream); text-align:center;}
.cta-band h2{font-size:clamp(2rem,4.5vw,3.2rem); max-width:22ch; margin:0 auto 1.2rem;}
.cta-band p{max-width:50ch; margin:0 auto 2rem; color:rgba(253,248,240,.9); font-size:1.1rem;}
.cta-band .btn-light{border-color:var(--cream);}

/* ---------- form ---------- */
.formwrap{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:start;}
@media(max-width:820px){ .formwrap{grid-template-columns:1fr;} }
form.contact{display:grid; gap:1.1rem; background:var(--cream); padding:2rem; border-radius:20px; border:1px solid var(--line); box-shadow:var(--shadow);}
.field{display:grid; gap:.4rem;}
.field label{font-weight:600; font-size:.85rem; letter-spacing:.02em;}
.field input,.field select,.field textarea{
  font:inherit; padding:.85rem 1rem; border:1.5px solid var(--line); border-radius:10px;
  background:var(--sand); color:var(--ink); transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--clay); background:var(--cream);}
.field textarea{min-height:120px; resize:vertical;}
.two{display:grid; grid-template-columns:1fr 1fr; gap:1.1rem;}
@media(max-width:520px){ .two{grid-template-columns:1fr;} }

/* ---------- footer ---------- */
footer.site{background:var(--ink); color:rgba(253,248,240,.78); padding:clamp(48px,6vw,72px) 0 2rem;}
.fgrid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem;}
@media(max-width:760px){ .fgrid{grid-template-columns:1fr 1fr;} }
footer.site h4{color:var(--cream); font-size:1rem; margin-bottom:1rem; font-family:'Hanken Grotesk',sans-serif; letter-spacing:.1em; text-transform:uppercase; font-size:.78rem;}
footer.site a{color:rgba(253,248,240,.7); text-decoration:none; display:block; padding:.3rem 0; font-size:.93rem;}
footer.site a:hover{color:var(--sun);}
footer .brand .bn{color:var(--cream);}
footer .lede{max-width:34ch; color:rgba(253,248,240,.7); margin-top:1rem; font-size:.95rem;}
.fbar{margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid rgba(253,248,240,.14); display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; font-size:.85rem; color:rgba(253,248,240,.55);}

/* ---------- reveal animation ---------- */
.reveal{opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease;}
.reveal.in{opacity:1; transform:none;}
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;} .reveal.d3{transition-delay:.24s;}
@media(prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none; transition:none;} html{scroll-behavior:auto;} }

/* ---------- misc ---------- */
.lead-block{max-width:60ch;}
.lead-block p{font-size:1.12rem; color:var(--ink-soft);}
.pull{font-family:'Fraunces',serif; font-size:clamp(1.5rem,3vw,2.1rem); font-weight:500; font-style:italic; line-height:1.3; color:var(--ink); border-left:3px solid var(--clay); padding-left:1.4rem; margin:2rem 0;}
.dark .pull{color:var(--cream); border-color:var(--sun);}
.tags{display:flex; flex-wrap:wrap; gap:.6rem; margin-top:2rem;}
.tags span{font-size:.82rem; font-weight:600; padding:.45rem .9rem; border-radius:999px; background:var(--sand-deep); color:var(--ink-soft);}
.dark .tags span{background:rgba(253,248,240,.1); color:rgba(253,248,240,.85);}
.page-hero{background:linear-gradient(170deg,#16242c,#24414a); color:var(--cream); padding:clamp(56px,8vw,96px) 0 clamp(48px,6vw,72px);}
.page-hero .eyebrow{color:var(--sun);} .page-hero .eyebrow::before{background:var(--sun);}
.page-hero h1{font-size:clamp(2.3rem,5.5vw,3.8rem); margin:1rem 0;}
.page-hero p{font-size:1.15rem; color:rgba(253,248,240,.82); max-width:54ch;}
