/* ============================================================
   It's Already Done Web Co — warm, welcoming, handshake-first
   Cream paper canvas · walnut ink · sign-painter green accent
   · red rubber-stamp motif ("PAID"-stamp energy, not tech glow)
   ============================================================ */

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

:root {
  --bg: #faf6ee;
  --bg-2: #f3edde;
  --panel: #fffdf7;
  --line: #e6dcc6;
  --text: #35291c;
  --muted: #7c6e5a;
  --green: #3e6b4f;
  --green-dim: #6f9a80;
  --green-glow: rgba(62, 107, 79, 0.12);
  --stamp-red: #b5402f;
  --honey: #c98a2d;
  --radius: 16px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  overflow-x: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-size: 1.05rem;
  line-height: 1.68;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
::selection { background: var(--green); color: #fffdf7; }

h1, h2, h3 { font-family: 'Fraunces', Georgia, serif; line-height: 1.08; letter-spacing: -0.01em; }

.wrap { max-width: 1140px; margin: 0 auto; padding: 0 1.5rem; }

a { color: var(--green); }

/* ---------- nav ---------- */
header.site {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250, 246, 238, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.nav-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 0.9rem 1.5rem; max-width: 1220px; margin: 0 auto; flex-wrap: wrap;
}
.brand { text-decoration: none; display: flex; align-items: center; gap: 0.65rem; }
.brand .logo { width: 62px; height: 62px; flex-shrink: 0; }
.brand .co { align-self: flex-end; padding-bottom: 0.3rem; }
.brand .word {
  font-family: 'Fraunces', serif;
  font-weight: 900; font-size: 1.3rem; color: var(--text);
}
.brand .word em { font-style: normal; color: var(--green); }
.brand .co { font-size: 0.75rem; color: var(--muted); letter-spacing: 0.2em; text-transform: uppercase; font-weight: 800; }
nav.main { display: flex; gap: 0.2rem; align-items: center; flex-wrap: wrap; }
nav.main a {
  color: var(--text); text-decoration: none; font-weight: 700; font-size: 0.95rem;
  padding: 0.45rem 0.85rem; border-radius: 999px; transition: color 0.15s, background 0.15s;
}
nav.main a:hover { background: var(--bg-2); color: var(--green); }
nav.main a.cta {
  background: var(--green); color: #fffdf7; margin-left: 0.4rem;
}
nav.main a.cta:hover { background: #2f5540; color: #fff; }

/* ---------- buttons ---------- */
.btn {
  display: inline-block; text-decoration: none; font-weight: 800;
  font-family: 'Nunito Sans', sans-serif; font-size: 1.02rem;
  padding: 0.9rem 1.8rem; border-radius: 999px;
  transition: transform 0.12s, box-shadow 0.15s, background 0.15s;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(53, 41, 28, 0.14); }
.btn-green { background: var(--green); color: #fffdf7; box-shadow: 0 6px 20px var(--green-glow); }
.btn-green:hover { background: #2f5540; }
.btn-ghost { border: 2px solid var(--line); color: var(--text); background: var(--panel); }
.btn-ghost:hover { border-color: var(--green-dim); color: var(--green); }

/* ---------- hero ---------- */
.hero { padding: 5rem 0 3rem; position: relative; overflow: hidden; }
.kicker {
  display: inline-flex; align-items: center; gap: 0.55rem;
  background: var(--panel); border: 1px solid var(--line); border-radius: 999px;
  color: var(--muted); font-size: 0.88rem; font-weight: 700;
  padding: 0.38rem 1rem; margin-bottom: 1.6rem;
}
.kicker .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--green); flex-shrink: 0; }
.hero h1 {
  font-size: clamp(2.7rem, 7vw, 5rem);
  font-weight: 900; max-width: 17ch;
}
.hero h1 .done { color: var(--green); }
@media (min-width: 760px) { .hero h1 .done { white-space: nowrap; } }
.hero p.lede {
  color: var(--muted); font-size: clamp(1.08rem, 1.8vw, 1.28rem);
  max-width: 56ch; margin: 1.6rem 0 2.2rem;
}
.hero p.lede strong { color: var(--text); }
.hero .btns { display: flex; gap: 0.9rem; flex-wrap: wrap; }

/* rubber stamp — red ink on paper */
.stamp {
  position: absolute; right: 4%; top: 5rem;
  transform: rotate(8deg);
  border: 3.5px double var(--stamp-red); border-radius: 10px;
  color: var(--stamp-red); font-family: 'Nunito Sans', sans-serif;
  font-weight: 800; font-size: 0.95rem; letter-spacing: 0.22em; text-transform: uppercase;
  padding: 0.55rem 1.1rem; opacity: 0.75;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.7'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.9'/%3E%3C/svg%3E");
  mask-size: 120px;
}
@media (max-width: 900px) { .stamp { display: none; } }

.mockup { margin-top: 3.2rem; position: relative; }
.mockup img {
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: 0 24px 60px rgba(53, 41, 28, 0.18);
}
.mockup .cap {
  margin-top: 1rem; color: var(--muted); font-size: 0.95rem; text-align: center;
}
.mockup .cap a { color: var(--green); font-weight: 700; text-decoration: none; }
.mockup .cap a:hover { text-decoration: underline; }

/* ---------- manifesto strip ---------- */
.strip {
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: var(--bg-2);
  padding: 2.8rem 0;
}
.strip p {
  font-family: 'Fraunces', serif; font-style: italic;
  font-size: clamp(1.3rem, 2.7vw, 1.75rem); font-weight: 500;
  max-width: 44ch; margin: 0 auto; text-align: center; line-height: 1.45;
}
.strip p em { color: var(--green); font-style: italic; font-weight: 700; }

/* ---------- sections ---------- */
section.block { padding: 5.2rem 0; }
.eyebrow {
  color: var(--stamp-red); font-weight: 800; font-size: 0.84rem;
  letter-spacing: 0.24em; text-transform: uppercase; margin-bottom: 0.8rem;
}
.block h2 { font-size: clamp(2rem, 4.4vw, 3rem); font-weight: 900; margin-bottom: 0.8rem; }
.block .sub { color: var(--muted); max-width: 60ch; font-size: 1.1rem; margin-bottom: 2.4rem; }

/* steps */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.2rem; }
.step {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.8rem 1.6rem 1.7rem; position: relative; overflow: hidden;
  box-shadow: 0 6px 24px rgba(53, 41, 28, 0.06);
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.step:hover { border-color: var(--green-dim); transform: translateY(-4px); box-shadow: 0 14px 34px rgba(53, 41, 28, 0.12); }
.step .num {
  font-family: 'Fraunces', serif; font-weight: 900;
  font-size: 3rem; line-height: 1; color: var(--green);
  margin-bottom: 0.9rem;
}
.step h3 { font-size: 1.32rem; font-weight: 700; margin-bottom: 0.5rem; }
.step p { color: var(--muted); font-size: 0.97rem; }
.step p strong { color: var(--text); }
.step .ghost {
  position: absolute; right: -10px; bottom: -30px;
  font-family: 'Fraunces', serif; font-weight: 900; font-size: 7rem;
  color: rgba(62, 107, 79, 0.07); line-height: 1; pointer-events: none;
}

/* case study */
.case { display: grid; grid-template-columns: 1.15fr 1fr; gap: 3rem; align-items: center; }
@media (max-width: 880px) { .case { grid-template-columns: 1fr; } }
.case-img {
  border-radius: var(--radius); overflow: hidden;
  border: 8px solid #fff; outline: 1px solid var(--line);
  box-shadow: 0 20px 50px rgba(53, 41, 28, 0.16);
  transform: rotate(-1.2deg);
}
.case h3 { font-size: 1.9rem; font-weight: 900; margin-bottom: 0.7rem; }
.case .tagchip {
  display: inline-block; background: rgba(62, 107, 79, 0.09); color: var(--green);
  border: 1px solid var(--green-dim); border-radius: 999px;
  font-size: 0.8rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.25rem 0.85rem; margin-bottom: 1.1rem;
}
ul.ticks { list-style: none; margin: 1.1rem 0 1.6rem; }
ul.ticks li { padding-left: 1.9rem; position: relative; margin-bottom: 0.6rem; color: var(--muted); }
ul.ticks li strong { color: var(--text); }
ul.ticks li::before { content: "✓"; position: absolute; left: 0; color: var(--green); font-weight: 800; }

/* included grid */
.inc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.2rem; }
.inc {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.5rem 1.5rem 1.4rem;
  box-shadow: 0 6px 24px rgba(53, 41, 28, 0.05);
}
.inc .ico { font-size: 1.7rem; margin-bottom: 0.7rem; display: block; }
.inc h3 { font-size: 1.15rem; font-weight: 700; margin-bottom: 0.35rem; }
.inc p { color: var(--muted); font-size: 0.94rem; }

/* pricing */
.price-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
@media (max-width: 880px) { .price-wrap { grid-template-columns: 1fr; } }
.price-card {
  background: var(--panel);
  border: 2px solid var(--green); border-radius: 22px;
  padding: 2.4rem 2.3rem; position: relative;
  box-shadow: 0 20px 50px rgba(62, 107, 79, 0.12);
}
.price-card .label { color: var(--muted); font-weight: 700; font-size: 0.95rem; }
.price-card .amount {
  font-family: 'Fraunces', serif; font-weight: 900;
  font-size: 3.6rem; color: var(--text); line-height: 1.05;
}
.price-card .amount small { font-size: 1.15rem; color: var(--muted); font-weight: 500; font-family: 'Nunito Sans', sans-serif; }
.price-card .setup { color: var(--muted); margin: 0.3rem 0 1.2rem; }
.price-card .setup strong { color: var(--text); }
.price-card ul.ticks { margin-top: 1.2rem; }
.price-card .btn { width: 100%; text-align: center; margin-top: 1.4rem; }
.price-note { color: var(--muted); font-size: 0.92rem; margin-top: 0.9rem; text-align: center; font-style: italic; }

/* local */
.local { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
@media (max-width: 880px) { .local { grid-template-columns: 1fr; } }
.local img {
  border-radius: var(--radius);
  border: 8px solid #fff; outline: 1px solid var(--line);
  box-shadow: 0 16px 40px rgba(53, 41, 28, 0.14);
  transform: rotate(1deg);
}
.towns { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.4rem; }
.towns span {
  background: var(--panel); border: 1px solid var(--line); border-radius: 999px; color: var(--muted);
  font-size: 0.88rem; font-weight: 700; padding: 0.3rem 0.9rem;
}
.towns span.hot { border-color: var(--green); color: var(--green); background: rgba(62, 107, 79, 0.07); }

/* FAQ */
.faq { max-width: 760px; }
details { border-bottom: 1px solid var(--line); padding: 1.1rem 0; }
summary {
  cursor: pointer; font-family: 'Fraunces', serif; font-weight: 700;
  font-size: 1.18rem; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem;
}
summary::-webkit-details-marker { display: none; }
summary::after { content: "+"; color: var(--green); font-size: 1.5rem; font-weight: 400; transition: transform 0.2s; flex-shrink: 0; }
details[open] summary::after { transform: rotate(45deg); }
details p { color: var(--muted); padding-top: 0.7rem; max-width: 65ch; }
details p strong { color: var(--text); }

/* final CTA */
.finale {
  text-align: center; padding: 6rem 0 6.5rem;
  background: var(--bg-2);
  border-top: 1px solid var(--line);
}
.finale h2 { font-size: clamp(2.2rem, 5.2vw, 3.6rem); font-weight: 900; max-width: 22ch; margin: 0 auto 1.1rem; }
.finale h2 em { color: var(--green); font-style: italic; }
.finale p { color: var(--muted); max-width: 52ch; margin: 0 auto 2.2rem; font-size: 1.12rem; }

/* footer */
footer.site {
  border-top: 1px solid var(--line);
  background: var(--bg);
  padding: 2.2rem 0 2.6rem; color: var(--muted); font-size: 0.92rem;
}
footer.site .row { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; align-items: center; }
footer.site a { color: var(--muted); text-decoration: none; }
footer.site a:hover { color: var(--green); }
