/* ==========================================================================
   ORBT — "anti-slop" design system  (shared override layer, loaded after styles.css)
   Ink + solar gold, but RAW and PHYSICAL: film grain, hairline edges (no glass),
   brutalist type, mono technical labels, keycap buttons, real spring motion.
   North stars: Linear / Vercel / Family.co — a dev tool that happens to be beautiful.
   Token names match styles.css so all inline JS keeps resolving.
   ========================================================================== */

:root{
  /* surfaces — flat, layered by hairlines not blur */
  --bg:        #08080b;
  --bg-1:      #0d0d11;
  --bg-2:      #131318;
  --bg-3:      #1a1a20;
  --panel:     #0d0d11;
  --line:      rgba(255,255,255,.085);
  --line-2:    rgba(255,255,255,.16);
  --line-hot:  rgba(246,196,83,.45);

  /* ink */
  --text:      #F4F3EE;
  --muted:     #97969f;
  --faint:     #5e5d67;

  /* brand — used as sharp accents + data, not glow */
  --accent:    #F6C453;
  --accent-2:  #FF9D5C;
  --accent-ink:#150f02;
  --accent-dim:rgba(246,196,83,.12);
  --ok:        #5BD6A0;
  --no:        #6a6973;

  --radius:    14px;
  --radius-sm: 9px;
  --radius-lg: 20px;

  /* type — brutalist display, mono technical layer, clean body */
  --display: "Clash Display", "Space Grotesk", system-ui, sans-serif;
  --body:    "General Sans", system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, "Space Mono", monospace;

  --maxw: 1200px;
  --pad: clamp(20px, 5vw, 56px);

  /* MOTION — real spring curves via linear() easing (not lazy cubic fades) */
  --spring: linear(0, 0.006, 0.025 2.8%, 0.101 6.1%, 0.539 18.9%, 0.721 25.3%,
                   0.849 31.5%, 0.937 38.1%, 0.968 41.8%, 0.991 45.7%, 1.006 50.1%,
                   1.015 55%, 1.017 63.9%, 1.001 79%, 0.999 87.4%, 1);
  --spring-soft: linear(0, 0.018, 0.069 4.5%, 0.276 11%, 0.638 19.5%, 0.805 24.4%,
                   0.934 29.9%, 1.012 36%, 1.04 42.4%, 1.041 49.2%, 1.02 60%, 1.004 76%, 1);
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- film grain: real raw texture, fixed over everything ---------- */
.grain{
  position: fixed; inset: 0; z-index: 9999; pointer-events: none; opacity: .045;
  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='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
@media (prefers-reduced-motion: no-preference){
  .grain{ animation: grainshift 6s steps(6) infinite; }
}
@keyframes grainshift{
  0%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)} 40%{transform:translate(3%,-4%)}
  60%{transform:translate(-3%,2%)} 80%{transform:translate(2%,4%)} 100%{transform:translate(0,0)}
}
.page-motion{ background: radial-gradient(140% 90% at 50% -20%, rgba(246,196,83,.05), transparent 60%) !important; }

body{ background: var(--bg); color: var(--text); }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family: var(--display); font-weight: 600; line-height: .96; letter-spacing: -.035em; }
.display{ font-weight: 600; letter-spacing: -.05em; line-height: .9; }
h2{ font-size: clamp(2.1rem, 5vw, 3.8rem); letter-spacing: -.045em; }
.lead{ color: var(--muted); font-size: clamp(1.02rem,1.4vw,1.18rem); line-height: 1.5; }

/* mono technical eyebrow with brackets: [ LABEL ] */
.eyebrow{
  font-family: var(--mono); font-size: .72rem; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase; color: var(--accent);
  display: inline-flex; align-items: center; gap: .5em;
}
.eyebrow::before{ content: "["; opacity: .7; width: auto; height: auto; background: none; }
.eyebrow::after{ content: "]"; opacity: .7; }

/* highlight word — solid gold (brutalist, no gradient glow) */
.hl, .display em{ font-style: normal; color: var(--accent); }

