:root{
  --deep:#061020;--ocean:#0a1628;
  --foam:#e8f4f8;--tide:#4fc3f7;--kelp:#26a69a;
  --coral:#ff7043;--sand:#ffd54f;--bike:#a78bfa;--run:#ff8a65;--climb:#f06292;--mist:#b0bec5;
  --glass:rgba(255,255,255,0.05);--gb:rgba(255,255,255,0.09);
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{background:var(--deep);color:var(--foam);font-family:'Bricolage Grotesque',sans-serif;min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at 15% 60%,rgba(79,195,247,.07) 0%,transparent 55%),
             radial-gradient(ellipse at 85% 15%,rgba(38,166,154,.05) 0%,transparent 50%),
             radial-gradient(ellipse at 55% 85%,rgba(26,58,92,.35) 0%,transparent 55%);}
.app{position:relative;z-index:1;max-width:860px;margin:0 auto;
  padding:calc(1.5rem + var(--safe-top)) 1.5rem calc(4rem + var(--safe-bot));}

/* ── Header ── */
header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2.2rem;padding-bottom:1.3rem;border-bottom:1px solid var(--gb);}
.logo{font-family:'Instrument Serif',serif;font-size:2.2rem;color:var(--tide);letter-spacing:-1px;line-height:1;}
.logo em{color:var(--foam);font-style:italic;}
.profile-chip{display:flex;align-items:center;gap:.6rem;background:var(--glass);border:1px solid var(--gb);border-radius:100px;padding:.35rem 1rem .35rem .35rem;cursor:pointer;transition:all .2s;font-size:.84rem;color:var(--mist);}
.profile-chip:hover{border-color:var(--tide);color:var(--foam);}
.avatar{width:27px;height:27px;border-radius:50%;background:linear-gradient(135deg,var(--tide),var(--kelp));display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--deep);flex-shrink:0;}

/* ── Card ── */
.card{background:var(--glass);border:1px solid var(--gb);border-radius:16px;padding:1.4rem;margin-bottom:1.2rem;backdrop-filter:blur(10px);}
.card-title{font-family:'DM Mono',monospace;font-size:.68rem;font-weight:500;text-transform:uppercase;letter-spacing:.13em;color:var(--mist);margin-bottom:.9rem;}

/* ── Journey ── */
.journey-top{display:flex;align-items:baseline;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;}
.total-km{font-family:'Instrument Serif',serif;font-size:1.6rem;color:var(--foam);line-height:1;}
.origin-badge{font-family:'DM Mono',monospace;font-size:.72rem;background:rgba(79,195,247,.11);color:var(--tide);padding:.25rem .65rem;border-radius:100px;border:1px solid rgba(79,195,247,.2);margin-left:auto;}

/* ── City timeline ── */
.timeline-wrap{margin-bottom:1rem;}
.timeline-scroll{overflow-x:auto;padding-top:10px;padding-bottom:.6rem;}
.timeline-scroll::-webkit-scrollbar{height:3px;}
.timeline-scroll::-webkit-scrollbar-thumb{background:var(--gb);border-radius:3px;}
.timeline{display:flex;align-items:flex-start;min-width:max-content;}
.tl-city{display:flex;flex-direction:column;align-items:center;min-width:78px;}
.tl-seg{display:flex;align-items:center;padding-top:13px;}
.tl-line{height:2px;min-width:24px;flex:1;background:rgba(255,255,255,.07);}
.tl-line.done{background:linear-gradient(90deg,var(--kelp),var(--tide));}
.tl-dot{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.13);background:var(--deep);display:flex;align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0;transition:all .3s;}
.tl-dot.done{background:linear-gradient(135deg,var(--kelp),var(--tide));border-color:var(--tide);}
.tl-dot.here{border-color:var(--tide);box-shadow:0 0 0 4px rgba(79,195,247,.18);animation:glow 2s infinite;}
.tl-dot.origin{background:linear-gradient(135deg,var(--kelp),var(--tide));border-color:var(--kelp);}
@keyframes glow{0%,100%{box-shadow:0 0 0 4px rgba(79,195,247,.18)}50%{box-shadow:0 0 0 8px rgba(79,195,247,.05)}}
.tl-name{font-family:'DM Mono',monospace;font-size:.53rem;color:var(--mist);text-align:center;margin-top:.3rem;max-width:74px;line-height:1.3;word-break:break-word;}
.tl-name.hi{color:var(--tide);}
.tl-km{font-family:'DM Mono',monospace;font-size:.47rem;color:rgba(255,255,255,.22);text-align:center;}

