/* ============================================================================
   dep.app — shared design system  ·  dark-studio / luminous
   Pure CSS, no build. One cached file drives every page.
   Per-app accent: set .accent-* on a card or hero; vars cascade to glow/links.
   ========================================================================== */

:root{
  /* dark-first canvas */
  --bg:#0F1115;
  --bg-2:#0B0D11;
  --surface:#161A21;
  --surface-2:#1B2029;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.14);
  --text:#ECEEF2;
  --muted:#9AA3B2;
  --faint:#6B7280;

  /* default accent = Hourly Move (coral → amber), overridden per app */
  --accent:#FF6B4A;
  --accent-2:#FFB020;
  --accent-soft:#3FB6A8;
  --on-accent:#1A1208;

  --nav-h:68px;
  --maxw:1080px;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 18px 40px -22px rgba(0,0,0,.8);
  --ease:cubic-bezier(.22,.61,.36,1);

  --font-display:"Bricolage Grotesque","Hanken Grotesk",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}

/* per-app accents (work on dark and light) */
.accent-hm    { --accent:#FF6B4A; --accent-2:#FFB020; --accent-soft:#3FB6A8; --on-accent:#1A1208; }
.accent-blue  { --accent:#5AA2FF; --accent-2:#3B82F6; --accent-soft:#22D3EE; --on-accent:#06122B; }
.accent-bright{ --accent:#FBBF24; --accent-2:#F59E0B; --accent-soft:#FCD34D; --on-accent:#241803; }
.accent-note  { --accent:#34D399; --accent-2:#10B981; --accent-soft:#6EE7B7; --on-accent:#04231A; }
.accent-sub   { --accent:#FF5C5C; --accent-2:#3FB6A8; --accent-soft:#5AA2FF; --on-accent:#1A0A0A; }

[data-theme="light"]{
  --bg:#F7F6F3;
  --bg-2:#FFFFFF;
  --surface:#FFFFFF;
  --surface-2:#F2F1EC;
  --line:rgba(17,20,26,.10);
  --line-strong:rgba(17,20,26,.18);
  --text:#16181D;
  --muted:#5A6270;
  --faint:#8A9099;
  --shadow:0 18px 40px -26px rgba(20,23,28,.35);
}

/* ---------- reset & base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-top:var(--nav-h);
  overflow-x:hidden;
}
/* faint film-grain over everything for depth */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
[data-theme="light"] body::after{opacity:.025}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--on-accent)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--font-mono);font-size:.72rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  background:color-mix(in srgb,var(--bg) 78%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-weight:700;font-size:1.18rem;letter-spacing:-.02em}
.brand .dot{width:11px;height:11px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 0 14px var(--accent)}
.nav-right{display:flex;align-items:center;gap:1.6rem}
.nav-link{color:var(--muted);font-weight:500;font-size:.95rem;transition:color .2s}
.nav-link:hover{color:var(--text)}
.theme-toggle{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);color:var(--text);
  cursor:pointer;transition:border-color .2s,color .2s}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
.theme-toggle .sun{display:none}
[data-theme="light"] .theme-toggle .sun{display:block}
[data-theme="light"] .theme-toggle .moon{display:none}

/* ---------- hero ---------- */
.hero{position:relative;padding:clamp(56px,11vw,128px) 0 clamp(40px,7vw,80px);overflow:hidden}
.hero::before{ /* accent gradient-mesh glow */
  content:"";position:absolute;z-index:0;top:-30%;right:-10%;
  width:min(820px,90vw);height:min(820px,90vw);border-radius:50%;
  background:radial-gradient(circle at 50% 50%,
    color-mix(in srgb,var(--accent) 42%,transparent),transparent 62%);
  filter:blur(30px);opacity:.55;pointer-events:none;
}
.hero::after{
  content:"";position:absolute;z-index:0;bottom:-40%;left:-15%;
  width:min(620px,80vw);height:min(620px,80vw);border-radius:50%;
  background:radial-gradient(circle at 50% 50%,
    color-mix(in srgb,var(--accent-soft) 30%,transparent),transparent 64%);
  filter:blur(36px);opacity:.4;pointer-events:none;
}
.hero .wrap{position:relative;z-index:2}
.hero h1{
  font-family:var(--font-display);font-weight:800;letter-spacing:-.035em;
  font-size:clamp(2.6rem,7vw,5.2rem);line-height:.98;margin:.5em 0 .35em;max-width:14ch;
}
.hero h1 .grad{
  background:linear-gradient(105deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero .lede{font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--muted);max-width:54ch}

/* ---------- app grid (home) ---------- */
.apps{padding:clamp(30px,6vw,70px) 0 20px;position:relative;z-index:2}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:2rem}
.section-head h2{font-family:var(--font-display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em}
.section-head .count{font-family:var(--font-mono);color:var(--faint);font-size:.8rem}

.app-card{
  position:relative;display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:center;
  background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:2.4rem;margin-bottom:1.6rem;overflow:hidden;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.app-card::before{ /* accent edge glow on hover */
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(120% 80% at 85% 0%,
    color-mix(in srgb,var(--accent) 16%,transparent),transparent 60%);
  opacity:0;transition:opacity .35s;
}
.app-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:var(--shadow)}
.app-card:hover::before{opacity:1}
.app-card.featured{grid-template-columns:1fr 360px;border-color:color-mix(in srgb,var(--accent) 30%,var(--line))}
.app-card.featured::before{opacity:.6}

.app-icon{width:74px;height:74px;border-radius:18px;border:1px solid var(--line-strong);
  box-shadow:0 10px 24px -10px rgba(0,0,0,.6);margin-bottom:1.2rem;object-fit:cover}
.app-icon.svg{background:#0c0d11;padding:0}
.app-name{font-family:var(--font-display);font-weight:700;font-size:1.9rem;letter-spacing:-.025em;line-height:1.05}
.app-tagline{display:block;color:var(--accent);font-weight:600;margin:.45rem 0 .9rem}
.app-desc{color:var(--muted);font-size:1.02rem;max-width:52ch}
.ticks{list-style:none;margin:1.2rem 0 1.6rem;display:grid;gap:.55rem}
.ticks li{position:relative;padding-left:1.7rem;color:var(--muted);font-size:.96rem}
.ticks li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 10px var(--accent)}
.ticks li b{color:var(--text);font-weight:600}

.card-actions{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;margin-top:.4rem}
.text-link{font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:.35em;
  transition:gap .2s}
.text-link:hover{gap:.6em}
.text-link svg{width:16px;height:16px}

/* card visual side */
.app-visual{display:flex;align-items:center;justify-content:center;min-height:260px}
.shot{width:auto;height:380px;max-width:100%;border-radius:22px;border:1px solid var(--line-strong);
  box-shadow:0 24px 60px -28px rgba(0,0,0,.85)}
.placeholder{width:230px;aspect-ratio:9/16;border-radius:22px;border:1px solid var(--line-strong);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 20%,var(--surface)),var(--surface-2));
  color:var(--text);text-align:center;padding:1rem}

/* ---------- Day-Ring arc motif (Hourly Move) ---------- */
.dayring{position:relative;width:300px;height:300px;display:grid;place-items:center}
.dayring .ring{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 200deg,var(--accent),var(--accent-2) 120deg,transparent 200deg);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 14px),#000 calc(100% - 13px));
          mask:radial-gradient(farthest-side,transparent calc(100% - 14px),#000 calc(100% - 13px));
  filter:drop-shadow(0 0 18px color-mix(in srgb,var(--accent) 60%,transparent));
  animation:sweep 1.4s var(--ease) both}