/* ---------- layout ---------- */
.wrap{ max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad); }
section{ padding-block: clamp(60px, 8vw, 120px); }

/* ======================================================================
   NAV — clean technical bar, hairline underline (no glass pill)
   ====================================================================== */
.nav{
  top: 0; left: 0; right: 0; transform: none; width: 100%;
  border-radius: 0; border: 0; border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 80%, transparent);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  padding: 14px var(--pad); display: flex; align-items: center; justify-content: space-between;
  box-shadow: none;
}
.nav.scrolled{ background: color-mix(in srgb, var(--bg) 92%, transparent); border-bottom-color: var(--line-2); }
.nav .logo{ font-family: var(--display); font-weight: 600; font-size: 1.4rem; letter-spacing: -.04em; }
.nav-links{ display: flex; gap: clamp(.8rem, 2vw, 2rem); }
.nav-links a{ font-family: var(--mono); font-size: .8rem; letter-spacing: .04em; color: var(--muted); transition: color .2s var(--ease); }
.nav-links a:hover, .nav-links a.active{ color: var(--text); }
.nav-links a.active{ color: var(--accent); }
.nav-cta{ display: flex; align-items: center; gap: .6rem; }

/* ======================================================================
   BUTTONS — physical keycaps: hard bottom edge, press down on :active (spring)
   ====================================================================== */