/* ── Leg ── */
.leg-block{padding-top:.9rem;border-top:1px solid var(--gb);}
.leg-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.3rem;}
.leg-lbl{font-family:'DM Mono',monospace;font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--mist);}
.leg-pct-txt{font-family:'DM Mono',monospace;font-size:.68rem;color:var(--tide);}
.leg-cities{font-family:'Instrument Serif',serif;font-size:1.05rem;color:var(--foam);margin-bottom:.4rem;}
.leg-cities b{color:var(--tide);}
.pbar-wrap{height:6px;background:rgba(255,255,255,.06);border-radius:100px;overflow:hidden;margin-bottom:.32rem;}
.pbar{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--kelp),var(--tide));transition:width .7s cubic-bezier(.34,1.56,.64,1);}
.pbar-rows{display:flex;justify-content:space-between;font-family:'DM Mono',monospace;font-size:.67rem;color:var(--mist);}

/* ── Stats ── */
.stats-grid{display:grid;gap:.6rem;margin-top:1rem;}
.stat-box{background:rgba(255,255,255,.03);border:1px solid var(--gb);border-radius:10px;padding:.7rem .9rem;}
.stat-lbl{font-family:'DM Mono',monospace;font-size:.58rem;text-transform:uppercase;letter-spacing:.08em;color:var(--mist);margin-bottom:.22rem;}
.stat-val{font-family:'Instrument Serif',serif;font-size:1.25rem;color:var(--foam);line-height:1;}
.stat-u{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--mist);margin-left:.1rem;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.58rem 1.1rem;border-radius:10px;border:none;cursor:pointer;font-family:'Bricolage Grotesque',sans-serif;font-size:.84rem;font-weight:600;transition:all .15s;}
.btn-primary{background:linear-gradient(135deg,var(--tide),var(--kelp));color:var(--deep);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,195,247,.28);}
.btn-ghost{background:var(--glass);border:1px solid var(--gb);color:var(--foam);}
.btn-ghost:hover{border-color:var(--tide);background:rgba(79,195,247,.07);}
.btn-sand{background:rgba(255,213,79,.11);border:1px solid rgba(255,213,79,.24);color:var(--sand);}
.btn-sand:hover{background:rgba(255,213,79,.2);}
.btn-coral{background:rgba(255,112,67,.13);border:1px solid rgba(255,112,67,.28);color:var(--coral);}
.btn-coral:hover{background:rgba(255,112,67,.22);}
.btn-danger{background:rgba(255,82,82,.12);border:1px solid rgba(255,82,82,.3);color:#ff5252;}
.btn-danger:hover{background:rgba(255,82,82,.22);}
.act-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.2rem;}

