/* Orchid light palette from Flutter tokens */
:root{
  /* Palette per brief */
  --color-primary:#6F59FF;
  --color-primary-hover:#5E4BE6;
  --color-on-primary:#FFFFFF;
  --color-surface:#FFFFFF;
  --color-on-surface:#1F1F1F;
  --color-on-surface-muted:#5B5B5B;
  --color-surface-tint:#F6F2FF;
  --color-outline:#E7E0FF;

  /* Icon accent backgrounds */
  --accent-lilac:#C6B6FF;
  --accent-soft-purple:#DCD4FF;
  --accent-pink:#F8C7E0;
  --accent-apricot:#FDE3C2;
  --accent-lavender:#E8DCFF;
  --accent-mauve:#E8E0FF;
  --accent-honey:#FFF1B8;

  --radius-xl:24px;
  --radius-lg:16px;
  --radius-md:12px;

  --font-display:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--color-surface);color:var(--color-on-surface);font-family:var(--font-body);font-weight:400;line-height:1.5;overflow-x:hidden}
a{color:inherit;text-decoration:none}
/* Make links in document pages look clearly clickable */
.doc a{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}
.doc a:hover{color:var(--color-primary-hover);text-decoration-thickness:2px}
/* Indicate external links that open in a new tab */
.doc a[target="_blank"]::after{content:"↗";margin-left:4px;font-size:.9em}
img{max-width:100%;height:auto}

.container{width:min(1040px,92%);margin-inline:auto;overflow:hidden}
.row{display:flex;gap:16px}
.between{justify-content:space-between}
.center{align-items:center}

.site-header{position:sticky;top:0;background:var(--color-surface);border-bottom:1px solid color-mix(in oklab,var(--color-outline),transparent 40%);backdrop-filter:saturate(1.2) blur(8px);z-index:10}
.site-header .brand{display:flex;gap:10px;align-items:center;padding-block:12px}
.brand-name{font-family:var(--font-display);font-weight:600;letter-spacing:-0.2px}
.site-nav{display:flex;gap:16px;align-items:center}
.site-nav a{padding:8px 10px;border-radius:10px;display:flex;align-items:center;gap:8px}
.site-nav .burger{display:none;background:transparent;border:1px solid color-mix(in oklab, var(--color-outline), transparent 35%);padding:6px 8px;border-radius:10px}

/* Language selector styling */
.language-selector {
  display: flex;
  align-items: center;
  margin-right: 16px;
}

.language-selector select {
  background: var(--color-surface);
  border: 1px solid color-mix(in oklab, var(--color-outline), transparent 35%);
  border-radius: 8px;
  padding: 6px 8px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-on-surface);
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.language-selector select:hover {
  border-color: var(--color-primary);
}

.language-selector select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--color-primary), transparent 80%);
}
.site-nav .burger .material-symbols-rounded{font-size:22px}
.site-nav .nav-links{display:flex;gap:16px;position:relative;z-index:20}
.site-nav a[aria-current="page"]{background:var(--color-surface-container)}
.site-nav .cta .material-symbols-rounded{font-size:20px}
.site-nav .nav-link{display:flex;align-items:center}

/* Modal */
.modal{border:none;border-radius:16px;padding:0;max-width:min(520px,92%);box-shadow:0 20px 60px rgba(0,0,0,.18);}
.modal::backdrop{background:rgba(0,0,0,.35)}
.modal-body{padding:24px 20px 16px;text-align:center}
.modal-icon .material-symbols-rounded{font-size:48px;color:var(--color-primary)}
.modal h3{font-family:var(--font-display);font-weight:600;margin:12px 0 8px}
.modal p{color:var(--color-on-surface-muted);margin:0 0 16px}
.modal .actions{display:flex;justify-content:center;padding-bottom:8px}

