/* Pomar — pomar.one landing (V1). Modern Minimal: graphite surfaces, a coral signature. */
:root {
  --bg0:#0d0e11; --bg1:#15171c; --bg2:#1c1f25; --border:#2a2d34;
  --text:#e7e9ee; --text2:#aab0bb; --text3:#727885;
  --accent:#ed6a4d; --accent-hi:#f4806a; --accent-soft:rgba(237,106,77,.13);
  --radius:14px; --radius-sm:9px; --maxw:1120px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--font); background:var(--bg0); color:var(--text);
  line-height:1.55; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; height:auto; display:block; }
.wrap { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.center { text-align:center; }
.muted { color:var(--text3); }

/* ---- type ---- */
h1 { font-size:clamp(2.1rem,5vw,3.5rem); line-height:1.05; letter-spacing:-.02em; font-weight:680; }
h2 { font-size:clamp(1.6rem,3.4vw,2.3rem); line-height:1.12; letter-spacing:-.018em; font-weight:660; }
h3 { font-size:1.3rem; letter-spacing:-.01em; font-weight:640; }
p { color:var(--text2); }
.lead { font-size:1.18rem; color:var(--text); margin-top:18px; max-width:42ch; }
.lead-narrow { font-size:1.12rem; color:var(--text2); max-width:60ch; margin:18px auto 0; }
.eyebrow { color:var(--accent); font-size:.8rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; margin-bottom:18px; }
.kicker { color:var(--accent); font-size:.78rem; font-weight:650; letter-spacing:.08em; text-transform:uppercase; margin-bottom:14px; }
.fineprint { color:var(--text3); font-size:.9rem; margin-top:20px; }
.note { background:var(--bg1); border:1px solid var(--border); border-radius:var(--radius-sm); padding:14px 16px; font-size:.95rem; margin-top:18px; }
.formula { font-family:var(--mono); color:var(--accent-hi); background:var(--accent-soft); display:inline-block;
  padding:8px 14px; border-radius:8px; margin:8px 0; font-size:1rem; }

/* ---- buttons ---- */
.btn { display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:.95rem;
  padding:11px 18px; border-radius:10px; border:1px solid transparent; cursor:pointer; transition:.16s ease;
  white-space:nowrap; }
.btn--lg { padding:15px 26px; font-size:1.05rem; }
.btn--accent { background:var(--accent); color:#1a0f0c; }
.btn--accent:hover { background:var(--accent-hi); transform:translateY(-1px); }
.btn--ghost { background:transparent; color:var(--text); border-color:var(--border); }
.btn--ghost:hover { border-color:var(--text3); background:var(--bg1); }
.ver { font-size:.85em; opacity:.8; font-weight:600; }

/* ---- nav ---- */
.nav { position:sticky; top:0; z-index:50; background:rgba(13,14,17,.82); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border); }
.nav__inner { display:flex; align-items:center; gap:24px; height:64px; }
.brand { display:inline-flex; align-items:center; gap:10px; font-weight:700; letter-spacing:-.01em; font-size:1.15rem; }
.brand__mark { width:16px; height:16px; border-radius:5px; background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-soft); }
.nav__links { display:flex; gap:26px; margin-left:auto; font-size:.95rem; color:var(--text2); }
.nav__links a:hover { color:var(--text); }
.nav__cta { margin-left:4px; }

/* ---- hero ---- */
.hero { padding:72px 0 64px; background:
  radial-gradient(900px 400px at 78% -8%, rgba(237,106,77,.10), transparent 60%); }
.hero__grid { display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center; }
.hero__grid > * { min-width:0; }
.hero__cta { display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
.center-cta { justify-content:center; }
.hero__caption { text-align:center; color:var(--text3); font-size:.85rem; margin-top:16px; letter-spacing:.01em; }

/* product screenshots */
.hero__shot { width:100%; height:auto; display:block; border-radius:14px; border:1px solid var(--border);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.85); }
.shot { margin:44px auto 0; max-width:780px; }
.shot img { width:100%; height:auto; display:block; border-radius:14px; border:1px solid var(--border);
  box-shadow:0 26px 64px -30px rgba(0,0,0,.8); }
.shot figcaption { color:var(--text3); font-size:.92rem; text-align:center; margin-top:14px; }