.btn{
  font-family: var(--mono); font-weight: 600; font-size: .82rem; letter-spacing: .02em;
  border-radius: var(--radius-sm); padding: .7rem 1.15rem;
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--accent); color: var(--accent-ink);
  border: 0; box-shadow: 0 3px 0 0 #b98a23, 0 6px 14px -6px rgba(246,196,83,.5);
  transition: transform .12s var(--ease), box-shadow .12s var(--ease), background .2s;
}
.btn:hover{ background: #ffd169; transform: translateY(-1px); box-shadow: 0 4px 0 0 #b98a23, 0 10px 22px -8px rgba(246,196,83,.6); }
.btn:active{ transform: translateY(3px); box-shadow: 0 0 0 0 #b98a23, 0 2px 8px -4px rgba(246,196,83,.5); }
.btn-lg{ padding: .95rem 1.6rem; font-size: .9rem; }
.btn-ghost, .btn.btn-ghost{
  background: transparent; color: var(--text);
  border: 1px solid var(--line-2); box-shadow: none;
}
.btn-ghost:hover{ background: rgba(255,255,255,.04); border-color: var(--text); transform: translateY(-1px); }
.btn-ghost:active{ transform: translateY(1px); }

/* ======================================================================
   HERO — type-led brutalist, live input + "Enter Orbit", no orb
   ====================================================================== */
.hero{
  min-height: auto; display: block; overflow: visible;
  padding-top: clamp(120px, 18vh, 200px); padding-bottom: clamp(50px, 8vh, 90px);
}
.hero-gl, .hero-veil, .hero-scroll{ display: none !important; }   /* retire the orb scaffolding */
.hero .wrap, .hero-inner{
  display: flex; flex-direction: column; align-items: flex-start; gap: clamp(1rem,2vw,1.4rem);
  max-width: 980px;
}
.hero-inner .display, .hero .display{
  font-size: clamp(3.2rem, 9.5vw, 7.5rem);
  text-transform: none;
}
.hero .lead{ max-width: 50ch; }

/* live claim input — big technical field with keycap submit */
.hero .claim, .claim.glass-pill{
  margin-top: .6rem; width: min(560px, 100%);
  display: flex; align-items: stretch; gap: 0;
  background: var(--bg-1); border: 1px solid var(--line-2);
  border-radius: var(--radius); padding: 6px; box-shadow: none;
  -webkit-backdrop-filter: none; backdrop-filter: none;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.hero .claim:focus-within{ border-color: var(--line-hot); box-shadow: 0 0 0 3px var(--accent-dim); }
.claim .pre{ display: flex; align-items: center; padding-left: .8rem; color: var(--faint); font-family: var(--mono); font-size: .95rem; }
.claim input{ flex: 1; min-width: 0; background: transparent; border: 0; color: var(--text); font-family: var(--mono); font-size: 1rem; padding: .7rem .4rem; }
.claim input::placeholder{ color: var(--faint); }
.claim .btn{ flex: none; }

.hero-trust{ display: flex; align-items: center; gap: .8rem; margin-top: .4rem; color: var(--muted); font-family: var(--mono); font-size: .8rem; }
.hero-trust .avatars{ display: flex; }
.hero-trust .avatars span{ width: 28px; height: 28px; border-radius: 50%; margin-left: -8px; border: 2px solid var(--bg); background: var(--bg-2) center/cover; }
.hero-trust .avatars span:first-child{ margin-left: 0; }

/* ======================================================================
   MARQUEE / CREATOR PROOF
   ====================================================================== */
.marquee{
  border-block: 1px solid var(--line); background: var(--bg-1);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee span{ color: var(--muted); font-family: var(--mono); font-size: .82rem; }
.marquee svg{ fill: var(--muted); }

/* horizontal creator bento (community) */
.comm-cols{ gap: 14px; }
.comm-card{
  border: 1px solid var(--line); border-radius: var(--radius); background: var(--bg-1);
  padding: .7rem .85rem; transition: transform .35s var(--spring), border-color .25s var(--ease);
}
.comm-card:hover{ transform: translateY(-4px); border-color: var(--line-2); }
.comm-h{ font-family: var(--mono); text-transform: uppercase; letter-spacing: .1em; font-size: .8rem; color: var(--muted); }
.comm-h svg{ fill: var(--accent); }

/* ======================================================================
   STAT / PROOF STRIP — mono data, hard rule separators
   ====================================================================== */
.proof{ border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--bg-1); padding: clamp(1.4rem,3vw,2.2rem); }
.proof-num, .stat-num{ font-family: var(--display); font-weight: 600; font-size: clamp(2rem,3.6vw,3rem); letter-spacing: -.04em; color: var(--accent); }
.proof-lbl{ font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); }
.proof-sep{ background: var(--line); }

/* ======================================================================
   BENTO CARDS — flat panels, hairline, spring lift, corner tick, hover motion demos
   ====================================================================== */
.card{
  position: relative; overflow: hidden;
  border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--bg-1);
  padding: clamp(1.4rem,2.2vw,2rem);
  transition: transform .4s var(--spring), border-color .25s var(--ease);
}
.card:hover{ transform: translateY(-5px); border-color: var(--line-2); }
/* corner registration tick — technical detail */
.card::after{
  content:""; position:absolute; top:12px; right:12px; width:9px; height:9px;
  border-top:1px solid var(--line-2); border-right:1px solid var(--line-2); opacity:.6;
}
.card.spot::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:0; transition:opacity .3s var(--ease);
  background: radial-gradient(300px circle at var(--mx,50%) var(--my,0%), rgba(246,196,83,.10), transparent 60%);
}
.card.spot:hover::before{ opacity:1; }
.card h3{ font-size: clamp(1.15rem,1.7vw,1.45rem); margin-bottom:.5rem; letter-spacing:-.02em; }
.card p{ color: var(--muted); font-size:.96rem; }
.card .ico{
  width: 44px; height: 44px; border-radius: var(--radius-sm); margin-bottom: 1.1rem;
  display: grid; place-items: center; background: var(--accent-dim); border: 1px solid var(--line-hot);
}
.card .ico svg{ width: 22px; height: 22px; stroke: var(--accent); fill: none; }

/* hover-motion demo widgets (drop into a card to physically show "subtle motion") */
.demo{ margin-top: 1.1rem; height: 54px; display:flex; align-items:center; gap:6px; }
.demo-bars span{ display:block; width:8px; height:14px; border-radius:3px; background:var(--accent); opacity:.5;
  transition: height .5s var(--spring), opacity .3s var(--ease); }