.dayring .ring.track{background:conic-gradient(var(--line) 0 100%);filter:none;animation:none}
.dayring .core{width:64%;height:64%;border-radius:50%;background:var(--surface);
  border:1px solid var(--line);display:grid;place-items:center;text-align:center;z-index:2}
.dayring .core .next{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;color:var(--faint)}
.dayring .core .time{font-family:var(--font-display);font-weight:800;font-size:2.2rem;letter-spacing:-.02em;
  background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- store buttons (placeholder-capable) ---------- */
.store-row{display:flex;flex-wrap:wrap;gap:.7rem}
.store-btn{
  display:inline-flex;align-items:center;gap:.7rem;padding:.7rem 1.1rem;border-radius:12px;
  background:#000;color:#fff;border:1px solid rgba(255,255,255,.16);
  transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;
}
[data-theme="light"] .store-btn{background:#111}
.store-btn svg{width:24px;height:24px;flex:0 0 auto}
.store-btn .st-sub{font-size:.62rem;letter-spacing:.04em;opacity:.8;line-height:1}
.store-btn .st-main{font-size:1rem;font-weight:600;line-height:1.15}
.store-btn:not(.is-soon):hover{transform:translateY(-2px);border-color:var(--accent);
  box-shadow:0 10px 26px -12px var(--accent)}
.store-btn.is-soon{opacity:.5;cursor:not-allowed;pointer-events:none}
.store-btn.is-soon .soon{
  position:absolute;top:-9px;right:-9px;font-family:var(--font-mono);font-size:.56rem;
  letter-spacing:.12em;text-transform:uppercase;padding:.2em .55em;border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);
  pointer-events:none}

/* ---------- dedicated app page ---------- */
.app-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.app-hero .big-icon{width:104px;height:104px;border-radius:24px;border:1px solid var(--line-strong);
  box-shadow:0 16px 40px -16px rgba(0,0,0,.7);margin-bottom:1.4rem}
.app-hero h1{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;
  font-size:clamp(2.4rem,5.5vw,3.8rem);line-height:1.02;margin-bottom:.4rem}
.app-hero .sub{color:var(--accent);font-weight:600;font-size:1.15rem;margin-bottom:1rem}
.app-hero .blurb{color:var(--muted);font-size:1.08rem;max-width:48ch;margin-bottom:1.6rem}

.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;
  padding:clamp(40px,7vw,80px) 0}
