/* SPA English Cloud v2.1 extension */
.cloud-account{margin-left:auto;display:flex;align-items:center;gap:8px;min-width:0}.cloud-chip{display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.12);color:#fff;border-radius:999px;padding:7px 11px;font-weight:800;font-size:.84rem;white-space:nowrap}.cloud-dot{width:9px;height:9px;border-radius:50%;background:#c9d3df;flex:0 0 auto}.cloud-chip[data-state="online"] .cloud-dot{background:#62e39f;box-shadow:0 0 0 4px rgba(98,227,159,.18)}.cloud-chip[data-state="syncing"] .cloud-dot{background:#ffd166}.cloud-chip[data-state="offline"] .cloud-dot{background:#ff8d8d}.cloud-chip[data-state="local"] .cloud-dot{background:#d5dce5}.cloud-user-btn{border:1px solid rgba(255,255,255,.45);background:transparent;color:#fff;border-radius:10px;padding:7px 10px;font-weight:800;white-space:nowrap}.cloud-user-btn:hover{background:rgba(255,255,255,.12)}
.auth-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:18px;background:rgba(5,15,28,.64);z-index:220}.auth-modal.show{display:flex}.auth-box{width:min(470px,100%);max-height:94vh;overflow:auto;background:var(--card);color:var(--ink);border:1px solid var(--line);border-radius:22px;box-shadow:0 22px 70px rgba(0,0,0,.28);padding:22px}.auth-box.gate .auth-close{display:none}.auth-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.auth-head h2{margin:0 0 5px}.auth-close{border:0;background:transparent;color:var(--ink);font-size:1.65rem}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:17px 0}.auth-tab{border:1px solid var(--line);background:var(--card);color:var(--ink);padding:10px;border-radius:11px;font-weight:900}.auth-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.auth-form{display:grid;gap:12px}.auth-message{margin-top:12px;min-height:25px}.auth-message.error{color:var(--danger)}.auth-message.good{color:var(--good)}.cloud-warning{border-left:5px solid var(--warn);background:#fff8e8;padding:12px 14px;border-radius:11px;color:#604300}.cloud-success{border-left:5px solid var(--good);background:#ecfbf4;padding:12px 14px;border-radius:11px;color:#0d5e3a}.cloud-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cloud-card{border:1px solid var(--line);background:var(--card);border-radius:15px;padding:15px}.cloud-card h3{margin:0 0 10px}.cloud-status-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.cloud-status-row:last-child{border-bottom:0}.cloud-status-value{font-weight:900;text-align:right;word-break:break-all}.cloud-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.cloud-config-form{display:grid;gap:10px}.cloud-config-form input{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.86rem}.privacy-choice{border:1px solid var(--line);border-radius:13px;padding:12px;background:var(--accent)}.share-status{display:inline-flex;align-items:center;border-radius:999px;padding:4px 8px;font-size:.76rem;font-weight:900}.share-status.private{background:var(--accent);color:var(--primary)}.share-status.pending{background:#fff3cd;color:#775600}.share-status.approved{background:#dff5e9;color:#0e633e}.share-status.rejected{background:#fde5e5;color:#8f2020}.sharedtag{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;background:#e7e2ff;color:#49378f;font-size:.78rem;font-weight:900}.admin-kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:18px}.admin-kpi{border:1px solid var(--line);background:var(--card);border-radius:15px;padding:15px;box-shadow:var(--shadow)}.admin-kpi b{font-size:1.7rem;display:block}.admin-kpi span{color:var(--muted);font-size:.83rem}.admin-toolbar{display:flex;gap:9px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:14px}.admin-section{margin-top:18px}.admin-user-table{width:100%;border-collapse:collapse;min-width:900px}.admin-user-table th,.admin-user-table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}.admin-user-table th{background:var(--accent);position:sticky;top:0}.admin-empty{padding:25px;text-align:center;color:var(--muted)}.review-card{border:1px solid var(--line);border-radius:14px;padding:14px;background:var(--card)}.review-card+.review-card{margin-top:10px}.review-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.review-actions{display:flex;gap:7px;flex-wrap:wrap}.sync-pulse{animation:syncPulse 1.1s ease-in-out infinite}@keyframes syncPulse{0%,100%{opacity:.5}50%{opacity:1}}.privacy-note{font-size:.82rem;color:var(--muted);margin-top:8px}.cloud-only{display:none}.cloud-ready .cloud-only{display:initial}.local-mode-banner{display:none;margin-bottom:14px}.local-mode-banner.show{display:block}.account-hero{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.account-hero h2{margin-bottom:4px}.version-pill{border-radius:999px;padding:5px 9px;background:var(--accent);color:var(--primary);font-weight:900;font-size:.78rem;white-space:nowrap}
@media(max-width:1100px){.admin-kpis{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.cloud-grid{grid-template-columns:1fr}.admin-kpis{grid-template-columns:1fr 1fr}.cloud-account{margin-left:auto}.cloud-chip span:last-child{display:none}.cloud-user-btn{max-width:118px;overflow:hidden;text-overflow:ellipsis}.account-hero{flex-direction:column}.review-head{flex-direction:column}}
@media(max-width:480px){.admin-kpis{grid-template-columns:1fr 1fr}.auth-box{padding:16px}.cloud-actions .btn{width:100%}}

/* v2.1 login-first gate and role separation */
body.auth-pending,body.auth-signed-out{min-height:100vh;overflow-x:hidden}
body.auth-pending .app,body.auth-signed-out .app{display:none!important}
body.auth-signed-in .app{display:block}
.auth-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;overflow:auto;padding:clamp(16px,4vw,48px);background:radial-gradient(circle at 15% 15%,rgba(64,145,220,.35),transparent 34%),linear-gradient(135deg,#071b30 0%,#123a63 52%,#1d5d94 100%)}
.auth-modal.show{display:flex}
.auth-shell{width:min(1040px,100%);display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.75fr);border:1px solid rgba(255,255,255,.22);border-radius:28px;overflow:hidden;box-shadow:0 34px 90px rgba(0,0,0,.38);background:rgba(255,255,255,.08);backdrop-filter:blur(14px)}
.auth-intro{color:#fff;padding:clamp(34px,6vw,72px);display:flex;flex-direction:column;justify-content:center;min-height:590px}
.auth-logo{width:74px;height:74px;display:grid;place-items:center;border-radius:22px;background:#fff;color:#123a63;font-size:1.65rem;font-weight:1000;letter-spacing:-.05em;box-shadow:0 16px 32px rgba(0,0,0,.18)}
.auth-eyebrow{font-weight:900;letter-spacing:.16em;font-size:.78rem;opacity:.78;margin:22px 0 8px}
.auth-intro h1{font-size:clamp(2rem,4vw,3.25rem);line-height:1.16;letter-spacing:-.045em;margin:0 0 18px;max-width:620px}
.auth-intro>p:not(.auth-eyebrow){font-size:1.06rem;line-height:1.75;max-width:600px;color:rgba(255,255,255,.84)}
.auth-feature-list{display:flex;flex-direction:column;gap:11px;margin-top:24px;font-weight:800;color:rgba(255,255,255,.93)}
.auth-box{width:100%;max-height:none;min-height:590px;border:0;border-radius:0;box-shadow:none;padding:clamp(28px,5vw,48px);display:flex;flex-direction:column;justify-content:center;background:var(--card)}
.auth-head h2{font-size:1.75rem;margin:5px 0 6px}.auth-role-note{display:inline-flex;padding:5px 9px;border-radius:999px;background:var(--accent);color:var(--primary);font-size:.77rem;font-weight:900}
.auth-tabs{margin:24px 0 18px}.auth-form input{min-height:50px;border:2px solid var(--line);border-radius:12px;padding:11px 12px;background:var(--card);color:var(--ink)}
.auth-form label{display:block;margin-bottom:6px;font-weight:900;color:var(--muted)}
.auth-loading{display:flex;align-items:center;gap:10px;margin:18px 0 0;padding:12px 14px;border-radius:12px;background:var(--accent);color:var(--primary)}
.auth-loading span{width:18px;height:18px;border:3px solid color-mix(in srgb,var(--primary) 25%,transparent);border-top-color:var(--primary);border-radius:50%;animation:authSpin .8s linear infinite}
.auth-config-help{margin-top:14px;padding:13px 14px;border-radius:12px;border-left:5px solid var(--danger);background:color-mix(in srgb,var(--danger) 9%,var(--card));color:var(--ink)}.auth-config-help p{margin:6px 0 0;font-size:.84rem}.auth-config-help code{word-break:break-all}
.auth-footnote{margin-top:18px;padding-top:15px;border-top:1px solid var(--line)}
@keyframes authSpin{to{transform:rotate(360deg)}}
.role-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:950;white-space:nowrap;border:1px solid rgba(255,255,255,.38)}
.role-badge[data-role="admin"]{background:#ffe7a3;color:#553800;border-color:#ffe7a3}.role-badge[data-role="member"]{background:rgba(255,255,255,.15);color:#fff}
body.role-admin .top{background:linear-gradient(90deg,#3d2b09,#7b5310)}body.role-admin .admin-nav{background:#fff1bf;color:#5d4100}body.role-admin .admin-nav.active{background:#7b5310;color:#fff}
body.role-member .admin-only{display:none!important}
.admin-nav[hidden],.role-badge[hidden]{display:none!important}
@media(max-width:820px){.auth-modal{align-items:flex-start;padding:0;background:#123a63}.auth-shell{grid-template-columns:1fr;border:0;border-radius:0;min-height:100vh}.auth-intro{min-height:auto;padding:28px 22px 22px}.auth-logo{width:54px;height:54px;border-radius:16px;font-size:1.25rem}.auth-intro h1{font-size:1.85rem;margin-bottom:10px}.auth-intro>p:not(.auth-eyebrow){font-size:.95rem;margin:0}.auth-feature-list{display:none}.auth-box{min-height:0;border-radius:24px 24px 0 0;padding:26px 20px 34px;justify-content:flex-start}.cloud-account{gap:5px}.role-badge{display:none!important}}