.card:hover .demo-bars span{ opacity:1; }
.card:hover .demo-bars span:nth-child(1){height:40px} .card:hover .demo-bars span:nth-child(2){height:22px}
.card:hover .demo-bars span:nth-child(3){height:52px} .card:hover .demo-bars span:nth-child(4){height:30px}
.card:hover .demo-bars span:nth-child(5){height:46px}
.demo-pulse{ width:14px; height:14px; border-radius:50%; background:var(--accent); transition:transform .5s var(--spring); }
.card:hover .demo-pulse{ transform:scale(1.4); box-shadow:0 0 0 6px var(--accent-dim); }
.demo-slide{ font-family:var(--mono); font-size:.8rem; color:var(--muted); transition:transform .5s var(--spring), color .3s; }
.card:hover .demo-slide{ transform:translateX(10px); color:var(--accent); }

/* ======================================================================
   LOOKS PHONES — physical drop-shadow, hard frame (no glass)
   ====================================================================== */
.phone{
  border-radius: 30px; background: var(--bg-2); border: 1px solid var(--line-2); padding: 8px;
  box-shadow: 0 40px 80px -30px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.03);
  transition: transform .5s var(--spring);
}

/* ======================================================================
   STEPS / HOW IT WORKS
   ====================================================================== */
.step h3{ font-size: clamp(1.1rem,1.6vw,1.4rem); }
.step p{ color: var(--muted); }
.steps-planet{ box-shadow: 0 0 0 4px var(--bg), 0 0 0 5px var(--accent); }

/* ======================================================================
   COMPARE / DATA TABLE — brutalist ledger
   ====================================================================== */
.table-wrap{ border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; background: var(--bg-1); }
.cmp{ width:100%; border-collapse: collapse; }
.cmp th, .cmp td{ padding: .95rem 1rem; text-align:center; border-bottom:1px solid var(--line); font-size:.92rem; }
.cmp th:first-child, .cmp td:first-child{ text-align:left; color:var(--text); }
.cmp thead th{ font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--faint); font-weight:500; }
.cmp thead th.hl{ color: var(--accent); }
.cmp th.hl, .cmp td.hl{ background: var(--accent-dim); color: var(--text); }
.cmp td{ color: var(--muted); font-family: var(--mono); }
.cmp .ck{ width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:2.6;margin:0 auto; }
.cmp .dash{ width:20px;height:20px;stroke:var(--no);fill:none;stroke-width:2.6;margin:0 auto; }

/* ======================================================================
   IMPORT
   ====================================================================== */
.import-box{ border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--bg-1); padding:clamp(1.3rem,2.2vw,1.9rem); }
.import-field{ background:#000; border:1px solid var(--line); border-radius:var(--radius-sm); padding:.85rem 1rem; margin:.7rem 0; font-family:var(--mono); }
.import-typed{ color: var(--text); } .import-typed::after{ content:"_"; color:var(--accent); animation:blink 1s steps(1) infinite; }
@keyframes blink{50%{opacity:0}}
.import-arrow{ color: var(--accent); text-align:center; } .import-result{ color: var(--accent); font-family:var(--mono); }

/* ======================================================================
   PRICING — flat cards, savage contrast row
   ====================================================================== */
.price{
  position: relative; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--bg-1);
  padding: clamp(1.5rem,2.3vw,2.1rem); display:flex; flex-direction:column; gap:.55rem;
  transition: transform .4s var(--spring), border-color .25s var(--ease);
}
.price:hover{ transform: translateY(-5px); border-color: var(--line-2); }
.price .tag{ font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); }
.price .amt{ font-family:var(--display); font-weight:600; font-size:clamp(2.2rem,3.4vw,3rem); letter-spacing:-.04em; }
.price .amt small{ font-size:.85rem; color:var(--muted); font-family:var(--mono); letter-spacing:0; }
.price .amt-alt{ font-family:var(--mono); font-size:.8rem; color:var(--accent); }
.price ul{ list-style:none; display:flex; flex-direction:column; gap:.6rem; margin:.6rem 0 1.2rem; }
.price li{ display:flex; gap:.6rem; align-items:flex-start; color:var(--muted); font-size:.92rem; }
.price li svg{ width:17px;height:17px;flex:none;stroke:var(--accent);fill:none;margin-top:.15rem; }
.price .btn, .price .btn-ghost{ margin-top:auto; width:100%; justify-content:center; }
.price.feat{ border-color: var(--line-hot); background: linear-gradient(180deg, var(--accent-dim), var(--bg-1) 40%); }
.price-badge{
  position:absolute; top:-11px; left:18px; font-family:var(--mono); font-size:.7rem; font-weight:600;
  letter-spacing:.06em; background:var(--accent); color:var(--accent-ink); padding:.28rem .7rem; border-radius:6px;
}
/* savage contrast strip: "Linktree $100/yr  ·  Orbt $29.99 forever" */
.savage{ border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--bg-1);
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:clamp(1rem,4vw,3rem);
  padding:clamp(1.4rem,3vw,2.4rem); margin-top:clamp(1.4rem,3vw,2rem); }