/* ── Activity grid ── */
.grid-scroll{overflow-x:auto;padding-bottom:.4rem;}
.grid-months{display:flex;padding-left:32px;margin-bottom:.28rem;}
.m-lbl{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--mist);flex-shrink:0;text-align:left;}
.grid-body{display:flex;gap:2px;}
.day-col-labels{display:flex;flex-direction:column;gap:2px;margin-right:4px;}
.d-lbl{height:12px;font-family:'DM Mono',monospace;font-size:.5rem;color:var(--mist);line-height:12px;width:24px;text-align:right;}
.weeks{display:flex;gap:2px;}
.wk{display:flex;flex-direction:column;gap:2px;}
/* Multi-activity cell: split into colored quarters */
.cell{width:12px;height:12px;border-radius:2px;cursor:default;transition:transform .1s;position:relative;overflow:hidden;background:rgba(255,255,255,.05);}
.cell:hover{transform:scale(1.6);z-index:10;}
.cell.today{outline:2px solid rgba(79,195,247,.85);outline-offset:0;}
/* Single-type cells */
.cell.c-swim{background:rgba(38,166,154,var(--ia,.3));outline:1px solid rgba(79,195,247,.4);}
.cell.c-walk{background:rgba(255,213,79,var(--ia,.25));outline:1px solid rgba(255,213,79,.35);}
.cell.c-bike{background:rgba(167,139,250,var(--ia,.35));outline:1px solid rgba(167,139,250,.4);}
.cell.c-run{background:rgba(255,138,101,var(--ia,.35));outline:1px solid rgba(255,138,101,.4);}
.cell.c-climb{background:rgba(240,98,146,var(--ia,.35));outline:1px solid rgba(240,98,146,.4);}
/* Multi-type: use CSS grid inside the cell */
.cell-inner{display:grid;width:100%;height:100%;position:absolute;inset:0;}
.cell-inner.two{grid-template-columns:1fr 1fr;}
.cell-inner.three{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;}
.cell-seg{width:100%;height:100%;}
.cell-seg.seg-swim{background:rgba(38,166,154,.75);}
.cell-seg.seg-walk{background:rgba(255,213,79,.65);}
.cell-seg.seg-bike{background:rgba(167,139,250,.75);}
.cell-seg.seg-run{background:rgba(255,138,101,.75);}
.cell-seg.seg-climb{background:rgba(240,98,146,.75);}
.cell-seg.span2{grid-column:1/-1;}
.cell-inner.four{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;}
.tip{position:fixed;background:var(--ocean);border:1px solid var(--gb);border-radius:8px;padding:.42rem .7rem;font-family:'DM Mono',monospace;font-size:.67rem;color:var(--foam);pointer-events:none;z-index:1000;white-space:nowrap;display:none;max-width:320px;white-space:normal;line-height:1.5;}
.grid-legend{display:flex;align-items:center;gap:3px;margin-top:.65rem;flex-wrap:wrap;}
.grid-legend span{font-family:'DM Mono',monospace;font-size:.57rem;color:var(--mist);}
.sc{width:12px;height:12px;border-radius:2px;flex-shrink:0;}

/* ── Log ── */
.log-list{display:flex;flex-direction:column;gap:.52rem;}
.log-entry{display:flex;align-items:flex-start;gap:.85rem;background:rgba(255,255,255,.03);border:1px solid var(--gb);border-radius:10px;padding:.75rem .95rem;transition:border-color .15s;}
.log-entry:hover{border-color:rgba(79,195,247,.22);}
.log-entry.ms{border-color:rgba(255,213,79,.28);background:rgba(255,213,79,.04);}
.log-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;margin-top:.1rem;}
.log-icon.swim{background:rgba(79,195,247,.11);}
.log-icon.walk{background:rgba(255,213,79,.11);}
.log-icon.bike{background:rgba(167,139,250,.11);}
.log-icon.run{background:rgba(255,138,101,.11);}
.log-icon.climb{background:rgba(240,98,146,.11);}
.log-icon.ms-icon{background:rgba(255,213,79,.14);}
.log-info{flex:1;min-width:0;}
.log-date{font-family:'DM Mono',monospace;font-size:.6rem;color:var(--mist);}
.log-desc{font-size:.83rem;color:var(--foam);margin-top:.08rem;}
.log-meta{display:flex;gap:.5rem;margin-top:.25rem;flex-wrap:wrap;}
.log-tag{font-family:'DM Mono',monospace;font-size:.6rem;padding:.18rem .5rem;border-radius:100px;border:1px solid;}
.log-tag.dist{color:var(--tide);border-color:rgba(79,195,247,.25);background:rgba(79,195,247,.07);}
.log-tag.dist.wc{color:var(--sand);border-color:rgba(255,213,79,.25);background:rgba(255,213,79,.07);}
.log-tag.dist.bc{color:var(--bike);border-color:rgba(167,139,250,.25);background:rgba(167,139,250,.07);}
.log-tag.dist.rc{color:var(--run);border-color:rgba(255,138,101,.25);background:rgba(255,138,101,.07);}
.log-tag.time.cc{color:var(--climb);border-color:rgba(240,98,146,.25);background:rgba(240,98,146,.07);}
.log-tag.time{color:var(--mist);border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.04);}
.log-tag.speed{color:var(--kelp);border-color:rgba(38,166,154,.25);background:rgba(38,166,154,.07);}
.del-btn{background:none;border:none;cursor:pointer;color:var(--mist);font-size:.85rem;padding:.2rem .38rem;transition:color .15s;opacity:.38;border-radius:4px;flex-shrink:0;margin-top:.1rem;}
.del-btn:hover{color:var(--coral);opacity:1;}
.edit-btn{background:none;border:none;cursor:pointer;color:var(--mist);font-size:.85rem;padding:.2rem .38rem;transition:color .15s;opacity:.38;border-radius:4px;flex-shrink:0;}
.edit-btn:hover{color:var(--tide);opacity:1;}
.log-actions{display:flex;flex-direction:column;align-items:center;gap:.05rem;flex-shrink:0;}