.hero{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;padding:96px 0;position:relative}
.hero:before{content:"";position:absolute;inset:0;background:url('./public/images/hero-flowers.png') center/cover no-repeat;opacity:.12;pointer-events:none}
.hero > *{position:relative}
.hero-text h1{font-family:var(--font-display);font-weight:500;font-size:52px;line-height:1.2;margin:0 0 12px;letter-spacing:-0.2px}
.lede{font-size:18px;color:var(--color-on-surface-muted);margin:0 0 16px}
.store-buttons{display:flex;gap:12px;flex-wrap:wrap}

.btn{display:inline-block;padding:14px 18px;border-radius:var(--radius-lg);font-weight:600;border:1px solid var(--color-outline)}
.btn.primary{background:var(--color-primary);color:var(--color-on-primary);border-color:var(--color-primary)}
.btn.outline{background:var(--color-surface)}
.btn.disabled{opacity:.6;pointer-events:none}
.btn i{margin-right:8px}
.btn.outline .fa-android{color:#3DDC84}
.btn.primary .fa-apple{color:#FFFFFF}

.hero-art{background:transparent;border:none;padding:0;border-radius:0}
.phone-mock{display:block;max-width:360px;width:100%;height:auto}
.hint{font-size:12px;opacity:.75;margin-top:8px}

/* Simple phone mockup */
.phone-frame{position:relative;aspect-ratio:9/19;border-radius:36px;border:1px solid var(--color-outline);background:#000;box-shadow:0 20px 60px rgba(15,11,26,.18), 0 6px 18px rgba(15,11,26,.08);overflow:hidden;max-width:360px;margin-inline:auto}
.phone-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:40%;height:22px;background:#000;border-bottom-left-radius:14px;border-bottom-right-radius:14px;z-index:2}
.phone-screen{position:absolute;inset:8px;background:#fff;border-radius:30px;object-fit:cover;width:calc(100% - 16px);height:calc(100% - 16px)}

.how{padding:48px 0 32px}
.how.hero{padding:96px 0 56px}
.how h2{font-family:var(--font-display);font-weight:500;margin:0 0 8px;font-size:36px;letter-spacing:-0.2px;text-align:center}
.sub{color:var(--color-on-surface-muted);margin:0 0 16px;font-family:var(--font-body);font-weight:400}
.how .sub{text-align:center}
.card-grid{list-style:none;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:20px 0 0;padding:0}
.card{background:color-mix(in oklab, var(--color-surface-tint), white 40%);border:1px solid color-mix(in oklab, var(--color-outline), transparent 40%);border-radius:20px;padding:22px;transition:transform .25s ease, box-shadow .25s ease;text-align:center}
.card h3{margin:8px 0 6px;font-weight:500;font-family:var(--font-display)}
.card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.06)}
.icon-tile{display:inline-grid;place-items:center;width:96px;height:96px;border-radius:16px;background:var(--color-surface-tint);border:1px solid color-mix(in oklab, var(--color-outline), transparent 40%)}
.icon-tile.lilac{background:#C6B6FF}
.icon-tile.purple{background:#DCD4FF}
.icon-tile.pink{background:#F8C7E0}
.icon-tile.apricot{background:#FDE3C2}
.icon-tile.lavender{background:#E8DCFF}
.icon-tile.mauve{background:#E8E0FF}
.icon-tile.honey{background:#FFF1B8}
.icon-tile svg.tabler{width:48px;height:48px;stroke:#1F1F1F;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon-pill{display:inline-grid;place-items:center;width:auto;height:auto;border-radius:14px;background:transparent;margin-bottom:12px;border:none}
.icon-pill.lilac{background:transparent}
.icon-pill.purple{background:transparent}
.icon-pill.pink{background:transparent}
.icon-pill .material-symbols-rounded{font-size:48px;line-height:1;color:rgba(31,31,31,.85)}
.icon-svg{width:48px;height:48px;stroke:rgba(31,31,31,.9);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card .icon-svg{stroke:rgba(31,31,31,.9)}
.mini.apricot .icon-svg{stroke:#6BAF52}
.mini.lavender .icon-svg{stroke:#6F59FF}
.mini.mauve .icon-svg{stroke:#E0B0FF}
.mini.honey .icon-svg{stroke:#E2A400}
.icon-img{width:48px;height:48px;display:block}
.icon-ph i{font-size:48px;line-height:1;--ph-duotone-primary: rgba(31,31,31,.9);--ph-duotone-secondary: rgba(31,31,31,.35)}
.lilac.icon-ph i{color:#7E6AE6; --ph-duotone-secondary: color-mix(in oklab, #C6B6FF, white 40%)}
.apricot.icon-ph i{color:#F4B981; --ph-duotone-secondary: color-mix(in oklab, #FDE3C2, white 35%)}
.mauve.icon-ph i{color:#E0B0FF; --ph-duotone-secondary: color-mix(in oklab, #E8E0FF, white 15%)}
.mini.green .icon-ph i{color:#6BAF52; --ph-duotone-secondary: rgba(31,31,31,.3)}
.mini.lavender .icon-ph i{color:#7E6AE6; --ph-duotone-secondary: color-mix(in oklab, #E8DCFF, white 35%)}
.mini.mauve .icon-ph i{--ph-duotone-secondary: color-mix(in oklab, #E0B0FF, white 15%)}
.mini.honey .icon-ph i{color:#E2A400; --ph-duotone-secondary: color-mix(in oklab, #FFF1B8, white 20%)}
.mini.apricot .icon-ph i{color:#F4B981; --ph-duotone-secondary: color-mix(in oklab, #FDE3C2, white 35%)}

.research{padding:40px 0 56px}
.research h2{font-family:var(--font-display);font-weight:500;margin:0 0 8px;font-size:32px;letter-spacing:-0.2px;text-align:center}
.research .sub{text-align:center}
.mini-grid{list-style:none;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin:16px 0 0;padding:0}
.mini{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border:1px solid color-mix(in oklab, var(--color-outline), transparent 35%);border-radius:20px;padding:20px;background:color-mix(in oklab, var(--color-surface-tint), white 35%);box-shadow:0 6px 18px rgba(0,0,0,.04)}
.mini.apricot{background:color-mix(in oklab, var(--accent-apricot), white 35%)}
.mini.lavender{background:color-mix(in oklab, var(--accent-lavender), white 35%)}
.mini.mauve{background:color-mix(in oklab, var(--accent-mauve), white 35%)}
.mini.honey{background:color-mix(in oklab, var(--accent-honey), white 35%)}
.mini .icon-pill{width:auto;height:auto;border-radius:0;margin-bottom:10px}
.mini h3{margin:0;font-weight:500;font-family:var(--font-display)}
/* Phosphor duotone icons inside mini cards */
.mini .icon-ph i{font-size:48px;line-height:1;--ph-duotone-primary: rgba(31,31,31,.9);--ph-duotone-secondary: rgba(31,31,31,.32)}
.mini.apricot .icon-ph i{color:#6BAF52}
.mini.lavender .icon-ph i{color:#6F59FF}
.mini.mauve .icon-ph i{color:#7A66F3}
.mini.honey .icon-ph i{color:#E2A400}

.garden-band{position:relative;background:var(--color-surface);overflow:hidden}
.garden-band:before{content:"";position:absolute;inset:0;pointer-events:none}
.garden-art{position:relative;display:flex;justify-content:center;padding:0 0 24px;overflow:hidden}
.garden-img{width:min(1100px,100%);max-width:100vw;height:auto;display:block;margin-inline:auto}
.band-overlay{position:absolute;top:0;left:50%;transform:translateX(-50%);width:100%;max-width:min(1100px,92vw);text-align:center;padding-top:16px}
.band-overlay h2{font-family:var(--font-display);font-weight:500;margin:0 0 6px;font-size:32px;letter-spacing:-0.2px}
.band-overlay p{margin:0;color:#2b2b2b}

.shots{padding:24px 0}
.shots h2{font-family:var(--font-display);font-weight:500;margin:0 0 10px;text-align:center;font-size:32px;letter-spacing:-0.2px}
.carousel{display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 32px)/3);gap:16px;overflow-x:auto;max-width:100%;scroll-snap-type:x mandatory;padding-bottom:8px}
.slide{scroll-snap-align:start;text-align:center}
.slide figcaption{margin-top:8px;color:var(--color-on-surface-muted)}
.phone-frame.small{max-width:240px}

.closing{padding:56px 0;text-align:center}
.closing h2{font-family:var(--font-display);font-weight:500;margin:0 0 10px}

.doc{padding:32px 0 64px}
.doc h1{font-family:var(--font-display);font-weight:700}
.doc h2{margin-top:28px}
.doc ul{padding-left:20px}

/* Support form */
.support{padding:40px 0}
.support h1{font-family:var(--font-display);font-weight:600;margin:0 0 8px}
.support p{color:var(--color-on-surface-muted)}
.support form{margin-top:16px;display:grid;gap:12px;max-width:640px}
.field{display:grid;gap:6px}
.field label{font-weight:500}
.field input,.field textarea{border:1px solid color-mix(in oklab, var(--color-outline), transparent 35%);border-radius:12px;padding:12px 14px;font-family:var(--font-body)}
.field textarea{min-height:140px;resize:vertical}
.notice{padding:12px 14px;border-radius:12px;background:color-mix(in oklab, var(--accent-lavender), white 45%);border:1px solid color-mix(in oklab, var(--color-outline), transparent 35%)}

.site-footer{border-top:1px solid var(--color-outline);padding:16px 0;background:var(--color-surface)}
.footer-links{display:flex;gap:16px}

@media (max-width:900px){
  .hero{grid-template-columns:1fr;padding:56px 0;gap:20px;overflow:hidden}
  .card-grid{grid-template-columns:1fr}
  .mini-grid{grid-template-columns:1fr 1fr}
  .carousel{grid-auto-columns:100%}
  .hero-text h1{font-size:40px}
  .lede{font-size:16px}
  .site-header .container{flex-wrap:wrap}
  .site-nav{gap:10px}
  .site-nav .burger{display:inline-flex}
  .site-nav .nav-links{display:none;position:absolute;top:60px;right:4%;background:var(--color-surface);border:1px solid color-mix(in oklab, var(--color-outline), transparent 35%);border-radius:12px;box-shadow:0 16px 40px rgba(0,0,0,.12);padding:8px 10px;flex-direction:column;min-width:160px;z-index:50}
  .site-nav .nav-links a{padding:10px 12px}
  .site-nav .nav-links.open{display:flex}
}

@media (max-width:600px){
  .container{width:min(1040px,94%)}
  .brand-name{font-size:14px}
  .site-nav a{padding:6px 8px}
  .site-nav .cta .material-symbols-rounded{font-size:18px}
  .hero{padding:24px 0 28px}
  .how.hero{padding:20px 0}
  .hero-text{text-align:center}
  .hero-text h1{font-size:34px;margin-bottom:10px}
  .lede{font-size:15px;margin-bottom:14px}
  .store-buttons{justify-content:center}
  .hero .phone-frame{max-width:min(260px,80vw)}
  .hero-art{padding-top:30px}
  .research{padding:36px 0 48px}
  .research h2{font-size:28px}
  .mini h3{font-size:16px}
  .band-overlay{padding-top:12px}
  .band-overlay h2{font-size:28px}
  .shots h2{font-size:28px}
  .phone-frame.small{max-width:220px}
  /* Garden band: avoid overlaying text on image on small screens */
  .garden-art{display:flex;flex-direction:column-reverse;align-items:center;padding:0 0 24px}
  .band-overlay{position:static;transform:none;max-width:100%;width:100%;padding:8px 0 6px;background:transparent}
}
@media (min-width:901px){
  /* Reduce hero phone size to ~60% of previous (360px -> 216px) */
  .hero .phone-frame{max-width:216px}
}

/* scroll reveal */
.card, .mini, .band-content, .slide, .hero-text, .hero-art{opacity:0;transform:translateY(24px);transition:opacity .28s ease, transform .32s ease}
.reveal{opacity:1;transform:translateY(0)}