.savage .col{ display:flex; flex-direction:column; gap:.3rem; }
.savage .col.them{ text-align:right; }
.savage .lbl{ font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.12em; color:var(--faint); }
.savage .big{ font-family:var(--display); font-weight:600; font-size:clamp(1.8rem,4vw,3.2rem); letter-spacing:-.04em; }
.savage .them .big{ color:var(--muted); text-decoration:line-through; text-decoration-color:var(--no); }
.savage .us .big{ color:var(--accent); }
.savage .sub{ font-family:var(--mono); font-size:.78rem; color:var(--muted); }
.savage .vs{ font-family:var(--mono); font-size:.8rem; color:var(--faint); padding:.4rem .6rem; border:1px solid var(--line); border-radius:50%; }
@media (max-width:620px){ .savage{ grid-template-columns:1fr; gap:1.2rem; } .savage .col.them{text-align:left} .savage .vs{justify-self:start} }

/* ======================================================================
   FAQ — hard ledger rows
   ====================================================================== */
.q{ border:1px solid var(--line); border-radius:var(--radius); background:var(--bg-1); margin-bottom:10px; overflow:hidden; }
.q button{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1.1rem 1.3rem; text-align:left; font-family:var(--display); font-weight:600; font-size:1.02rem; color:var(--text); }
.q .plus{ position:relative; width:16px; height:16px; flex:none; }
.q .plus::before, .q .plus::after{ content:""; position:absolute; inset:0; margin:auto; background:var(--accent); transition:transform .35s var(--spring); }
.q .plus::before{ width:16px; height:2px; } .q .plus::after{ width:2px; height:16px; }
.q.open .plus::after{ transform:scaleY(0); }
.q .ans{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .4s var(--ease); }
.q.open .ans{ grid-template-rows:1fr; }
.q .ans-in{ overflow:hidden; } .q .ans p{ padding:0 1.3rem 1.2rem; color:var(--muted); }

/* ======================================================================
   CTA BAND
   ====================================================================== */
.cta-band{ border-top:1px solid var(--line); text-align:center; }
.cta-band .wrap{ display:flex; flex-direction:column; align-items:center; gap:1rem; }
.cta-band h2{ font-size:clamp(2.4rem,6vw,4.5rem); }
.cta-field{ display:none; }
.cta-band .claim{ margin-inline:auto; }

/* ======================================================================
   FOOTER — logo crest, no giant wordmark
   ====================================================================== */
