/* Warmly - bold & warm.  Light = "Warm Ember" (B) · Dark = "Ink Editorial" (C).
   Same components, two skins, toggled via [data-theme="dark"]. */
:root{
  --bg:#FBF8F3; --bg-2:#F2EDE5; --card:#FFFFFF;
  --ink:#2B2622; --ink-soft:#6F675F; --ink-faint:#6F675F;
  --line:#E7DFD4;
  --green:#946145; --green-2:#5E7264; --gold:#5E7264; --gold-soft:#5E7264; --rose:#946145;
  --accent:#946145; --on-accent:#FBF8F3; --hero:#F0E6DA; --hero-ink:#3A332D;
  --r:20px; --shadow:0 1px 2px rgba(40,30,20,.05),0 12px 30px rgba(40,30,20,.09);
  --serif:'Space Grotesk',system-ui,sans-serif;
  --sans:'Space Grotesk',system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',monospace;
}
[data-theme="dark"]{
  --bg:#14100C; --bg-2:#1E1812; --card:#1B150F;
  --ink:#F2E6D2; --ink-soft:#B7A892; --ink-faint:#B7A892;
  --line:#322820;
  --green:#F5A623; --green-2:#E8806B; --gold:#E8806B; --gold-soft:#E8806B; --rose:#F5A623;
  --accent:#F5A623; --on-accent:#2A1B07; --hero:#2A1B0C; --hero-ink:#FBEBCB;
  --r:22px; --shadow:0 1px 2px rgba(0,0,0,.35),0 16px 40px rgba(0,0,0,.55);
}
/* ===== D · Brutalist Mono skin (toggled via [data-theme="brutal"]) ===== */
:root.skin-hearthstone{
  --bg:#E6E0D7; --bg-2:#DED7CC; --card:#EDE7DE;
  --ink:#352F28; --ink-soft:#675D50; --ink-faint:#675D50;
  --line:#CFC6B8;
  --green:#9A623B; --green-2:#5F7355; --gold:#5F7355; --gold-soft:#5F7355; --rose:#9A623B;
  --accent:#9A623B; --on-accent:#FBF4EA; --hero:#E0D8CC; --hero-ink:#352F28;
  --r:26px; --shadow:0 1px 2px rgba(40,30,20,.05),0 12px 30px rgba(40,30,20,.09);
}
:root.skin-letterpress{
  --bg:#F4EDE0; --bg-2:#EBE2D2; --card:#FBF7EF;
  --ink:#2E2620; --ink-soft:#6B5D4D; --ink-faint:#6B5D4D;
  --line:#DAD0BF;
  --green:#9B3A2E; --green-2:#B5732A; --gold:#B5732A; --gold-soft:#B5732A; --rose:#9B3A2E;
  --accent:#9B3A2E; --on-accent:#FBF7EF; --hero:#3C4A3A; --hero-ink:#F6ECDA;
  --r:14px; --shadow:0 1px 2px rgba(40,30,20,.05),0 12px 30px rgba(40,30,20,.09);
}
:root.skin-pressedgarden{
  --bg:#EDE7DA; --bg-2:#E2DBC9; --card:#F6F1E7;
  --ink:#2E3A2C; --ink-soft:#5E6B55; --ink-faint:#5E6B55;
  --line:#D2C9B3;
  --green:#5B7355; --green-2:#C0714B; --gold:#C0714B; --gold-soft:#C0714B; --rose:#5B7355;
  --accent:#5B7355; --on-accent:#F7F4EB; --hero:#3D5440; --hero-ink:#F2EEDF;
  --r:20px; --shadow:0 1px 2px rgba(40,30,20,.05),0 12px 30px rgba(40,30,20,.09);
}
[data-theme="dark"].skin-hearthglow{
  --bg:#1A120E; --bg-2:#2E201A; --card:#241814;
  --ink:#F6E7D6; --ink-soft:#C9A98F; --ink-faint:#C9A98F;
  --line:#3D2A20;
  --green:#FF8A3D; --green-2:#FFC061; --gold:#FFC061; --gold-soft:#FFC061; --rose:#FF8A3D;
  --accent:#FF8A3D; --on-accent:#2A1206; --hero:#3A1A0C; --hero-ink:#FFF1E2;
  --r:22px; --shadow:0 1px 2px rgba(0,0,0,.35),0 16px 40px rgba(0,0,0,.55);
}
[data-theme="dark"].skin-candlelit{
  --bg:#1C1422; --bg-2:#251A2E; --card:#2A1E34;
  --ink:#EFE2D2; --ink-soft:#B9A0B4; --ink-faint:#B9A0B4;
  --line:rgba(239,226,210,0.12);
  --green:#F2A65A; --green-2:#FF8FA3; --gold:#FF8FA3; --gold-soft:#FF8FA3; --rose:#F2A65A;
  --accent:#F2A65A; --on-accent:#2A1206; --hero:#F0A24E; --hero-ink:#3A1F0C;
  --r:22px; --shadow:0 1px 2px rgba(0,0,0,.35),0 16px 40px rgba(0,0,0,.55);
}
[data-theme="brutal"] .card{ border-width:2px; }
[data-theme="brutal"] .hero{ background:var(--accent); border:2px solid #111; box-shadow:5px 5px 0 #111; }
[data-theme="brutal"] .hero .btn.primary{ background:#fff; color:#111; border:2px solid #111; box-shadow:2px 2px 0 #111; }
[data-theme="brutal"] .hero .btn.ghost{ color:#fff; border-color:#fff; }
[data-theme="brutal"] .btn{ border:2px solid #111; box-shadow:2px 2px 0 #111; border-radius:9px; }
[data-theme="brutal"] .btn:hover{ transform:translate(-1px,-1px); box-shadow:3px 3px 0 #111; }
[data-theme="brutal"] .btn.primary{ background:var(--accent); color:#fff; }
[data-theme="brutal"] .tile{ border-width:2px; box-shadow:4px 4px 0 #111; }
[data-theme="brutal"] input,[data-theme="brutal"] select,[data-theme="brutal"] textarea{ border:2px solid #111; border-radius:8px; }
[data-theme="brutal"] .pill{ border:1.5px solid #111; border-radius:6px; }
[data-theme="brutal"] .chip{ border:1.5px solid #111; }
[data-theme="brutal"] .chip.on{ background:var(--accent); color:#fff; }
[data-theme="brutal"] .seg{ border:2px solid #111; border-radius:9px; background:#fff; }
[data-theme="brutal"] .seg button.on{ background:var(--accent); color:#fff; border-radius:6px; }
[data-theme="brutal"] .sortsel{ border:2px solid #111; border-radius:8px; }
[data-theme="brutal"] .tabs a.active{ background:var(--accent); color:#fff; }
[data-theme="brutal"] .topbar{ border-bottom:2px solid #111; background:var(--bg); }
[data-theme="brutal"] .icon-btn{ border:2px solid #111; box-shadow:2px 2px 0 #111; font-weight:700; }
[data-theme="brutal"] h1.title,[data-theme="brutal"] .brand,[data-theme="brutal"] .nm,[data-theme="brutal"] .who{ font-weight:700; }
[data-theme="brutal"] .fab{ border:2px solid #111; box-shadow:4px 4px 0 #111; }
[data-theme="brutal"] .review-badge{ border:1.5px solid #111; }
[data-theme="brutal"] .prog .bar{ border:1.5px solid #111; background:#fff; }
[data-theme="brutal"] .prog .bar span{ background:var(--accent); }
[data-theme="brutal"] .voicebar{ border:2px solid #111; box-shadow:3px 3px 0 #111; }
*{ margin:0; padding:0; box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{ background:var(--bg); color:var(--ink); font-family:var(--sans); font-size:16px; line-height:1.5; -webkit-font-smoothing:antialiased; padding-bottom:50px; overflow-x:hidden; }
a{ color:inherit; text-decoration:none; cursor:pointer; }
.wrap{ max-width:1180px; margin:0 auto; padding:0 20px; }
.serif{ font-family:var(--serif); }
.mono{ font-family:var(--mono); }

/* topbar */
.topbar{ position:sticky; top:0; z-index:30; background:color-mix(in srgb,var(--bg) 86%,transparent); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.topbar .wrap{ display:flex; align-items:center; gap:14px; height:60px; }
.brand{ display:inline-flex; flex-direction:column; line-height:1; justify-content:center; }
.brand .brandname{ font-family:var(--serif); font-weight:700; font-size:23px; letter-spacing:-.02em; }
.brand .dot{ color:#E0552E; }
.brand .ver{ font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.06em; color:var(--ink-faint); margin-top:3px; text-transform:none; }
.brand .ver:empty{ display:none; }
.tabs{ display:flex; gap:2px; margin-left:6px; flex:1; }
.tabs a{ font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.02em; color:var(--ink-soft); padding:8px 13px; border-radius:30px; white-space:nowrap; text-transform:lowercase; }
.tabs a:hover{ background:var(--card); color:var(--ink); }
.tabs a.active{ background:var(--green); color:var(--on-accent); }
.icon-btn{ width:38px; height:38px; border-radius:11px; border:1px solid var(--line); background:var(--card); color:var(--ink); cursor:pointer; font-size:15px; flex-shrink:0; }
.icon-btn.menu{ display:none; }

/* views */
.view{ padding:24px 0 40px; }
h1.title{ font-family:var(--serif); font-weight:600; font-size:31px; letter-spacing:-.025em; }
.muted{ color:var(--ink-soft); font-size:14.5px; margin-top:4px; }
.kick{ font-family:var(--mono); font-size:11px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--green-2); margin:28px 0 10px; }

/* cards */
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow); padding:16px 18px; margin-bottom:10px; }
.row{ display:flex; align-items:center; gap:14px; }
.between{ justify-content:space-between; }
.grow{ flex:1; min-width:0; }
.avatar{ width:46px; height:46px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:600; font-size:18px; color:#fff; }
.nm{ font-family:var(--serif); font-weight:600; font-size:16.5px; letter-spacing:-.01em; overflow-wrap:anywhere; }
.sub{ font-family:var(--mono); font-size:11.5px; color:var(--ink-soft); margin-top:2px; letter-spacing:.01em; overflow-wrap:anywhere; }
.pill{ font-family:var(--mono); font-size:10px; font-weight:500; letter-spacing:.05em; text-transform:uppercase; padding:4px 9px; border-radius:20px; white-space:nowrap; }
.pill.bday{ background:color-mix(in srgb,var(--gold-soft) 28%,transparent); color:var(--gold); }
.pill.anniv{ background:color-mix(in srgb,var(--rose) 22%,transparent); color:var(--rose); }
.pill.warm{ background:color-mix(in srgb,var(--green-2) 18%,transparent); color:var(--green-2); }
.pill.t1{ background:color-mix(in srgb,var(--green-2) 16%,transparent); color:var(--green-2); }
.pill.t2{ background:color-mix(in srgb,var(--gold-soft) 26%,transparent); color:var(--gold); }
.pill.t3{ background:var(--bg); color:var(--ink-faint); border:1px solid var(--line); }

/* hero - bold colour-block (used for the headline item) */
.hero{ position:relative; overflow:hidden; background:var(--hero); color:var(--hero-ink); border-radius:var(--r); padding:18px 18px 16px; margin-bottom:12px; }
.hero .nm{ color:var(--hero-ink); font-size:21px; }
.hero .sub{ color:var(--hero-ink); opacity:.85; }
.hero .blob{ position:absolute; right:-24px; top:-24px; width:118px; height:118px; opacity:.9; animation:float 7s ease-in-out infinite; }
.circ{ position:relative; display:inline-block; padding:0 2px; }
.circ svg{ position:absolute; inset:-6px -6px; width:calc(100% + 12px); height:calc(100% + 12px); overflow:visible; }
.circ path{ fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-dasharray:180; stroke-dashoffset:180; animation:draw 1s ease forwards .4s; }
.ico{ flex-shrink:0; }

/* buttons */
.btn{ display:inline-flex; align-items:center; gap:7px; font-family:var(--sans); font-size:14px; font-weight:600; padding:11px 17px; border-radius:13px; border:none; cursor:pointer; transition:transform .12s,filter .12s; }
.btn:hover{ transform:translateY(-1px); filter:brightness(1.03); }
.btn.primary{ background:var(--green); color:var(--on-accent); }
.btn.gold{ background:var(--gold-soft); color:#3a2a05; }
.btn.wa{ background:#25D366; color:#053; }
.btn.ghost{ background:var(--card); color:var(--ink); border:1px solid var(--line); }
.btn.sm{ padding:8px 13px; font-size:13px; border-radius:10px; }
.btn.block{ width:100%; justify-content:center; }
/* "Fresh idea" reroll: a warm, popping accent with premium tactile depth. */
.btn.fresh{ background:linear-gradient(135deg,#FF8A3D 0%,#E05530 100%); color:#fff; font-weight:700; border:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45), 0 2px 6px rgba(224,85,48,.38), 0 7px 18px rgba(224,85,48,.24);
  text-shadow:0 1px 1px rgba(120,40,10,.28); }
.btn.fresh:hover{ transform:translateY(-1px); filter:brightness(1.05) saturate(1.06); }
[data-theme="brutal"] .btn.fresh{ background:var(--gold-soft); color:#111; border:2px solid #111; box-shadow:2px 2px 0 #111; text-shadow:none; }
[data-theme="brutal"] .btn.fresh:hover{ transform:translate(-1px,-1px); box-shadow:3px 3px 0 #111; }
.btn-row{ display:flex; gap:8px; flex-wrap:wrap; }

/* forms */
label.fl{ display:block; font-family:var(--mono); font-size:11.5px; font-weight:500; letter-spacing:.03em; color:var(--ink-soft); margin:12px 0 5px; text-transform:uppercase; }
input,select,textarea{ width:100%; font-family:var(--sans); font-size:15px; color:var(--ink); background:var(--bg-2); border:1px solid var(--line); border-radius:11px; padding:11px 13px; }
input:focus,select,textarea:focus{ outline:none; border-color:var(--green-2); }
textarea{ resize:vertical; min-height:90px; line-height:1.5; }
.two{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.three{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }

/* search */
.search{ position:relative; margin:14px 0; }
.search input{ padding-left:38px; }
.search svg{ position:absolute; left:12px; top:13px; width:16px; height:16px; color:var(--ink-faint); }
.chips{ display:flex; gap:7px; flex-wrap:wrap; margin:10px 0; }
.chip{ font-family:var(--mono); font-size:12px; font-weight:500; padding:7px 14px; border-radius:30px; border:1px solid var(--line); background:var(--card); color:var(--ink-soft); cursor:pointer; }
.chip.on{ background:var(--green); color:var(--on-accent); border-color:var(--green); }

.empty{ text-align:center; color:var(--ink-soft); padding:48px 16px; font-size:14.5px; line-height:1.7; }
.empty .big{ font-family:var(--serif); font-weight:600; font-size:21px; color:var(--ink); margin-bottom:8px; }

/* import preview table */
.tbl{ width:100%; border-collapse:collapse; font-size:13.5px; margin-top:12px; }
.tbl th{ text-align:left; font-family:var(--mono); font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-faint); padding:8px 10px; border-bottom:1px solid var(--line); }
.tbl td{ padding:9px 10px; border-bottom:1px solid var(--line); vertical-align:middle; }
.tbl select{ padding:5px 7px; font-size:12.5px; border-radius:7px; }
.tbl input[type=checkbox]{ width:18px; height:18px; }

/* modal */
.modal-bg{ position:fixed; inset:0; background:rgba(15,14,9,.5); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); display:none; align-items:flex-end; justify-content:center; z-index:60; }
.modal-bg.show{ display:flex; }
.modal{ background:var(--bg-2); width:100%; max-width:560px; border-radius:22px 22px 0 0; padding:22px; max-height:88vh; overflow-y:auto; box-shadow:0 -10px 40px rgba(0,0,0,.3); }
@media(min-width:640px){ .modal-bg{ align-items:center; } .modal{ border-radius:22px; } }
.modal h3{ font-family:var(--serif); font-weight:600; font-size:21px; }
.modal .x{ float:right; border:none; background:none; font-size:22px; color:var(--ink-soft); cursor:pointer; }
.note{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); background:var(--bg); border:1px solid var(--line); border-radius:11px; padding:10px 12px; margin:10px 0; line-height:1.55; }

.foot{ font-family:var(--mono); font-size:11.5px; color:var(--ink-faint); text-align:center; padding:24px 18px 8px; letter-spacing:.01em; }

@keyframes float{ 0%,100%{ transform:translateY(0) rotate(0); } 50%{ transform:translateY(8px) rotate(7deg); } }
@keyframes draw{ to{ stroke-dashoffset:0; } }
@media (prefers-reduced-motion:reduce){ .hero .blob{ animation:none; } .circ path{ stroke-dashoffset:0; animation:none; } .floaty{ animation:none; } }

/* hero buttons (on the bold colour-block) */
.hero .btn.primary{ background:var(--hero-ink); color:var(--accent); }
.hero .btn.ghost{ background:transparent; color:var(--hero-ink); border-color:color-mix(in srgb,var(--hero-ink) 45%,transparent); }

/* progress bar + floating icon */
.prog .pstat{ font-family:var(--mono); font-size:13px; color:var(--ink-soft); margin-top:3px; }
.prog .bar{ height:10px; background:color-mix(in srgb,var(--ink) 8%,transparent); border-radius:20px; margin-top:12px; overflow:hidden; }
.prog .bar span{ display:block; height:100%; min-width:8px; background:linear-gradient(90deg,var(--green-2),var(--green)); border-radius:20px; transition:width .7s ease; }
.floaty{ display:inline-flex; animation:float 7s ease-in-out infinite; }

/* world map */
.map-wrap{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:12px; margin:10px 0 4px; box-shadow:var(--shadow); }
.world{ width:100%; height:auto; display:block; }
.map-land{ fill:color-mix(in srgb,var(--ink) 10%,transparent); }
.map-dot{ fill:var(--green); opacity:.9; }
.map-dot.big{ fill:var(--accent); }
.geo-row{ display:flex; align-items:center; gap:11px; padding:10px 4px; border-bottom:1px solid var(--line); font-size:14.5px; }
.geo-row:last-child{ border-bottom:none; }
.geo-row .ct{ margin-left:auto; font-family:var(--mono); font-size:12px; color:var(--ink-soft); }
.geo-dot{ width:11px; height:11px; border-radius:50%; background:var(--green); flex-shrink:0; }

/* layout density on bigger screens */
.grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:10px; align-items:start; }
.today-top{ display:grid; gap:10px; }
@media(min-width:820px){ .today-top{ grid-template-columns:1.7fr 1.3fr; align-items:start; } }
.today-top .hero, .today-top .prog{ margin-bottom:0; }
.seg{ display:inline-flex; background:color-mix(in srgb,var(--ink) 7%,transparent); border-radius:30px; padding:3px; }
.seg button{ font-family:var(--mono); font-size:12px; text-transform:lowercase; letter-spacing:.04em; color:var(--ink-soft); background:none; border:none; padding:6px 14px; border-radius:30px; cursor:pointer; }
.seg button.on{ background:var(--green); color:var(--on-accent); }
.tile{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow); padding:16px; cursor:pointer; display:flex; flex-direction:column; transition:transform .12s; }
.tile:hover{ transform:translateY(-2px); }
.tile .avatar{ margin-bottom:10px; }
.gsec{ display:flex; align-items:center; gap:10px; font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--green-2); margin:22px 2px 10px; }
.gsec .ct{ color:var(--ink-faint); }
.sortsel{ width:auto; font-family:var(--mono); font-size:12px; color:var(--ink-soft); background:var(--card); border:1px solid var(--line); border-radius:30px; padding:7px 12px; }
.ctx{ background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:10px 12px; margin:10px 0; }
.ctx .sub{ margin:2px 0; }
.kebab{ background:none; border:none; color:var(--ink-faint); cursor:pointer; padding:6px; line-height:0; flex-shrink:0; border-radius:8px; }
.kebab:hover{ background:color-mix(in srgb,var(--ink) 7%,transparent); color:var(--ink); }
.kebab svg{ fill:currentColor; }
.tile{ position:relative; }
.tile .kebab{ position:absolute; top:8px; right:6px; }

/* floating + button (type / speak / scan) */
.fab-wrap{ position:fixed; right:18px; bottom:20px; z-index:50; display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
.fab{ width:60px; height:60px; border-radius:50%; border:none; background:#FF5A36; color:#fff; font-size:34px; line-height:58px; text-align:center; cursor:pointer; box-shadow:0 10px 26px rgba(255,90,54,.5); transition:transform .25s; }
.fab:active{ transform:scale(.9); }
.fab.open{ transform:rotate(45deg); }
.fab-menu{ display:none; flex-direction:column; align-items:flex-end; gap:10px; }
.fab-menu.open{ display:flex; }
.fab-opt{ background:var(--card); color:var(--ink); border:1px solid var(--line); border-radius:30px; padding:11px 18px; font-family:var(--sans); font-weight:600; font-size:14px; cursor:pointer; box-shadow:var(--shadow); white-space:nowrap; animation:fabin .18s ease both; }
@keyframes fabin{ from{ opacity:0; transform:translateY(10px) scale(.96); } to{ opacity:1; transform:none; } }
.review-badge{ font-family:var(--mono); font-size:10px; font-weight:500; text-transform:uppercase; letter-spacing:.05em; color:#fff; background:#FF5A36; padding:3px 8px; border-radius:20px; white-space:nowrap; }
.card-img{ max-width:100%; border-radius:12px; margin-bottom:12px; display:block; }

/* per-contact social deep-link icons (only shown for channels a contact has) */
.socrow{ display:flex; gap:9px; flex-wrap:wrap; margin:12px 0 2px; }
.soc{ width:44px; height:44px; border-radius:14px; display:inline-flex; align-items:center; justify-content:center; background:#fff; color:var(--ink-soft); cursor:pointer; transition:transform .14s ease, box-shadow .14s ease; box-shadow:0 4px 12px rgba(36,28,20,.11), inset 0 0 0 1px rgba(36,28,20,.05); }
.soc:hover{ transform:translateY(-2px); box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 12px 24px rgba(36,28,20,.14); }
.soc:active{ transform:translateY(0) scale(.96); }
.soc svg{ width:22px; height:22px; fill:currentColor; }
[data-theme="dark"] .soc{ background:#FBFAF8; box-shadow:0 5px 14px rgba(0,0,0,.5), inset 0 0 0 1px rgba(0,0,0,.10); }
[data-theme="brutal"] .soc{ background:var(--card); box-shadow:2px 2px 0 #111; border:1.5px solid #111; }
[data-theme="brutal"] .soc svg{ filter:none; }
.soc-wa{ color:#25D366 } .soc-call{ color:var(--green-2) } .soc-mail{ color:#EA4335 } .soc-in{ color:#0A66C2 } .soc-ig{ color:#E1306C } .soc-x{ color:var(--ink) } .soc-tg{ color:#229ED9 } .soc-web{ color:var(--ink-soft) }
.socadd{ color:var(--ink-faint); font-size:21px; font-weight:600; background:transparent; border:1.5px dashed var(--line); box-shadow:none; }

/* ===== Reach hub — premium tactile channel bar (the hero of a contact) ===== */
.reach-label{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--green-2); margin:18px 2px 11px; }
[data-theme="dark"] .reach-label{ color:var(--green); }
.reach{ display:grid; grid-template-columns:repeat(4,1fr); gap:11px; margin-bottom:6px; }
/* Authentic app logos on soft-edge light tiles (Contacts-app style). The official brand silhouettes
   render in their TRUE colour on a light tile, so negative space (e.g. the WhatsApp handset) reads
   correctly. call/text/mail are clean system glyphs tinted to recognisable action colours. */
.reach .act{ -webkit-appearance:none; appearance:none; display:flex; flex-direction:column; align-items:center; gap:10px; padding:6px 4px 4px; border-radius:16px; cursor:pointer; color:var(--ink); font-family:inherit; text-align:center;
  background:none; border:0; transition:transform .15s ease; }
.reach .act:hover{ transform:translateY(-3px); }
.reach .act:active{ transform:translateY(0) scale(.95); }
.reach .act .ic{ width:56px; height:56px; border-radius:17px; display:flex; align-items:center; justify-content:center;
  background:#fff; box-shadow:0 5px 14px rgba(36,28,20,.13), inset 0 0 0 1px rgba(36,28,20,.05); transition:box-shadow .15s ease; }
.reach .act:hover .ic{ box-shadow:0 11px 24px rgba(36,28,20,.20), inset 0 0 0 1px rgba(36,28,20,.05); }
.reach .act .ic svg{ width:30px; height:30px; fill:currentColor; }
.reach .act .lb{ font-family:var(--mono); font-size:11px; font-weight:500; letter-spacing:.01em; color:var(--ink-soft); }
.reach .act.call .ic{ color:#1FA463; }
.reach .act.text .ic{ color:#E0552E; }
.reach .act.wa   .ic{ color:#25D366; }
.reach .act.mail .ic{ color:#C9A227; }
.reach .act.off .ic{ color:var(--ink-faint); box-shadow:inset 0 0 0 1px rgba(36,28,20,.07); }
.reach .act.off .lb{ color:var(--ink-faint); }
[data-theme="dark"] .reach .act .ic{ background:#FBFAF8; box-shadow:0 6px 16px rgba(0,0,0,.5), inset 0 0 0 1px rgba(0,0,0,.10); }
[data-theme="dark"] .reach .act:hover .ic{ box-shadow:0 12px 26px rgba(0,0,0,.6), inset 0 0 0 1px rgba(0,0,0,.10); }
[data-theme="dark"] .reach .act.off .ic{ background:#241f29; color:#6f6675; box-shadow:inset 0 0 0 1px rgba(255,255,255,.07); }
[data-theme="brutal"] .reach .act{ border:2px solid #111; border-radius:12px; background:var(--card); box-shadow:4px 4px 0 #111; }
[data-theme="brutal"] .reach .act:hover{ transform:translate(-1px,-1px); box-shadow:5px 5px 0 #111; }
[data-theme="brutal"] .reach .act:active{ transform:translate(1px,1px); box-shadow:2px 2px 0 #111; }
[data-theme="brutal"] .reach .act .ic{ border:2px solid #111; border-radius:10px; box-shadow:none; }
[data-theme="brutal"] .reach .act .ic svg{ filter:none; }

/* ===== Capture hub rows (premium tactile) ===== */
.cap{ -webkit-appearance:none; appearance:none; width:100%; text-align:left; display:flex; align-items:center; gap:14px; padding:15px; margin-top:11px; border-radius:16px; cursor:pointer; color:var(--ink); font-family:inherit;
  background:linear-gradient(180deg, color-mix(in srgb,var(--card) 86%,#fff 14%), var(--card));
  border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 1px 2px rgba(36,28,20,.05), 0 9px 20px rgba(36,28,20,.08);
  transition:transform .14s ease, box-shadow .14s ease; }
.cap:hover{ transform:translateY(-2px); box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 16px 30px rgba(36,28,20,.14); }
.cap:active{ transform:translateY(0) scale(.99); }
.cap .capic{ width:44px; height:44px; flex-shrink:0; border-radius:13px; display:flex; align-items:center; justify-content:center; color:var(--green-2);
  background:radial-gradient(120% 120% at 30% 22%, color-mix(in srgb,var(--green-2) 20%,var(--card)), color-mix(in srgb,var(--green-2) 7%,var(--card)));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5), 0 3px 8px rgba(36,28,20,.10); }
.cap .capic svg{ width:23px; height:23px; }
.cap .capt{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.cap .capt .ti{ font-family:var(--serif); font-weight:700; font-size:15.5px; }
.cap .capt .ds{ font-family:var(--mono); font-size:11.5px; color:var(--ink-soft); line-height:1.45; }
.cap.hero{ background:linear-gradient(160deg, color-mix(in srgb,var(--green-2) 88%,#fff 12%), var(--green-2)); border:none; color:var(--hero-ink); box-shadow:inset 0 1px 0 rgba(255,255,255,.14), 0 12px 26px rgba(20,70,58,.4); }
.cap.hero .capt .ds{ color:var(--hero-ink); opacity:.82; }
.cap.hero .capic{ background:rgba(255,255,255,.16); color:var(--hero-ink); box-shadow:inset 0 1px 0 rgba(255,255,255,.25); }
.cap.dim{ opacity:.82; }
[data-theme="dark"] .cap{ background:linear-gradient(180deg, color-mix(in srgb,var(--card) 90%,#fff 10%), var(--card)); box-shadow:inset 0 1px 0 rgba(255,255,255,.07), 0 10px 24px rgba(0,0,0,.45); }
[data-theme="dark"] .cap.hero{ color:#14151B; }
[data-theme="dark"] .cap.hero .capt .ds{ color:#14151B; }
[data-theme="dark"] .cap.hero .capic{ color:#14151B; }
[data-theme="brutal"] .cap{ border:2px solid #111; border-radius:12px; box-shadow:4px 4px 0 #111; background:var(--card); }
[data-theme="brutal"] .cap.hero{ background:var(--accent); color:#fff; border:2px solid #111; box-shadow:4px 4px 0 #111; }
[data-theme="brutal"] .cap.hero .capt .ds{ color:#fff; opacity:.9; }
[data-theme="brutal"] .cap .capic{ border:2px solid #111; border-radius:9px; background:var(--card); box-shadow:none; }
[data-theme="brutal"] .cap.hero .capic{ background:#fff; }

/* ===== quick-add detected chips ===== */
.qa-chips{ display:flex; flex-wrap:wrap; gap:7px; margin:11px 0 4px; }
.qchip{ font-family:var(--mono); font-size:11px; padding:6px 10px; border-radius:30px; border:1px dashed var(--ink-faint); color:var(--ink-faint); background:transparent; transition:.2s; }
.qchip.on{ border-style:solid; border-color:var(--green-2); color:var(--green-2); background:color-mix(in srgb,var(--green-2) 12%,transparent); box-shadow:inset 0 1px 0 rgba(255,255,255,.4); }
[data-theme="dark"] .qchip.on{ border-color:var(--green); color:var(--green); background:color-mix(in srgb,var(--green) 15%,transparent); }
[data-theme="brutal"] .qchip{ border-radius:6px; }
[data-theme="brutal"] .qchip.on{ border:1.5px solid #111; background:var(--accent); color:#fff; }
.qa-found{ flex-basis:100%; font-family:var(--mono); font-size:11px; color:var(--ink-soft); margin-top:3px; }

/* ===== App lock screen (premium tactile keypad) ===== */
.lockscreen{ position:fixed; inset:0; z-index:9999; display:none; background:var(--bg); align-items:stretch; justify-content:center; }
.lockscreen.unlocked{ opacity:0; transform:scale(1.03); transition:opacity .46s ease, transform .46s ease; }
.lk-inner{ width:100%; max-width:420px; display:flex; flex-direction:column; align-items:center; padding:62px 32px calc(34px + env(safe-area-inset-bottom)); }
.lk-brand{ font-family:var(--serif); font-weight:700; font-size:24px; letter-spacing:-.02em; }
.lk-brand .dot{ color:#E0552E; }
.lk-icon{ margin:30px 0 14px; color:var(--ink); }
.lk-icon svg{ width:34px; height:34px; }
.lk-msg{ font-family:var(--mono); font-size:13px; color:var(--ink-soft); min-height:18px; text-align:center; letter-spacing:.01em; }
.lk-msg.err{ color:var(--rose); }
.lk-dots{ display:flex; gap:16px; margin:22px 0 2px; }
.lk-dots i{ width:14px; height:14px; border-radius:50%; border:2px solid var(--ink-faint); transition:.15s; }
.lk-dots i.full{ background:var(--accent); border-color:var(--accent); box-shadow:0 2px 7px color-mix(in srgb,var(--accent) 55%,transparent); }
[data-theme="brutal"] .lk-dots i{ border-color:#111; }
[data-theme="brutal"] .lk-dots i.full{ background:var(--accent); border-color:#111; box-shadow:none; }
.lk-dots.shake{ animation:lkshake .42s; }
@keyframes lkshake{ 10%,90%{transform:translateX(-2px)} 30%,70%{transform:translateX(-7px)} 50%{transform:translateX(7px)} }
.lk-pad{ margin-top:auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; width:100%; max-width:262px; }
.lk-key{ -webkit-appearance:none; appearance:none; aspect-ratio:1; border-radius:50%; cursor:pointer; font-family:var(--serif); font-size:27px; font-weight:500; color:var(--ink);
  background:linear-gradient(180deg, color-mix(in srgb,var(--card) 82%,#fff 18%), var(--card)); border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65), 0 1px 2px rgba(36,28,20,.05), 0 8px 18px rgba(36,28,20,.11);
  display:flex; align-items:center; justify-content:center; transition:transform .08s ease, box-shadow .12s ease; }
.lk-key:active{ transform:scale(.93); box-shadow:inset 0 2px 7px rgba(36,28,20,.20); }
.lk-key.fn{ background:transparent; border-color:transparent; box-shadow:none; color:var(--ink-soft); }
.lk-key.fn.ghost{ pointer-events:none; }
.lk-key.fn svg{ width:27px; height:27px; }
.lk-key.bio{ color:var(--green-2); }
[data-theme="dark"] .lk-key{ background:linear-gradient(180deg, color-mix(in srgb,var(--card) 88%,#fff 12%), var(--card)); box-shadow:inset 0 1px 0 rgba(255,255,255,.09), 0 8px 20px rgba(0,0,0,.5); }
[data-theme="dark"] .lk-key.bio{ color:var(--green); }
[data-theme="dark"] .lk-key.fn{ background:transparent; box-shadow:none; }
[data-theme="brutal"] .lk-key{ border:2px solid #111; border-radius:14px; box-shadow:3px 3px 0 #111; background:var(--card); }
[data-theme="brutal"] .lk-key:active{ transform:translate(1px,1px); box-shadow:1px 1px 0 #111; }
[data-theme="brutal"] .lk-key.fn{ border-color:transparent; box-shadow:none; }
.lk-divider{ height:1px; background:var(--line); margin:14px 0; }

/* My Card */
.mycard{ text-align:center; }
.mc-photo{ width:84px; height:84px; border-radius:50%; margin:4px auto 10px; background:var(--green); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:600; font-size:30px; overflow:hidden; cursor:pointer; }
.mc-photo img{ width:100%; height:100%; object-fit:cover; }
.mc-name{ font-family:var(--serif); font-weight:600; font-size:22px; letter-spacing:-.01em; }
.mc-title{ font-family:var(--mono); font-size:12.5px; color:var(--ink-soft); margin-top:2px; }
.mycard .socrow{ justify-content:center; }
.qrwrap{ display:flex; flex-direction:column; align-items:center; margin:10px 0; }
.qrbox{ background:#fff; padding:12px; border-radius:18px; border:1px solid var(--line); box-shadow:var(--shadow); display:inline-block; }
.qrcanvas{ display:block; image-rendering:pixelated; border-radius:4px; }

/* ===================== My Card v2: Poster / Aurora / Foil + Relight ===================== */
.mycard{ position:relative; width:100%; max-width:420px; margin:8px auto 14px; border-radius:26px; overflow:hidden; isolation:isolate; box-shadow:0 26px 58px rgba(20,12,10,.42), 0 2px 0 rgba(255,255,255,.05); }
.mycard .vmark{ width:16px; height:11px; flex:0 0 auto; }
.mycard .biz-tags{ display:flex; gap:7px; flex-wrap:wrap; }
.mycard .biz-tag{ display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:11px; padding:5px 11px 5px 9px; border-radius:30px; line-height:1; white-space:nowrap; }
.mycard .biz-tag svg{ width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:1.8; }
.mycard .socrow{ display:flex; gap:9px; margin:0; flex-wrap:wrap; }
.mycard .soc{ width:38px; height:38px; border-radius:12px; display:flex; align-items:center; justify-content:center; box-shadow:none; border:none; }
.mycard .soc svg{ width:19px; height:19px; }
.mycard .mc-name{ overflow-wrap:anywhere; }
.foil .mc-hd{ min-width:0; flex:1; }
.mc-edit{ position:absolute; top:14px; right:14px; width:34px; height:34px; border-radius:50%; border:none; background:rgba(255,255,255,.16); color:#fff; -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:9; }
.mc-edit svg{ width:15px; height:15px; fill:currentColor; }
.mc-grain{ position:absolute; inset:0; pointer-events:none; z-index:6; opacity:.06; mix-blend-mode:overlay; background-size:140px 140px; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.mc-qr .qrcanvas, .mc-qrtile .qrcanvas{ width:100%!important; height:100%!important; display:block; border-radius:3px; }

/* ---- 1. HEARTH POSTER ---- */
.mycard.poster{ --sh:color-mix(in srgb, var(--a1) 18%, #0d090c); --hi:color-mix(in srgb, var(--a1) 72%, #ffe7c4); background:var(--sh); color:#F5EEE0; min-height:528px; }
.poster .mc-pbg{ position:absolute; inset:0; cursor:pointer; }
.poster .mc-pbg img{ width:100%; height:100%; object-fit:cover; object-position:50% 20%; filter:grayscale(1) contrast(1.07) brightness(1.06); mix-blend-mode:screen; }
.poster .mc-duo{ position:absolute; inset:0; background:var(--hi); mix-blend-mode:multiply; }
.poster .mc-scrim{ position:absolute; inset:0; background:linear-gradient(to top, var(--sh) 7%, color-mix(in srgb,var(--sh) 55%,transparent) 34%, transparent 58%); }
.poster .mc-nameback{ position:absolute; left:18px; right:18px; bottom:198px; font-weight:700; font-size:64px; line-height:.84; letter-spacing:-.03em; color:color-mix(in srgb,#fff 13%,transparent); }
.poster .mc-brand{ position:absolute; top:18px; left:20px; z-index:4; display:flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11px; letter-spacing:.16em; opacity:.92; }
.poster .mc-foot{ position:absolute; left:20px; right:20px; bottom:18px; z-index:4; }
.poster .mc-name{ font-weight:700; font-size:46px; line-height:.92; letter-spacing:-.03em; text-shadow:0 2px 20px rgba(0,0,0,.5); }
.poster .mc-title{ font-family:var(--mono); font-size:12px; opacity:.88; margin:8px 0 13px; }
.poster .biz-tags{ }
.poster .biz-tag{ background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); color:#F5EEE0; }
.poster .mc-row2{ display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-top:14px; }
.poster .soc{ background:rgba(255,255,255,.14); color:#F5EEE0; }
.poster .mc-qr{ width:66px; height:66px; border-radius:11px; background:#fff; padding:5px; box-shadow:0 6px 16px rgba(0,0,0,.4); flex:0 0 auto; }
.poster .mc-sheen{ position:absolute; inset:0; z-index:5; pointer-events:none; background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.14) 49%,transparent 58%); mix-blend-mode:screen; }
.poster .mc-addphoto{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:9px; cursor:pointer; text-align:center; padding:0 30px; }
.poster .mc-addphoto .ring{ width:76px; height:76px; border-radius:50%; border:2px dashed rgba(255,255,255,.5); display:flex; align-items:center; justify-content:center; font-size:32px; font-weight:300; }
.poster .mc-addphoto .t1{ font-family:var(--mono); font-size:13px; letter-spacing:.02em; }
.poster .mc-addphoto .t2{ font-family:var(--mono); font-size:11px; opacity:.7; }

/* ---- 2. AURORA HEARTH ---- */
.mycard.aurora{ background:var(--base); color:var(--ink); min-height:528px; padding:24px 22px; display:flex; flex-direction:column; align-items:center; text-align:center; }
.aurora .mc-mesh{ position:absolute; inset:0; z-index:0; filter:saturate(1.3); background:
  radial-gradient(60% 50% at 28% 26%, var(--a1) 0%, transparent 60%),
  radial-gradient(55% 45% at 88% 12%, var(--a2) 0%, transparent 55%),
  radial-gradient(72% 62% at 86% 96%, var(--a1) 0%, transparent 58%),
  radial-gradient(52% 52% at 8% 92%, var(--a2) 0%, transparent 55%);
  background-blend-mode:screen,screen,soft-light,screen; }
.aurora>*{ position:relative; z-index:3; }
.aurora .mc-inner{ position:absolute; inset:0; z-index:7; border-radius:26px; box-shadow:inset 0 1px 0 rgba(255,255,255,.22), inset 0 0 0 1px rgba(255,255,255,.07); pointer-events:none; }
.aurora .mc-brand{ align-self:flex-start; display:flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11px; letter-spacing:.16em; opacity:.85; }
.aurora .mc-photo{ margin-top:18px; width:96px; height:96px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:700; font-size:34px; overflow:hidden; cursor:pointer; position:relative; background:color-mix(in srgb,var(--a1) 36%,var(--base)); box-shadow:0 8px 22px rgba(0,0,0,.35), 0 0 0 4px color-mix(in srgb,var(--base) 62%,transparent); }
.aurora .mc-photo::before{ content:''; position:absolute; inset:-16px; border-radius:50%; z-index:-1; background:radial-gradient(circle,var(--a1) 0%,transparent 68%); opacity:.75; filter:blur(4px); }
.aurora .mc-photo img{ width:100%; height:100%; object-fit:cover; }
.aurora .mc-name{ font-weight:700; font-size:31px; letter-spacing:-.02em; margin-top:15px; line-height:1; }
.aurora .mc-title{ font-family:var(--mono); font-size:12px; letter-spacing:.05em; text-transform:uppercase; opacity:.78; margin-top:7px; }
.aurora .biz-tags{ justify-content:center; margin-top:15px; }
.aurora .biz-tag{ background:rgba(255,255,255,.14); border:1px solid color-mix(in srgb,var(--ink) 16%,transparent); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); }
.aurora .socrow{ justify-content:center; margin-top:16px; }
.aurora .soc{ background:rgba(255,255,255,.16); border:1px solid color-mix(in srgb,var(--ink) 14%,transparent); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); }
.aurora .mc-qrtile{ margin-top:auto; display:flex; align-items:center; gap:11px; background:#fff; border-radius:15px; padding:9px 14px 9px 9px; box-shadow:0 10px 26px rgba(0,0,0,.28); }
.aurora .mc-qr{ width:68px; height:68px; flex:0 0 auto; }
.aurora .mc-qrtile span{ font-family:var(--mono); font-size:10.5px; line-height:1.4; color:#2B2622; text-align:left; }

/* ---- 3. FOIL & PRESS ---- */
.mycard.foil{ background:var(--base); color:var(--ink); min-height:528px; padding:26px 24px; }
.foil .mc-paper{ position:absolute; inset:0; z-index:0; background:linear-gradient(160deg, color-mix(in srgb,var(--base) 94%, #fff 6%), var(--base)); }
.foil>*{ position:relative; z-index:2; }
.foil .mc-grain{ opacity:.07; mix-blend-mode:multiply; }
.foil .mc-idx{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; font-weight:600; display:flex; align-items:center; gap:8px; background:linear-gradient(100deg,var(--f1),var(--f2) 38%,#fff7e0 50%,var(--f2) 62%,var(--f1)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.foil .vmark{ color:var(--f2); }
.foil .mc-idx .vmark{ width:18px; height:12px; }
.foil .mc-rule{ height:1px; background:linear-gradient(90deg, color-mix(in srgb,var(--ink) 38%,transparent), transparent); margin:12px 0 18px; }
.foil .mc-head{ display:flex; gap:15px; align-items:center; }
.foil .mc-photo{ width:74px; height:74px; border-radius:50%; flex:0 0 74px; padding:3px; background:linear-gradient(135deg,var(--f1),#fff7e0,var(--f2)); display:flex; align-items:center; justify-content:center; cursor:pointer; overflow:hidden; }
.foil .mc-photo img{ width:100%; height:100%; border-radius:50%; object-fit:cover; }
.foil .mc-photo.ini{ font-family:var(--serif); font-weight:700; font-size:27px; color:var(--base); }
.foil .mc-name{ font-weight:700; font-size:33px; letter-spacing:-.02em; line-height:.97; text-shadow:var(--deb); }
.foil .mc-title{ font-family:var(--mono); font-size:11.5px; letter-spacing:.05em; text-transform:uppercase; opacity:.7; margin-top:8px; }
.foil .mc-lbl{ font-family:var(--mono); font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; opacity:.55; margin:22px 0 10px; }
.foil .biz-tag{ border:1px solid color-mix(in srgb,var(--f2) 55%,transparent); color:var(--ink); background:transparent; }
.foil .biz-tag svg{ stroke:var(--f2); }
.foil .mc-bottom{ position:absolute; left:24px; right:24px; bottom:24px; z-index:2; display:flex; align-items:flex-end; justify-content:space-between; }
.foil .soc{ width:34px; height:34px; border-radius:10px; border:1px solid color-mix(in srgb,var(--f2) 50%,transparent); color:var(--ink); }
.foil .mc-qr{ width:72px; height:72px; background:#fff; border-radius:8px; padding:6px; box-shadow:inset 0 0 0 1px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.18); flex:0 0 auto; }
.foil .mc-seal{ position:absolute; top:24px; right:22px; z-index:2; }
.foil .mc-seal .vmark{ width:34px; height:24px; }

/* ---- Relight controls ---- */
.mc-controls{ display:flex; align-items:center; justify-content:center; gap:10px; flex-wrap:wrap; margin:2px 0 10px; }
.mc-looks{ display:inline-flex; background:var(--card); border:1px solid var(--line); border-radius:30px; padding:3px; }
.mc-look{ border:none; background:none; font-family:var(--mono); font-size:12px; color:var(--ink-soft); padding:6px 13px; border-radius:24px; cursor:pointer; }
.mc-look.on{ background:var(--green); color:var(--on-accent); }
.mc-relight{ display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:12px; color:var(--ink); background:var(--card); border:1px solid var(--line); border-radius:30px; padding:7px 13px; cursor:pointer; }
.mc-relight svg{ width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.mc-auto{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); background:none; border:1px solid var(--line); border-radius:30px; padding:7px 12px; cursor:pointer; }
@media (prefers-reduced-motion:reduce){ .mycard *{ animation:none!important; } }

/* ---- Beta feedback widget ---- */
.fb-fab{ position:fixed; left:14px; bottom:calc(18px + env(safe-area-inset-bottom)); z-index:45; display:inline-flex; align-items:center; gap:7px; padding:9px 14px 9px 11px; border:none; border-radius:30px; background:color-mix(in srgb,var(--green) 90%, #000); color:var(--on-accent); font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.02em; cursor:pointer; box-shadow:0 6px 18px rgba(0,0,0,.3); opacity:.55; transition:opacity .2s, transform .12s; }
.fb-fab:hover{ opacity:1; }
.fb-fab:active{ transform:scale(.96); opacity:1; }
.fb-fab svg{ width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.fb-fab[hidden], .fb-bg[hidden]{ display:none !important; }  /* the [hidden] attribute must win over the display rules below */
.fb-bg{ position:fixed; inset:0; z-index:60; background:rgba(20,14,12,.46); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); display:flex; align-items:flex-end; justify-content:center; }
.fb-sheet{ width:100%; max-width:480px; background:var(--bg); border-radius:22px 22px 0 0; padding:20px 18px calc(20px + env(safe-area-inset-bottom)); box-shadow:0 -10px 40px rgba(0,0,0,.32); animation:fbup .22s ease-out; }
@keyframes fbup{ from{ transform:translateY(22px); opacity:.5; } to{ transform:translateY(0); opacity:1; } }
.fb-sheet h3{ font-family:var(--serif); font-weight:600; font-size:20px; letter-spacing:-.01em; }
.fb-sheet .sub{ font-family:var(--mono); font-size:11.5px; color:var(--ink-soft); margin-top:3px; }
.fb-moods{ display:flex; gap:8px; margin:14px 0; }
.fb-mood{ flex:1; padding:10px 4px; border:1px solid var(--line); border-radius:14px; background:var(--card); cursor:pointer; font-family:var(--mono); font-size:12px; color:var(--ink); display:flex; flex-direction:column; align-items:center; gap:4px; }
.fb-mood .em{ font-size:21px; line-height:1; }
.fb-mood.on{ border-color:var(--green); box-shadow:0 0 0 2px color-mix(in srgb,var(--green) 32%,transparent); }
.fb-sheet textarea{ width:100%; min-height:92px; font-family:inherit; font-size:15px; color:var(--ink); background:var(--card); border:1px solid var(--line); border-radius:12px; padding:11px 12px; resize:vertical; }
.fb-sheet textarea:focus{ outline:none; border-color:var(--green); }
.fb-ctx{ font-family:var(--mono); font-size:10.5px; color:var(--ink-faint); margin:9px 2px 0; }
.fb-actions{ display:flex; gap:9px; margin-top:14px; }
.fb-send{ flex:1; }
.fb-priv{ font-family:var(--mono); font-size:10.5px; color:var(--ink-soft); text-align:center; margin-top:11px; line-height:1.55; }
.fb-foot{ display:flex; justify-content:space-between; align-items:center; margin-top:11px; }
.fb-foot button{ font-family:var(--mono); font-size:11px; color:var(--ink-soft); background:none; border:none; cursor:pointer; padding:4px; }

/* voice capture (Wispr-style live listening) */
.voicebar{ display:flex; align-items:center; gap:12px; background:var(--accent); color:var(--hero-ink); border-radius:14px; padding:10px 14px; margin:8px 0; }
.vbars{ display:inline-flex; align-items:flex-end; gap:3px; height:20px; }
.vbars i{ width:3px; height:6px; background:currentColor; border-radius:3px; animation:vb .9s ease-in-out infinite; }
.vbars i:nth-child(2){ animation-delay:.12s } .vbars i:nth-child(3){ animation-delay:.24s } .vbars i:nth-child(4){ animation-delay:.36s } .vbars i:nth-child(5){ animation-delay:.48s }
@keyframes vb{ 0%,100%{ height:5px } 50%{ height:18px } }
.vtext{ font-family:var(--mono); font-size:12px; flex:1; }
@media (prefers-reduced-motion:reduce){ .vbars i{ animation:none; height:12px; } }

/* mobile */
@media(max-width:680px){
  .tabs{ position:fixed; inset:60px 0 auto 0; flex-direction:column; background:var(--bg); border-bottom:1px solid var(--line); padding:8px 14px 14px; transform:translateY(-150%); transition:transform .25s; z-index:25; }
  .tabs.open{ transform:none; }
  .tabs a{ padding:13px 10px; border-bottom:1px solid var(--line); border-radius:8px; font-size:13px; }
  .icon-btn.menu{ display:block; }
  .topbar .wrap{ gap:10px; }
  .tabs{ flex:0; }
  .three{ grid-template-columns:1fr 1fr 1fr; gap:6px; }
}