/* ── Modal ── */
.overlay{position:fixed;inset:0;background:rgba(6,16,32,.9);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .2s;}
.overlay.open{opacity:1;pointer-events:all;}
.modal{background:#0d1e34;border:1px solid var(--gb);border-radius:20px 20px 0 0;padding:1.9rem 1.9rem calc(1.9rem + var(--safe-bot));width:100%;max-width:560px;transform:translateY(60px);transition:transform .25s cubic-bezier(.34,1.2,.64,1);max-height:92vh;overflow-y:auto;}
.overlay.open .modal{transform:translateY(0);}
@media(min-width:600px){
  .overlay{align-items:center;}
  .modal{border-radius:20px;padding:1.9rem;max-height:88vh;}
}
#m-add .modal{max-width:100%;}
.modal-title{font-family:'Instrument Serif',serif;font-size:1.5rem;color:var(--foam);margin-bottom:.2rem;}
.modal-sub{font-size:.77rem;color:var(--mist);margin-bottom:1.35rem;font-style:italic;}
.fg{margin-bottom:.85rem;}
.fl{display:block;font-family:'DM Mono',monospace;font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--mist);margin-bottom:.32rem;}
.fi,.fs{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--gb);border-radius:8px;padding:.58rem .82rem;color:var(--foam);font-family:'Bricolage Grotesque',sans-serif;font-size:.88rem;outline:none;transition:border-color .15s;}
.fi:focus,.fs:focus{border-color:var(--tide);}
.fs option{background:var(--ocean);}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:.68rem;}
.frow3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.68rem;}
.m-actions{display:flex;gap:.68rem;margin-top:1.35rem;flex-wrap:wrap;}
.m-actions .btn{flex:1;justify-content:center;min-width:120px;}
.section-divider{height:1px;background:var(--gb);margin:1.4rem 0;}
.section-head{font-family:'DM Mono',monospace;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--mist);margin-bottom:.9rem;}

