/* HouseKraft Landing Styles — Light theme with beige accents
   Variant: Compact Footer + Underlined Links
*/
:root{
  --bg:#faf7f1;
  --panel:#ffffff;
  --muted:#6b7280;
  --text:#1f2937;
  --brand:#e6d9c9;      /* beige light */
  --brand2:#d4b996;     /* beige medium */
  --accent:#b3845a;     /* warm accent */
  --ring: rgba(212,185,150,.35);
  --link:#8a5a36;       /* accessible warm link */
  --link-hover:#6f482b; /* darker on hover */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,'Noto Sans',sans-serif;line-height:1.55}

/* Global link styling */
a{
  color:var(--link);
  text-decoration:underline;
  text-underline-offset:2px;
  text-decoration-thickness:1.5px;
}
a:hover,
a:focus-visible{color:var(--link-hover)}
a:focus-visible{outline:2px solid var(--ring); outline-offset:2px}

/* Buttons and pill CTAs should not be underlined */
.btn, .cta-pill{
  text-decoration:none;
  color:inherit;
}

.container{max-width:1100px;margin:0 auto;padding:clamp(16px,2vw,24px)}

.site-header{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:14px}
.logo-img{width:48px;height:48px;object-fit:contain;border-radius:8px}
.brand-text h1{margin:0;font-size:1.25rem}
.tagline{margin:.125rem 0 0;color:var(--muted);font-size:.9rem}
.links{display:flex;gap:14px;align-items:center}
.links a{opacity:.95}

/* ===== HERO ===== */
.hero{display:grid;grid-template-columns:1fr 1.35fr;gap:28px;align-items:center}
.hero-text h2{font-size:clamp(28px,4.2vw,48px);line-height:1.05;margin:0 0 12px}
.gradient{background:linear-gradient(135deg,var(--brand2),var(--brand));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-text p{color:var(--muted);margin:0 0 16px}

.btn{display:inline-block;background:linear-gradient(135deg,var(--brand2),var(--brand));color:#0b0b0c;font-weight:700;border:0;border-radius:12px;padding:.9rem 1.1rem;box-shadow:0 0 0 0 rgba(0,0,0,0);transition:transform .08s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px -12px var(--ring)}
.btn:active{transform:translateY(0) scale(.98)}

.hero-card .card{background:linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.015));border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:14px}
.card-badge{display:inline-block;font-size:.75rem;color:var(--muted);border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:.2rem .6rem;margin-bottom:8px}

/* Large preview with video support */
.card-media{
  position: relative;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  aspect-ratio: 16 / 9;
  max-height: 520px;
}
.hero-video{display:block;width:100%;height:100%;object-fit:cover}
.card-caption{color:var(--muted);margin:.6rem 0 0}

/* ===== FEATURES ===== */
.features h3, .trial h3, .waitlist h3{font-size:clamp(20px,3vw,28px);margin:0 0 14px}
.feature-grid{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:0;margin:0}
.feature-grid li{background:var(--panel);border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:16px}
.feature-grid h4{margin:.2rem 0 .3rem;font-size:1.05rem}
.feature-grid p{margin:0;color:var(--muted)}
.feat-img{width:100%;height:auto;display:block;border-radius:12px;border:1px solid rgba(0,0,0,.08);margin-bottom:.6rem;background:#f4ebde}

/* ===== TRIAL CREATIVES ===== */
.trial .cta-row{display:flex;flex-wrap:wrap;gap:10px}
.cta-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(0,0,0,.14);border-radius:999px;padding:.6rem .9rem;background:rgba(0,0,0,.03)}
.pill-note{color:var(--muted);font-size:.9em}

.trial-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:12px}
.trial-card{background:var(--panel);border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.trial-img{width:100%;height:auto;display:block}
.trial-meta{padding:12px 14px;color:var(--text)}
.trial-meta p{margin:.25rem 0 0;color:var(--muted);font-size:.95rem}

/* ===== WAITLIST ===== */
.waitlist-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center;background:rgba(0,0,0,.03);border:1px solid rgba(0,0,0,.1);padding:10px;border-radius:14px}
.waitlist-form input[type="email"]{flex:1;min-width:220px;background:#ffffff;border:1px solid rgba(0,0,0,.14);color:var(--text);padding:.8rem 1rem;border-radius:10px;outline:none}
.waitlist-form input[type="email"]:focus{border-color:var(--brand2);box-shadow:0 0 0 6px var(--ring)}
.waitlist-form .hp{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.form-hint{width:100%;margin:0;color:var(--muted);font-size:.9rem}

/* ===== FOOTER (COMPACT) ===== */
.site-footer{
  border-top:1px solid rgba(0,0,0,.08);
  margin-top:16px;
  padding-top:8px;
  display:flex;
  flex-wrap:wrap;
  flex-direction:row;
  gap:4px 12px;
  align-items:center;
}
.site-footer p{
  margin:0;
  line-height:1.25;
  font-size:0.95rem;
}
.muted{color:var(--muted)}

/* Utilities */
.visually-hidden{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
img, video{max-width:100%; height:auto; display:block}

/* Base small-screen behaviour */
@media (max-width:900px){
  .hero{grid-template-columns:1fr;gap:18px}
  .hero-card{order:-1}
  .card-media{max-height:360px}
  .trial-grid{grid-template-columns:1fr}
}

/* ===== Responsive Hotfixes ===== */

/* 1) Header wrap + spacing on medium screens */
@media (max-width: 1100px){
  .site-header{flex-wrap:wrap}
  .links{width:100%; justify-content:flex-start; gap:12px; margin-top:8px}
}

/* 2) Hero: stack earlier on tablets and keep preview above text on mobile */
@media (max-width: 1100px){
  .hero{grid-template-columns:1fr}
  .hero-card{order:-1}
}

/* 2b) Rock-solid 16:9 for hero preview (older Safari/Android) */
.card-media{position:relative}
.card-media::before{content:""; display:block; padding-top:56.25%} /* 16:9 aspect ratio shim */
.card-media > .hero-video,
.card-media > img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}

/* 3) Prevent subtle overflow on narrow viewports */
.container{padding-left:clamp(12px,2vw,24px); padding-right:clamp(12px,2vw,24px)}

/* 4) Feature & Trial grids collapse to 1-col on phones */
@media (max-width: 900px){
  .feature-grid{grid-template-columns:1fr}
  .trial-grid{grid-template-columns:1fr}
}

/* 5) Waitlist form ergonomics on phones */
@media (max-width: 600px){
  .waitlist-form{flex-direction:column; align-items:stretch}
  .waitlist-form button{width:100%}
}

/* 6) CTA pills wrap nicely */
.cta-row{flex-wrap:wrap}
.cta-pill{white-space:nowrap}

/* 7) Footer line-breaks better on tiny screens (still compact) */
@media (max-width:600px){
  .site-footer{align-items:flex-start; gap:4px 8px}
  .site-footer p{font-size:.92rem}
}
.site-footer a{word-break:break-word}
