:root{
  --canvas:#FBF6EA; --surface:#FFFDF7; --border:#EAE2D2;
  --primary:#6FB1DC; --primary-deep:#2F6FA5; --on-primary:#11324A;
  --butter:#F4E3A1; --butter-soft:#F8EEC4; --sage:#C2D2BE;
  --blush:#E8C4BA; --blush-soft:#F2DDD6;
  --text:#423D38; --muted:#9A938A;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--canvas);color:var(--text);font:16px/1.6 "Nunito Sans",sans-serif}
h1,h2,h3{font-family:"Quicksand",sans-serif;font-weight:600;line-height:1.25}
a{color:var(--primary-deep)}
.wrap{max-width:960px;margin:0 auto;padding:0 24px}

/* header + nav with Apps dropdown */
header{padding:18px 0;border-bottom:1px solid var(--border);background:var(--surface);position:relative;z-index:5}
header .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand{font-family:"Quicksand",sans-serif;font-weight:600;font-size:20px;text-decoration:none;color:var(--text)}
nav{display:flex;align-items:center;gap:20px}
nav a{ text-decoration:none;font-weight:600;font-size:15px;color:var(--primary-deep)}
.menu{position:relative}
.menu-btn{font:600 15px "Nunito Sans",sans-serif;color:var(--primary-deep);background:none;border:none;cursor:pointer;padding:6px 0}
.menu-list{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:8px;min-width:170px;margin-top:6px}
.menu:hover .menu-list,.menu:focus-within .menu-list{display:block}
/* Invisible bridge over the 6px gap between the button and the dropdown, so
   the menu doesn't close while the pointer crosses from one to the other. */
.menu-list::before{content:"";position:absolute;top:-10px;left:-10px;right:-10px;height:12px}
.menu-list a{display:block;padding:10px 14px;border-radius:10px}
.menu-list a:hover{background:var(--butter-soft)}
.menu-list .soon{display:block;padding:10px 14px;color:var(--muted);font-size:14px}

/* hero */
.hero{padding:72px 0 56px;text-align:center;position:relative;overflow:hidden}
.hero h1{font-size:clamp(30px,5vw,44px);max-width:640px;margin:0 auto 16px}
.hero p{color:var(--muted);max-width:540px;margin:0 auto}
.blob{position:absolute;border-radius:50%;opacity:.5;pointer-events:none}
.blob.b1{width:280px;height:280px;background:var(--blush-soft);top:-120px;right:-100px}
/* Sits fully inside the hero so it's only ever clipped by the screen edge,
   never chopped flat by the hero's invisible bottom boundary. */
.blob.b2{width:200px;height:200px;background:var(--sage);bottom:16px;left:-90px}

section{padding:56px 0}
.section-title{font-size:26px;margin-bottom:28px}

/* apps carousel (home) */
.carousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px 4px 16px;-webkit-overflow-scrolling:touch}
.slide{flex:0 0 min(420px,86%);scroll-snap-align:center;background:var(--surface);
  border:1px solid var(--border);border-radius:24px;padding:28px;display:flex;
  flex-direction:column;gap:12px}
.slide .app-icon{width:72px;height:72px;border-radius:20px;border:1px solid var(--border)}
.slide h3{font-size:22px}
.slide p{color:var(--text)}
.slide .spacer{flex:1}
.tag{display:inline-block;background:var(--butter-soft);border:1px solid var(--border);
  border-radius:999px;padding:4px 14px;font-size:13px;color:var(--muted);align-self:flex-start}
.tag.teaser{background:var(--blush-soft)}
.btn{display:inline-block;background:var(--primary);color:var(--on-primary);text-decoration:none;
  font-family:"Quicksand",sans-serif;font-weight:600;font-size:15px;border-radius:16px;
  padding:12px 22px;align-self:flex-start}
.btn.soon{background:var(--butter-soft);color:var(--muted);pointer-events:none;border:1px solid var(--border)}
.carousel-hint{color:var(--muted);font-size:13px;margin-top:4px}

/* app page blocks */
.app-hero{display:flex;align-items:center;gap:20px;flex-wrap:wrap;padding:48px 0 8px}
.app-hero img{width:96px;height:96px;border-radius:26px;border:1px solid var(--border)}
.app-hero .titles h1{font-size:34px}
.app-hero .titles p{color:var(--muted)}
.feature{display:flex;gap:36px;align-items:center;background:var(--surface);
  border:1px solid var(--border);border-radius:24px;padding:36px;flex-wrap:wrap;margin-bottom:24px}
.feature.flip{flex-direction:row-reverse}
.feature .shot{flex:0 0 220px;max-width:220px;margin:0 auto}
.feature .about{flex:1;min-width:260px}
.feature h3{font-size:22px;margin-bottom:10px}
.feature p{margin-bottom:12px}
.shot img{width:100%;border-radius:24px;border:1px solid var(--border);display:block}
.shot .placeholder{aspect-ratio:9/19;border:1px solid var(--border);border-radius:28px;
  background:var(--surface);display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:12px;padding:18px;text-align:center}
.shot .placeholder img{width:64px;height:64px;border-radius:18px;border:1px solid var(--border)}
.shot .placeholder span{color:var(--muted);font-size:13px}
.stores{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}

/* accordions */
details{background:var(--surface);border:1px solid var(--border);border-radius:16px;
  padding:16px 20px;margin-bottom:12px}
summary{font-family:"Quicksand",sans-serif;font-weight:600;cursor:pointer;font-size:17px}
details .body{padding-top:12px}
details .body p,details .body li{margin-bottom:10px}
details .body ul{padding-left:22px}

/* contact */
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;
  padding:40px;text-align:center;max-width:520px;margin:0 auto}
.contact-card p{color:var(--muted);margin:10px 0 22px}

footer{border-top:1px solid var(--border);background:var(--surface);
  padding:32px 0;margin-top:40px;text-align:center;color:var(--muted);font-size:14px}
footer a{font-weight:600}