/* ── Autocomplete ── */
.inp-wrap{position:relative;}
.sug-list{position:absolute;top:100%;left:0;right:0;background:#0d1e34;border:1px solid var(--tide);border-radius:8px;z-index:200;max-height:165px;overflow-y:auto;margin-top:2px;}
.sug-item{padding:.48rem .82rem;font-size:.83rem;cursor:pointer;color:var(--foam);border-bottom:1px solid var(--gb);}
.sug-item:last-child{border-bottom:none;}
.sug-item:hover,.sug-item:active{background:rgba(79,195,247,.09);color:var(--tide);}

/* ── Type toggle ── */
.type-row{display:flex;gap:.48rem;margin-bottom:.95rem;}
.t-btn{flex:1;padding:.52rem;border-radius:8px;border:1px solid var(--gb);background:var(--glass);color:var(--mist);cursor:pointer;font-family:'Bricolage Grotesque',sans-serif;font-size:.81rem;font-weight:600;text-align:center;transition:all .15s;}
.t-btn.s{background:rgba(79,195,247,.14);border-color:var(--tide);color:var(--tide);}
.t-btn.w{background:rgba(255,213,79,.14);border-color:var(--sand);color:var(--sand);}
.t-btn.b{background:rgba(167,139,250,.14);border-color:var(--bike);color:var(--bike);}
.t-btn.r{background:rgba(255,138,101,.14);border-color:var(--run);color:var(--run);}
.t-btn.cl{background:rgba(240,98,146,.14);border-color:var(--climb);color:var(--climb);}

/* ── Settings toggles ── */
.set-list{display:flex;flex-direction:column;gap:.7rem;}
.set-item{display:flex;align-items:center;justify-content:space-between;padding:.72rem .95rem;background:rgba(255,255,255,.03);border:1px solid var(--gb);border-radius:10px;}
.set-name{font-size:.87rem;font-weight:600;color:var(--foam);}
.set-desc{font-size:.7rem;color:var(--mist);margin-top:.08rem;}
.tog{position:relative;width:40px;height:22px;flex-shrink:0;}
.tog input{opacity:0;width:0;height:0;position:absolute;}
.tog-track{position:absolute;inset:0;background:rgba(255,255,255,.09);border-radius:100px;cursor:pointer;transition:background .2s;}
.tog input:checked+.tog-track{background:var(--tide);}
.tog-track::after{content:'';position:absolute;left:3px;top:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;}
.tog input:checked+.tog-track::after{transform:translateX(18px);}

/* ── Setup ── */
#setup{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1;}
.setup-box{background:var(--glass);border:1px solid var(--gb);border-radius:24px;padding:2.4rem;width:100%;max-width:430px;text-align:center;backdrop-filter:blur(10px);}
.sw-icon{font-size:3rem;margin-bottom:.9rem;display:block;animation:float 3s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.setup-title{font-family:'Instrument Serif',serif;font-size:2.2rem;color:var(--tide);margin-bottom:.45rem;}
.setup-sub{font-size:.82rem;color:var(--mist);margin-bottom:1.9rem;font-style:italic;line-height:1.5;}
.setup-box .fg{text-align:left;}

/* ── Misc ── */
.empty{text-align:center;padding:2rem;color:var(--mist);}
.empty .ei{font-size:2.4rem;margin-bottom:.45rem;display:block;}
.empty p{font-size:.82rem;font-style:italic;}
.notif{position:fixed;bottom:calc(1.5rem + var(--safe-bot));right:1.5rem;background:var(--ocean);border:1px solid var(--tide);border-radius:10px;padding:.68rem 1.05rem;font-size:.79rem;color:var(--foam);z-index:300;transform:translateY(120px);opacity:0;transition:all .3s;max-width:300px;}
.notif.show{transform:translateY(0);opacity:1;}
.notif.ok{border-color:var(--kelp);}
.notif.err{border-color:var(--coral);color:var(--coral);}
.install-banner{position:fixed;top:calc(1rem + var(--safe-top));left:50%;transform:translateX(-50%);background:var(--ocean);border:1px solid rgba(79,195,247,.3);border-radius:12px;padding:.65rem 1.1rem;font-size:.78rem;color:var(--foam);z-index:200;display:flex;align-items:center;gap:.75rem;box-shadow:0 4px 20px rgba(0,0,0,.4);white-space:nowrap;}
.install-banner button{background:var(--tide);color:var(--deep);border:none;border-radius:7px;padding:.3rem .75rem;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit;}
.install-banner .ib-close{background:none;border:none;color:var(--mist);cursor:pointer;font-size:1rem;padding:0;line-height:1;}
/* ── Trends ── */
.trends-tabs{display:flex;gap:.45rem;margin-bottom:1rem;flex-wrap:wrap;}
.trends-tab{background:rgba(255,255,255,.04);border:1px solid var(--gb);border-radius:100px;padding:.32rem .85rem;font-size:.76rem;font-family:'DM Mono',monospace;color:var(--mist);cursor:pointer;transition:all .2s;}
.trends-tab:hover{color:var(--foam);}
.trends-tab.active.swim{background:rgba(79,195,247,.12);border-color:rgba(79,195,247,.3);color:var(--tide);}
.trends-tab.active.walk{background:rgba(38,166,154,.12);border-color:rgba(38,166,154,.3);color:var(--kelp);}
.trends-tab.active.bike{background:rgba(167,139,250,.12);border-color:rgba(167,139,250,.3);color:var(--bike);}
.trends-tab.active.run{background:rgba(255,138,101,.12);border-color:rgba(255,138,101,.3);color:var(--run);}
.trends-tab.active.climb{background:rgba(240,98,146,.12);border-color:rgba(240,98,146,.3);color:var(--climb);}
.trends-chart-wrap{margin-bottom:1rem;overflow:visible;}
.trends-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:.5rem;}
.trends-stat{background:rgba(255,255,255,.03);border:1px solid var(--gb);border-radius:10px;padding:.6rem .75rem;text-align:center;}
.ts-val{font-family:'DM Mono',monospace;font-size:.9rem;color:var(--foam);font-weight:600;line-height:1.2;}
.ts-unit{font-size:.68rem;color:var(--mist);font-weight:400;}
.ts-lbl{font-size:.62rem;color:var(--mist);margin-top:.15rem;text-transform:uppercase;letter-spacing:.05em;}
@media(max-width:580px){.stats-grid{grid-template-columns:1fr 1fr!important;}.tl-city{min-width:64px;}.frow3{grid-template-columns:1fr 1fr;}}

/* ── Cloud Sync UI ── */
.header-right{display:flex;align-items:center;gap:.75rem;}
.sync-indicator{display:flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border-radius:100px;font-size:.72rem;font-family:'DM Mono',monospace;cursor:pointer;border:1px solid transparent;transition:all .2s;}
.sync-indicator.sync-ok{color:var(--kelp);border-color:rgba(38,166,154,.25);background:rgba(38,166,154,.08);}
.sync-indicator.sync-busy{color:var(--tide);border-color:rgba(79,195,247,.25);background:rgba(79,195,247,.08);}
.sync-indicator.sync-fail{color:#f2994a;border-color:rgba(242,153,74,.25);background:rgba(242,153,74,.08);}
.setup-login-link{text-align:center;margin-top:1rem;font-size:.82rem;color:var(--mist);}
.setup-login-link a{color:var(--tide);text-decoration:none;}
.setup-login-link a:hover{text-decoration:underline;}
/* cloud account section in profile modal */
.cloud-status-label{font-size:.82rem;color:var(--mist);margin:.1rem 0 .75rem;}
.cloud-user-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem;}
.cloud-user-label{font-size:.78rem;color:var(--mist);}
.cloud-username-mask{font-size:.82rem;color:var(--foam);font-family:'DM Mono',monospace;cursor:pointer;letter-spacing:.05em;}
.cloud-sync-row{font-size:.75rem;color:var(--mist);margin-bottom:.1rem;}
.cloud-links{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.85rem;}
.cloud-links a{font-size:.78rem;color:var(--tide);text-decoration:none;}
.cloud-links a:hover{text-decoration:underline;}
.cloud-links a.cloud-signout{color:#eb5757;}
/* passphrase strength */
.strength-bar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;margin:.35rem 0 .15rem;overflow:hidden;}
.strength-fill{height:100%;width:0;border-radius:2px;transition:width .3s,background .3s;}
.strength-label{font-size:.72rem;font-family:'DM Mono',monospace;min-height:.9rem;}
/* field status */
.field-status{font-size:.72rem;margin-top:.25rem;min-height:.9rem;font-family:'DM Mono',monospace;}
.field-status--ok{color:#6fcf97;}
.field-status--error{color:#eb5757;}
.field-status--checking{color:var(--mist);}
/* passphrase warning checkbox */
.passphrase-warn-row{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;color:var(--mist);margin:.85rem 0 .5rem;cursor:pointer;line-height:1.4;}
.passphrase-warn-row input{margin-top:.15rem;flex-shrink:0;accent-color:var(--tide);}
/* modal spinner */
.modal-spinner{display:flex;align-items:center;gap:.65rem;font-size:.8rem;color:var(--mist);justify-content:center;padding:.75rem 0;}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(79,195,247,.25);border-top-color:var(--tide);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg);}}
/* conflict resolution */
.conflict-rows{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0;}
.conflict-row{background:rgba(255,255,255,.04);border:1px solid var(--gb);border-radius:10px;padding:.75rem 1rem;}
.conflict-src{font-size:.75rem;color:var(--mist);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.25rem;}
.conflict-detail{font-size:.84rem;color:var(--foam);}
