:root{
  --bg:#f4f2ec;
  --bg-alt:#ebe7de;
  --ink:#1b1a17;
  --muted:#6f6a60;
  --line:#dcd7cc;
  --dark:#1c1b18;
  --card:#faf9f5;
  --green:#5b8c5a;
  --amber:#bf8a3c;
  --gray:#9b958a;
  --maxw:1080px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.1;letter-spacing:-0.01em}
h1{font-size:clamp(2.4rem,5vw,3.6rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.5rem)}
h3{font-size:1.2rem}
p{color:var(--muted)}

a{color:inherit;text-decoration:none}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 22px;border-radius:8px;font-size:.92rem;font-weight:500;
  border:1px solid transparent;cursor:pointer;transition:.2s ease;
}
.btn-dark{background:var(--dark);color:#f4f2ec}
.btn-dark:hover{background:#000}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-light{background:#f4f2ec;color:var(--dark)}
.btn-light:hover{background:#fff}

/* nav */
.nav{position:sticky;top:0;z-index:40;background:rgba(244,242,236,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.98rem}
.brand-mark{width:22px;height:22px;display:inline-block;border-radius:6px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.92rem;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{color:#f4f2ec}
.nav-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);display:block}

/* hero */
.hero{padding:84px 0 72px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-family:'Inter',sans-serif}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--muted);display:inline-block}
.hero-text h1{margin:18px 0 20px}
.lede{font-size:1.08rem;max-width:30em}
.hero-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-media{position:relative}
.media-placeholder{
  aspect-ratio:4/4.4;border:1px solid var(--line);border-radius:14px;
  background:repeating-linear-gradient(135deg,#efece4 0 12px,#f4f2ec 12px 24px);
  display:flex;align-items:flex-end;justify-content:center;padding:18px;
}
.media-placeholder span{font-size:.78rem;color:var(--gray)}
.media-placeholder.dark{aspect-ratio:4/3;background:repeating-linear-gradient(135deg,#e4e0d6 0 12px,#ebe7de 12px 24px)}
.hero-img,.featured-img{width:100%;height:auto;display:block}

/* sections */
.section{padding:78px 0;border-top:1px solid var(--line)}
.section-head{display:flex;justify-content:space-between;gap:40px;align-items:flex-end;margin-bottom:44px;flex-wrap:wrap}
.kicker{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.section-note{max-width:24em;font-size:.98rem}

/* cards */
.card-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:24px;min-height:180px;display:flex;flex-direction:column}
.card-icon{width:24px;height:24px;border:1px solid var(--ink);border-radius:6px;margin-bottom:auto}
.card h3{margin:28px 0 8px}
.card p{font-size:.9rem}

/* services call to action */
.services-cta{margin-top:40px;padding-top:32px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.services-cta p{font-family:'Fraunces',serif;font-size:1.3rem;color:var(--ink)}

/* stats */
.stats{padding:56px 0;border-top:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{display:flex;flex-direction:column;gap:8px;border-left:1px solid var(--line);padding-left:18px}
.stat-num{font-family:'Fraunces',serif;font-size:2.6rem;font-weight:500;line-height:1}
.pct{font-size:1.4rem;vertical-align:super}
.stat-label{font-size:.84rem;color:var(--muted)}

/* featured */
.featured{padding:78px 0;background:var(--bg-alt);border-top:1px solid var(--line)}
.featured-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center}
.featured-text h2{margin:14px 0 16px}
.featured-stats{display:flex;gap:36px;margin:28px 0 22px;flex-wrap:wrap}
.featured-stats div{display:flex;flex-direction:column}
.featured-stats strong{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:500}
.featured-stats span{font-size:.82rem;color:var(--muted)}
.link-arrow{background:none;border:none;cursor:pointer;font:inherit;font-weight:500;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px}
.link-arrow::after{content:" \2192"}

/* work grid */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.project{
  text-align:left;background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:26px;cursor:pointer;font:inherit;color:inherit;transition:.2s ease;display:flex;flex-direction:column;
}
.project:hover{transform:translateY(-3px);border-color:var(--ink)}
.project-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.project-mark{width:14px;height:14px;background:var(--ink);border-radius:4px}
.project h3{margin-bottom:8px}
.project p{font-size:.92rem;margin-bottom:18px}
.project-go{font-size:.85rem;font-weight:500;color:var(--ink)}
.project-go::after{content:" \2192"}

/* status pill */
.status{display:inline-flex;align-items:center;gap:7px;font-size:.74rem;color:var(--muted);font-weight:500}
.status .dot{width:8px;height:8px;border-radius:50%}
.status-live .dot{background:var(--green)}
.status-dev .dot{background:var(--amber)}
.status-concept .dot{background:var(--gray)}

/* about */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.about-text h2{margin:14px 0 18px}
.about-text p{margin-bottom:16px;max-width:32em}
.founder{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:30px}
.founder blockquote{font-family:'Fraunces',serif;font-size:1.25rem;line-height:1.4;color:var(--ink)}
.founder figcaption{display:flex;align-items:center;gap:12px;margin-top:22px}
.founder-avatar{width:40px;height:40px;border-radius:50%;background:var(--line)}
.founder-meta{display:flex;flex-direction:column;font-size:.86rem}
.founder-meta strong{font-weight:600}
.founder-meta span{color:var(--muted)}

/* cta */
.cta{padding:40px 0 78px}
.cta-card{background:var(--dark);color:#f4f2ec;border-radius:18px;padding:46px;display:flex;justify-content:space-between;align-items:center;gap:36px;flex-wrap:wrap}
.cta-text h2{color:#f4f2ec;margin-bottom:10px}
.cta-text p{color:#bdb8ad;max-width:30em}
.cta-actions{display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.cta-email{font-size:.88rem;color:#bdb8ad}
.cta-email:hover{color:#fff}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-intro h2{margin:14px 0 16px}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-form label{display:flex;flex-direction:column;gap:7px;font-size:.85rem;font-weight:500}
.contact-form input,.contact-form textarea{
  font:inherit;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:var(--card);color:var(--ink);resize:vertical;
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--ink)}
.contact-form .btn{align-self:flex-start;margin-top:4px}
.form-status{font-size:.88rem;font-weight:500}

/* footer */
.footer{border-top:1px solid var(--line);padding:56px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:32px;padding-bottom:36px}
.footer-brand p{font-size:.9rem;max-width:26em;margin-top:14px}
.footer-col h4{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:'Inter',sans-serif;font-weight:600;margin-bottom:14px}
.footer-col a{display:block;font-size:.92rem;color:var(--muted);margin-bottom:9px}
.footer-col a:hover{color:var(--ink)}
.footer-bottom{border-top:1px solid var(--line);padding-top:22px;font-size:.82rem;color:var(--muted)}

/* modal */
.modal{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(20,18,15,.5)}
.modal-card{position:relative;background:var(--bg);border-radius:16px;max-width:540px;width:100%;padding:40px;max-height:88vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.25)}
.modal-close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--muted)}
.modal-status{display:inline-flex;align-items:center;gap:7px;font-size:.74rem;font-weight:500;color:var(--muted);margin-bottom:14px}
.modal-status .dot{width:8px;height:8px;border-radius:50%}
.modal-card h3{font-size:1.7rem;margin-bottom:8px}
.modal-tagline{font-size:1rem;margin-bottom:18px}
.modal-body p{font-size:.95rem;margin-bottom:14px}

/* tabs */
main{min-height:72vh}
.tab{display:none}
.tab.active{display:block;animation:tabin .4s ease}
@keyframes tabin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
/* first block inside a tab does not need a divider line above it */
.tab > .section:first-child,
.tab > .hero:first-child{border-top:none}
/* active tab link */
.nav-links a.tablink.active{color:var(--ink);font-weight:600}

/* responsive */
@media (max-width:860px){
  .hero-grid,.featured-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .card-row,.stats-grid{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{
    position:fixed;top:64px;left:0;right:0;background:var(--bg);
    flex-direction:column;align-items:flex-start;gap:0;padding:8px 24px 20px;
    border-bottom:1px solid var(--line);display:none;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 0;width:100%}
  .nav-cta{margin-top:8px}
  .nav-toggle{display:flex}
  .cta-card{padding:34px}
}
@media (max-width:520px){
  .card-row,.stats-grid,.footer-grid{grid-template-columns:1fr}
  .featured-media .media-placeholder{aspect-ratio:4/3}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