.feature{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:1.6rem;transition:transform .3s var(--ease),border-color .3s}
.feature:hover{transform:translateY(-3px);border-color:var(--line-strong)}
.feature .fi{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:1rem;
  background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}
.feature .fi svg{width:22px;height:22px}
.feature h3{font-family:var(--font-display);font-weight:700;font-size:1.15rem;margin-bottom:.4rem;letter-spacing:-.01em}
.feature p{color:var(--muted);font-size:.96rem}

.gallery{display:flex;gap:1.2rem;overflow-x:auto;padding:1rem 0 1.6rem;scroll-snap-type:x mandatory}
.gallery img{height:520px;width:auto;border-radius:24px;border:1px solid var(--line-strong);
  box-shadow:0 30px 70px -34px rgba(0,0,0,.85);scroll-snap-align:center;flex:0 0 auto}

.callout{position:relative;overflow:hidden;border-radius:var(--radius);padding:clamp(2rem,5vw,3.4rem);
  border:1px solid color-mix(in srgb,var(--accent) 28%,var(--line));
  background:linear-gradient(180deg,var(--surface),var(--surface-2));text-align:center;margin:2rem 0}
.callout::before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 120% at 50% 0%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 60%)}
.callout *{position:relative}
.callout h2{font-family:var(--font-display);font-weight:800;font-size:clamp(1.6rem,4vw,2.4rem);
  letter-spacing:-.02em;margin-bottom:.6rem}
.callout p{color:var(--muted);max-width:52ch;margin:0 auto 1.2rem}

.section-title{font-family:var(--font-display);font-weight:700;font-size:1.7rem;letter-spacing:-.02em;
  margin:0 0 .4rem}
.section-intro{color:var(--muted);max-width:52ch;margin-bottom:1.4rem}

/* ---------- legal / prose ---------- */
.prose{max-width:780px;margin:0 auto;padding:clamp(40px,7vw,72px) 0}
.prose .card{background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.4rem,4vw,2.6rem)}
.prose h1{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,4vw,2.4rem);
  letter-spacing:-.025em;margin-bottom:.4rem}
.prose .meta{color:var(--faint);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;margin-bottom:1.6rem}
.prose h2{font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--text);
  margin:1.8rem 0 .6rem;display:flex;align-items:center;gap:.6rem}
.prose h2 .num{font-family:var(--font-mono);font-size:.8rem;color:var(--accent)}
.prose p{color:var(--muted);margin:.7rem 0}
.prose ul{color:var(--muted);margin:.6rem 0 .6rem 1.2rem;display:grid;gap:.4rem}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose .lead{color:var(--text);font-size:1.06rem}
.tldr{border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));border-radius:var(--radius-sm);
  padding:1rem 1.2rem;margin:1.2rem 0;background:color-mix(in srgb,var(--accent) 7%,transparent)}
.tldr b{color:var(--text)}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:4rem;padding:3rem 0 2.4rem;position:relative;z-index:2}
.footer .wrap{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center}
.footer .links{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer a{color:var(--muted);font-size:.92rem}
.footer a:hover{color:var(--accent)}
.footer .copy{color:var(--faint);font-size:.86rem}

/* ---------- load-in animation ---------- */
.reveal{opacity:0;transform:translateY(18px);animation:rise .7s var(--ease) forwards}
.reveal.d1{animation-delay:.08s}.reveal.d2{animation-delay:.16s}
.reveal.d3{animation-delay:.24s}.reveal.d4{animation-delay:.32s}.reveal.d5{animation-delay:.40s}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes sweep{from{opacity:0;transform:rotate(-26deg) scale(.94)}to{opacity:1;transform:none}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .app-card,.app-card.featured{grid-template-columns:1fr;gap:1.8rem}
  .app-visual{order:-1;min-height:auto}
  .shot{height:320px}
  .app-hero{grid-template-columns:1fr;gap:2rem}
  .app-hero .visual{order:-1;display:flex;justify-content:center}
  .gallery img{height:420px}
}
@media (max-width:520px){
  .nav-right{gap:1rem}
  .nav-link{display:none}
  .app-card{padding:1.6rem}
  .store-row{width:100%}
  .gallery img{height:360px}
}