/* ---- sections ---- */
.sec { padding:74px 0; border-top:1px solid var(--border); }
.sec--alt { background:var(--bg1); }
.sec__split { display:grid; grid-template-columns:1.15fr .85fr; gap:54px; align-items:start; }
.sec__head h2 { margin-bottom:16px; }
.sec__head p { margin-top:12px; max-width:52ch; }
.routes { display:flex; flex-direction:column; gap:8px; margin-top:20px; }
.routes code { font-family:var(--mono); font-size:.86rem; color:var(--text); background:var(--bg2);
  border:1px solid var(--border); padding:9px 12px; border-radius:8px; }

/* feature lists */
.featlist { list-style:none; display:flex; flex-direction:column; gap:2px; margin-top:6px; }
.featlist li { padding:13px 4px 13px 30px; border-bottom:1px solid var(--border); position:relative; color:var(--text); font-size:1.02rem; }
.featlist li::before { content:""; position:absolute; left:4px; top:50%; transform:translateY(-50%);
  width:8px; height:8px; border-radius:2px; background:var(--accent); }
.featlist li:last-child { border-bottom:none; }
.featlist--no li::before { background:none; content:"×"; color:var(--text3); left:2px; width:auto; height:auto;
  transform:translateY(-50%); font-size:1.05rem; line-height:1; }

/* ecosystem */
.sec--feature { text-align:center; background:
  radial-gradient(800px 360px at 50% 0%, rgba(237,106,77,.07), transparent 62%); }
.sec--feature .kicker { display:block; }
.duo { display:flex; align-items:stretch; justify-content:center; gap:18px; margin:44px 0 28px; flex-wrap:wrap; }
.duo__card { flex:1 1 320px; max-width:380px; text-align:left; background:var(--bg1); border:1px solid var(--border);
  border-radius:var(--radius); padding:26px; }
.duo__card--soon { background:transparent; border-style:dashed; }
.duo__card h3 { margin:14px 0 8px; }
.duo__plus { align-self:center; color:var(--text3); font-size:1.8rem; font-weight:300; }
.tag { display:inline-block; font-size:.72rem; font-weight:650; letter-spacing:.03em; padding:5px 10px; border-radius:999px; text-transform:uppercase; }
.tag--now { background:var(--accent-soft); color:var(--accent-hi); }
.tag--soon { background:var(--bg2); color:var(--text3); }

/* the name / orchard */
.sec--orchard { text-align:center; background:
  radial-gradient(720px 320px at 50% 0%, rgba(237,106,77,.06), transparent 62%); }
.sec--orchard em { color:var(--accent-hi); font-style:italic; }
.flavours { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:32px auto 22px; max-width:640px; }
.flavours span { font-size:.92rem; color:var(--text2); background:var(--bg2); border:1px solid var(--border);
  padding:8px 15px; border-radius:999px; }

/* download */
.sec--download { text-align:center; background:var(--bg1);
  background-image:radial-gradient(700px 320px at 50% 120%, rgba(237,106,77,.10), transparent 60%); }
.betanotes { list-style:none; display:inline-flex; flex-wrap:wrap; justify-content:center; gap:10px 22px; margin-top:30px; color:var(--text2); font-size:.92rem; }
.betanotes li { position:relative; padding-left:16px; }
.betanotes li::before { content:""; position:absolute; left:0; top:.62em; width:6px; height:6px; border-radius:50%; background:var(--accent); }

/* footer */
.footer { border-top:1px solid var(--border); padding:50px 0 40px; background:var(--bg0); }
.footer__inner { display:flex; justify-content:space-between; gap:32px; flex-wrap:wrap; margin-bottom:26px; }
.footer__brand { max-width:340px; }
.footer__brand p { margin-top:12px; font-size:.92rem; }
.footer__links { display:flex; flex-direction:column; gap:10px; font-size:.95rem; color:var(--text2); }
.footer__links a:hover { color:var(--text); }
.footer__small { font-size:.82rem; border-top:1px solid var(--border); padding-top:22px; max-width:760px; }

/* ---- responsive ---- */
@media (max-width:860px) {
  .hero__grid, .sec__split { grid-template-columns:1fr; gap:36px; }
  .hero { padding:48px 0 44px; }
  .nav__links { display:none; }
  .hero__visual { order:-1; }
  .sec { padding:56px 0; }
}
@media (max-width:480px) {
  .nav__cta { display:none; }
  .btn--lg { width:100%; justify-content:center; }
  .hero__cta, .center-cta { flex-direction:column; }
}