footer{ border-top:1px solid var(--line); background:var(--bg-1); padding-block: clamp(2.8rem,5vw,4.5rem) 2rem; }
footer .logo{ font-family:var(--display); font-weight:600; font-size:1.4rem; }
.foot-blurb{ color:var(--muted); max-width:32ch; margin:.7rem 0 1.1rem; font-size:.92rem; }
.foot-social a{ width:36px;height:36px;border-radius:8px;display:grid;place-items:center;border:1px solid var(--line);margin-right:.45rem;transition:border-color .2s var(--ease),transform .3s var(--spring); }
.foot-social a:hover{ border-color:var(--line-2); transform:translateY(-2px); }
.foot-social svg{ width:16px;height:16px;fill:var(--muted); } .foot-social a:hover svg{ fill:var(--accent); }
footer h5{ font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; color:var(--text); margin-bottom:.9rem; }
.foot-grid a{ display:block; color:var(--muted); padding:.28rem 0; font-size:.92rem; transition:color .2s var(--ease); }
.foot-grid a:hover{ color:var(--text); }
.foot-bottom{ border-top:1px solid var(--line); margin-top:2.2rem; padding-top:1.4rem; color:var(--faint); font-family:var(--mono); font-size:.78rem; }

/* ======================================================================
   PAGE HEAD (pricing/about/etc.) + misc
   ====================================================================== */
.page-head{ padding-top:clamp(120px,16vh,180px); }
.page-head .hero-glow{ display:none; }
.page-head .display{ font-size:clamp(2.8rem,7vw,5.5rem); }
.head-facts{ display:flex; flex-wrap:wrap; justify-content:center; gap:1rem; margin-top:1.4rem; font-family:var(--mono); font-size:.82rem; color:var(--muted); }
.head-facts b{ color:var(--accent); }
.head-facts .sep{ width:1px; height:1em; background:var(--line-2); }
.orbt-divider span{ background:linear-gradient(90deg,transparent,var(--line-2),transparent); }
.mobile-menu{ background:var(--bg); border-bottom:1px solid var(--line); }
.mobile-menu a{ font-family:var(--mono); }
::selection{ background:var(--accent); color:var(--accent-ink); }

/* swatches (used by dashboard + any picker): high-contrast active ring */
.swatch.active, .color-dot.active, [data-swatch].active{
  box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px var(--accent) !important;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; }
  .card:hover,.price:hover,.comm-card:hover,.phone{ transform:none; }
}

/* ======================================================================
   RESPONSIVE
   ====================================================================== */
@media (max-width: 860px){ .nav-links{ display:none; } }
@media (max-width: 560px){
  .hero .claim{ flex-wrap:wrap; } .claim .pre{ padding:.4rem .8rem; }
  .savage{ text-align:left; }
}

/* ======================================================================
   OAUTH — social sign-in buttons (login / signup / welcome)
   ====================================================================== */
.oauth-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.oauth-btn{
  display:flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.72rem .8rem; border:1px solid var(--line-2); border-radius:var(--radius-sm);
  background:var(--bg-2); color:var(--text);
  font-family:var(--mono); font-size:.82rem; font-weight:500; cursor:pointer;
  transition:transform .12s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
}
.oauth-btn:hover{ border-color:var(--text); background:rgba(255,255,255,.05); transform:translateY(-1px); }
.oauth-btn:active{ transform:translateY(1px); }
.oauth-btn:disabled{ opacity:.5; cursor:default; transform:none; }
.oauth-btn svg{ width:18px; height:18px; flex:none; display:block; }
.oauth-btn.loading{ color:transparent; position:relative; }
.oauth-btn.loading > *{ visibility:hidden; }
.oauth-btn.loading::after{
  content:""; position:absolute; width:15px; height:15px; border-radius:50%;
  border:2px solid var(--line-2); border-top-color:var(--accent); animation:oauthspin .7s linear infinite;
}
@keyframes oauthspin{ to{ transform:rotate(360deg); } }
.oauth-divider{
  display:flex; align-items:center; gap:.8rem; margin:1.15rem 0;
  color:var(--faint); font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
}
.oauth-divider::before, .oauth-divider::after{ content:""; flex:1; height:1px; background:var(--line); }
@media (max-width:380px){ .oauth-grid{ grid-template-columns:1fr; } }
