:root{--bg:#07111f;--panel:#0b1726;--panel2:#132944;--text:#f7fbff;--muted:#b2c0d0;--line:rgba(255,255,255,.13);--brand:#f3c74d;--brand2:#12385c;--ok:#5bd493;--warn:#f3c74d;--bad:#ff6f61;--accent:#6ec6e8;--shadow:0 24px 60px rgba(0,0,0,.38)}
*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;background:radial-gradient(circle at top left,#284d74 0,#07111f 42%,#03070d 100%);color:var(--text);min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}label.photo,.file-picker{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.phone-shell{max-width:430px;min-height:100vh;margin:0 auto;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.015));box-shadow:0 0 0 1px rgba(255,255,255,.07),var(--shadow);position:relative;padding-bottom:84px}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 18px 12px;background:rgba(7,17,31,.9);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}.eyebrow{text-transform:uppercase;letter-spacing:.13em;color:var(--brand);font-size:11px;font-weight:900}h1{font-size:22px;margin:4px 0 0}h2{margin:0 0 10px}main{padding:16px}.card,.panel{background:rgba(11,23,38,.86);border:1px solid var(--line);border-radius:24px;padding:16px;box-shadow:0 18px 40px rgba(0,0,0,.22);margin-bottom:14px}.login-card{margin-top:34px}.brand-logo{width:180px;max-width:100%;height:auto;display:block;margin-bottom:14px;border-radius:10px;background:#fff;padding:8px;box-shadow:0 10px 26px rgba(0,0,0,.18)}.card-head .brand-logo{width:150px;margin:0 0 7px;padding:6px}.field{display:grid;gap:7px;margin:12px 0}.field label{color:var(--muted);font-size:13px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.07);color:var(--text);padding:12px;outline:none}textarea{min-height:82px;resize:vertical}.btn-row{display:flex;gap:10px;flex-wrap:wrap}.primary,.secondary,.ghost,.danger{border:0;border-radius:14px;padding:11px 13px;font-weight:850}.primary{background:linear-gradient(135deg,var(--brand),#ffe48a);color:#061320}.secondary{background:rgba(255,255,255,.11);color:var(--text);border:1px solid var(--line)}.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}.danger{background:rgba(255,111,97,.2);color:#ffe1de;border:1px solid rgba(255,111,97,.45)}.muted{color:var(--muted)}.small{font-size:12px}.hidden{display:none!important}.statusbar{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}.pill{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--line);font-size:12px;color:var(--muted)}.pill.ok{color:#d8ffe0;border-color:rgba(91,212,147,.4);background:rgba(91,212,147,.13)}.pill.warn{color:#fff0c2;border-color:rgba(243,199,77,.4);background:rgba(243,199,77,.13)}.pill.bad{color:#ffd6d6;border-color:rgba(255,111,97,.42);background:rgba(255,111,97,.15)}.id-card{overflow:hidden;padding:0;background:linear-gradient(145deg,#12385c,#07111f 75%);position:relative}.id-card:before{content:"";position:absolute;inset:-78px -60px auto auto;width:210px;height:210px;border-radius:50%;background:rgba(243,199,77,.2)}.id-card:after{content:"";position:absolute;left:-70px;bottom:-90px;width:220px;height:220px;border-radius:50%;background:rgba(110,198,232,.10)}.card-head{display:flex;justify-content:space-between;align-items:start;padding:16px;border-bottom:1px solid var(--line);position:relative;z-index:1}.verify{font-size:12px;color:#d8ffe0;font-weight:900;background:rgba(91,212,147,.16);border:1px solid rgba(91,212,147,.35);border-radius:999px;padding:7px 10px}.identity{display:grid;grid-template-columns:94px 1fr;gap:14px;padding:16px;position:relative;z-index:1}.photo{width:94px;height:122px;border-radius:18px;background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.03));border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;color:var(--muted);text-align:center;font-size:12px}.photo img{width:100%;height:100%;object-fit:cover}.name{font-size:22px;font-weight:950;margin-bottom:3px}.role{color:#ffe48a;font-weight:850}.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 16px;position:relative;z-index:1}.kv{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:16px;padding:10px}.kv span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.kv b{display:block;margin-top:4px;font-size:14px}.qr{margin:0 16px 16px;border:1px dashed rgba(255,255,255,.32);border-radius:18px;padding:12px;display:grid;grid-template-columns:74px 1fr;gap:12px;align-items:center;background:rgba(255,255,255,.045);position:relative;z-index:1}.qr-link{color:inherit;text-decoration:none}.qrbox{width:74px;height:74px;border-radius:10px;background:repeating-linear-gradient(45deg,#fff 0 5px,#111 5px 10px);border:6px solid #fff;overflow:hidden}.qrbox img{width:100%;height:100%;display:block;background:#fff}.skill-list,.job-list,.audit-list{display:grid;gap:10px}.skill,.job,.audit{border:1px solid var(--line);border-radius:18px;padding:12px;background:rgba(255,255,255,.05)}.skill{display:flex;justify-content:space-between;gap:12px;align-items:center}.bottom-nav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:min(430px,100%);display:flex;background:rgba(7,17,31,.95);backdrop-filter:blur(16px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom));z-index:30}.bottom-nav button{flex:1;background:transparent;border:0;color:var(--muted);font-size:12px;padding:10px 4px;border-radius:14px}.bottom-nav button.active{background:rgba(243,199,77,.16);color:var(--text);font-weight:900}.banner{border:1px solid rgba(243,199,77,.45);background:rgba(243,199,77,.12);border-radius:18px;padding:12px;margin-bottom:14px}.mapbox{height:190px;border-radius:20px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(110,198,232,.16),rgba(255,255,255,.03)),repeating-linear-gradient(0deg,transparent 0 28px,rgba(255,255,255,.05) 29px),repeating-linear-gradient(90deg,transparent 0 28px,rgba(255,255,255,.05) 29px);position:relative;overflow:hidden}.road{position:absolute;background:rgba(255,255,255,.12);border-radius:999px}.road.r1{width:230px;height:22px;left:45px;top:70px;transform:rotate(-22deg)}.road.r2{width:190px;height:18px;right:-20px;bottom:50px;transform:rotate(18deg)}.route-line{position:absolute;left:70px;top:45px;width:210px;height:88px;border-top:5px solid var(--brand);border-right:5px solid var(--brand);border-radius:0 30px 0 0}.pin{position:absolute;width:22px;height:22px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--bad);box-shadow:0 0 0 6px rgba(255,111,97,.15)}.pin:after{content:"";position:absolute;inset:6px;border-radius:50%;background:#fff}.pin.a{left:56px;top:34px;background:var(--ok)}.pin.b{right:70px;bottom:46px}.toast{position:fixed;left:50%;bottom:82px;transform:translateX(-50%);width:min(390px,calc(100% - 28px));background:#f7fbff;color:#07111f;padding:12px 14px;border-radius:16px;box-shadow:var(--shadow);font-weight:850;z-index:50}@media(min-width:760px){.phone-shell{margin:24px auto;min-height:880px;border-radius:34px;overflow:hidden}.bottom-nav{position:absolute;border-radius:0 0 34px 34px}}


/* Branded header treatment */
.brand-topbar{
  background:#ffffff;
  color:#172033;
  border-bottom:1px solid rgba(23,32,51,.10);
  box-shadow:0 12px 30px rgba(3,7,13,.18);
  padding:12px 14px;
}
.topbar-logo-wrap{display:flex;align-items:center;min-width:0;}
.topbar-logo{width:230px;max-width:65vw;height:auto;display:block;}
.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.screen-kicker{
  color:#4f5d72;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  white-space:nowrap;
}
.brand-topbar .ghost{
  color:#12385c;
  border-color:rgba(18,56,92,.22);
  background:rgba(18,56,92,.06);
}
.login-card .brand-logo{width:230px;}
.card-head .brand-logo{width:180px;background:#fff;}
@media(max-width:390px){.topbar-logo{width:190px}.screen-kicker{display:none}.brand-topbar{padding:10px 12px}}

/* Polished header: logo is the brand, not a repeated content block */
.brand-topbar{
  min-height:112px;
  align-items:center;
  padding:16px 14px;
}
.topbar-logo-wrap{flex:1;min-width:0;}
.topbar-logo{
  width:240px;
  max-width:calc(100vw - 165px);
  min-width:190px;
  object-fit:contain;
}
.topbar-actions{margin-left:auto;}
.screen-kicker{display:none!important;}
.login-card{margin-top:50px;}
.login-card .brand-logo{display:none!important;}
.card-head .brand-logo{display:none!important;}
.credential-label{
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#cfe8ff;
}
@media(max-width:390px){
  .brand-topbar{min-height:104px;padding:14px 12px;}
  .topbar-logo{width:218px;min-width:175px;max-width:calc(100vw - 145px);}
  .brand-topbar .ghost{padding:9px 10px;font-size:13px;}
}


/* Inbox and message notification flow */
.nav-badge{display:inline-grid;place-items:center;min-width:17px;height:17px;margin-left:3px;padding:0 4px;border-radius:999px;background:#f3c74d;color:#061320;font-size:10px;font-weight:950;vertical-align:middle}.message-modal{position:fixed;inset:0;z-index:90;display:grid;place-items:end center;padding:16px;background:rgba(3,7,13,.35);backdrop-filter:blur(4px)}.message-sheet{width:min(398px,100%);display:grid;grid-template-columns:42px 1fr;gap:12px;padding:16px;border-radius:24px;background:#f7fbff;color:#07111f;box-shadow:0 28px 70px rgba(0,0,0,.44);border:1px solid rgba(18,56,92,.12)}.message-sheet .muted{color:#526074}.message-sheet h2{margin:2px 0 8px;color:#07111f}.message-sheet p{margin:0 0 14px;line-height:1.45}.message-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#12385c,#6ec6e8);color:#f3c74d;font-size:26px;line-height:1}.message-list{display:grid;gap:10px}.message-item{width:100%;text-align:left;border:1px solid var(--line);border-radius:18px;padding:12px;background:rgba(255,255,255,.05);color:var(--text);display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start}.message-item p{margin:8px 0 0;color:var(--muted);line-height:1.45}.message-item.unread{border-color:rgba(243,199,77,.45);background:rgba(243,199,77,.08)}.message-item.read{opacity:.78}@media(max-width:390px){.bottom-nav button{font-size:11px;padding-left:2px;padding-right:2px}.message-modal{padding:12px}.message-sheet{border-radius:22px}}

/* v8 polish */
.verify.bad{color:#ffd6d6;border-color:rgba(255,111,97,.62);background:rgba(255,111,97,.22)}
.verify.warn{color:#fff0c2;border-color:rgba(243,199,77,.5);background:rgba(243,199,77,.16)}
.suspend-banner{border:1px solid rgba(255,111,97,.62);background:linear-gradient(135deg,rgba(255,111,97,.22),rgba(255,111,97,.08));border-radius:20px;padding:14px;margin-bottom:14px;color:#ffe7e4}
.suspend-banner b{display:block;font-size:16px;margin-bottom:4px}.suspend-banner p{margin:0;color:#ffd7d3;font-size:13px;line-height:1.45}
.suspended-card{background:linear-gradient(145deg,#4b1016,#07111f 78%);border-color:rgba(255,111,97,.44)}
.suspended-card:before{background:rgba(255,111,97,.25)}
.file-picker{display:flex;align-items:center;justify-content:center;min-height:46px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.09);color:var(--text);font-weight:850;cursor:pointer;padding:11px 13px;text-align:center}
.file-picker input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}.file-picker:hover{background:rgba(255,255,255,.13)}
.bio-note{margin-top:8px;line-height:1.4}.status-card{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.06);padding:12px;margin:10px 0 14px}.status-suspended{border-color:rgba(255,111,97,.48);background:rgba(255,111,97,.12)}

.loading-overlay{position:fixed;inset:auto 16px calc(86px + env(safe-area-inset-bottom)) 16px;z-index:70;display:flex;justify-content:center;pointer-events:none}.loading-overlay span{background:#f7fbff;color:#07111f;border-radius:999px;padding:10px 14px;box-shadow:var(--shadow);font-weight:850}.photo.uploading{outline:2px solid rgba(243,199,77,.75);outline-offset:3px}.photo .upload-state{font-weight:850;color:#ffe48a;padding:6px}.verify-expiry{margin-top:8px;color:#ffe48a}.button-busy{opacity:.65;pointer-events:none}

.qr-link{width:calc(100% - 32px);text-align:left;cursor:pointer;font:inherit;color:inherit;text-decoration:none;background:rgba(255,255,255,.045);border:1px dashed rgba(255,255,255,.32);appearance:none;-webkit-appearance:none}.qr-link:hover,.qr-link:focus{border-color:rgba(243,199,77,.65);box-shadow:0 0 0 3px rgba(243,199,77,.12);outline:none}
.verify-modal{position:fixed;inset:0;background:rgba(5,14,25,.72);display:grid;place-items:center;z-index:9999;padding:18px}
.verify-modal-card{position:relative;background:#fff;color:#172034;border-radius:24px;padding:22px;max-width:360px;width:100%;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,.35)}
.modal-close{position:absolute;right:12px;top:10px;border:0;background:#eef3f7;border-radius:999px;width:34px;height:34px;font-size:24px;line-height:1;cursor:pointer;color:#172034}
.qrbox.large{width:260px;height:260px;margin:14px auto;border-radius:18px;background:#fff;position:relative;overflow:hidden;border:1px solid #d7e0ea;display:grid;place-items:center}
.qrbox.large img{width:260px;height:260px;display:block;position:relative;z-index:2}
.qr-fallback{position:absolute;inset:0;display:grid;place-items:center;color:#7f8b99;font-weight:800}
.button-link{display:inline-flex;justify-content:center;text-decoration:none;margin-top:10px}
.verify-url-text{word-break:break-all;color:#5c6675;margin-top:12px}

/* v19: accreditation logos and verification modal polish */
.acc-logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#12385c,#2f6f9f);color:#fff;display:inline-grid;place-items:center;font-size:11px;font-weight:900;letter-spacing:.03em;flex:0 0 auto;box-shadow:0 8px 20px rgba(18,56,92,.22)}
.verify-acc-list{display:grid;gap:8px;margin:10px 0 16px}.verify-acc{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.verify-modal-card h3{margin:14px 0 8px;font-size:15px}.verify-expiry{color:#f3c74d}.skill{align-items:center}
.admin-send-panel textarea{width:100%}

/* v19 polish */
select option{background:#07111f;color:#f7fbff}
select:focus{border-color:rgba(243,199,77,.7);box-shadow:0 0 0 3px rgba(243,199,77,.12)}
.verify-modal-card{background:linear-gradient(180deg,#0b1726,#07111f);color:var(--text);border:1px solid var(--line);text-align:left}
.verify-modal-card .modal-close{color:var(--text)}
.verify-modal-card .qrbox.large{margin:12px auto;background:#fff;border:8px solid #fff;box-shadow:0 10px 28px rgba(0,0,0,.25)}
.verify-modal-card .verify-url-text{color:var(--muted)}
.verify-modal-card .button-link{display:inline-block;text-align:center;text-decoration:none;margin-top:6px;color:#061320}
.verify-modal-card .muted{color:var(--muted)}


/* v20: verification modal polish - keep the surrounding app dark, but use a clean light verifier card so the QR and close control remain readable. */
.verify-modal{background:rgba(3,7,13,.78);backdrop-filter:blur(10px);padding:18px}
.verify-modal-card{background:#f8fbff!important;color:#102033!important;border:1px solid rgba(12,32,55,.12)!important;text-align:center!important;border-radius:26px!important;padding:22px!important;box-shadow:0 28px 90px rgba(0,0,0,.48)!important;overflow:visible}
.verify-modal-card h2{margin:2px 42px 12px;font-size:22px;color:#102033!important;line-height:1.15}
.verify-modal-card .muted{color:#526477!important}.verify-modal-card .small{line-height:1.45}
.verify-modal-card .modal-close{right:12px;top:12px;width:38px;height:38px;border-radius:999px;background:#0b1726!important;color:#fff!important;border:1px solid rgba(255,255,255,.16)!important;box-shadow:0 8px 20px rgba(0,0,0,.22);font-size:24px;line-height:1!important;display:flex;align-items:center;justify-content:center;padding:0 0 2px 0;z-index:3}
.verify-modal-card .modal-close:hover,.verify-modal-card .modal-close:focus{background:#172b44!important;outline:3px solid rgba(243,199,77,.36)}
.verify-modal-card .qrbox.large{margin:14px auto 12px!important;background:#fff!important;border:10px solid #fff!important;border-radius:20px!important;box-shadow:0 16px 34px rgba(8,22,38,.18)!important;width:250px;height:250px;max-width:100%}
.verify-modal-card .qrbox.large img{width:100%;height:100%;object-fit:contain}
.verify-modal-card .button-link{display:block;text-align:center;text-decoration:none;margin:14px 0 0;color:#061320!important;border-radius:15px}
.verify-modal-card .verify-url-text{color:#617287!important;background:#eef4fa;border:1px solid #dce7f2;border-radius:14px;padding:10px;margin-top:12px;font-size:11px;line-height:1.35}
@media(max-width:390px){.verify-modal-card{padding:18px!important}.verify-modal-card .qrbox.large{width:220px;height:220px}.verify-modal-card h2{font-size:20px}}
/* v21 verification-code popup polish */
.verify-code-box{margin:14px 0;padding:14px;border-radius:18px;background:#102843;color:#fff;border:1px solid rgba(18,56,92,.18);display:grid;gap:4px;text-align:center;box-shadow:0 12px 30px rgba(8,22,38,.14)}
.verify-code-box span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#b9d3ef;font-weight:900}.verify-code-box b{font-size:34px;letter-spacing:.18em;font-variant-numeric:tabular-nums;line-height:1.05}.verify-code-box small{font-size:12px;color:#f3c74d}.verify-code-box.muted{background:#eef4fa;color:#102033}.verify-code-box.muted span,.verify-code-box.muted small{color:#526477}.verify-public-help{margin:12px 0;padding:12px;border-radius:16px;background:#eef4fa;border:1px solid #dce7f2;text-align:left;color:#102033}.verify-public-help>b{display:block;margin-bottom:4px}.verify-public-help>span{display:block;color:#526477;font-size:12px;line-height:1.35}.manual-ids{display:grid;grid-template-columns:auto 1fr;gap:4px 8px;margin-top:10px;align-items:center}.manual-ids small{color:#617287;text-transform:uppercase;font-size:10px;letter-spacing:.08em}.manual-ids b{font-size:12px;word-break:break-word}.qr-unavailable{width:100%;border-radius:18px;background:#eef4fa;border:1px dashed #bfd0e1;padding:18px;margin:12px 0;color:#526477;font-weight:850;text-align:center}.verify-modal-card h3{color:#102033!important;margin:14px 0 8px!important;text-align:left}.verify-modal-card .verify-acc-list{text-align:left}

/* v22: inbox/news list controls */
.subtabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0 14px;padding:4px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.045)}
.subtabs button{border:0;border-radius:12px;background:transparent;color:var(--muted);font-weight:850;padding:10px 12px;cursor:pointer}
.subtabs button.active{background:rgba(243,199,77,.18);color:var(--text);box-shadow:inset 0 0 0 1px rgba(243,199,77,.28)}
.scroll-list{max-height:min(54vh,520px);overflow:auto;padding-right:2px;scrollbar-width:thin}
.news-item{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;text-align:left;border:1px solid var(--line);background:rgba(255,255,255,.055);color:var(--text);border-radius:16px;padding:13px;margin:9px 0;cursor:pointer}
.news-item:hover,.news-item:focus{border-color:rgba(243,199,77,.55);outline:none;box-shadow:0 0 0 3px rgba(243,199,77,.11)}
.news-item b{display:block;margin:3px 0 4px}.news-item p{margin:0;color:var(--muted);line-height:1.38}.news-meta{font-size:12px;color:var(--muted);font-weight:750}
/* v23 verification modal compact holder photo */
.verify-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px;text-align:left}
.verify-modal-head h2{margin:0!important;text-align:left!important}
.verify-holder-photo{width:54px;height:54px;border-radius:16px;background:#e8eef4;overflow:hidden;flex:0 0 auto;border:1px solid #dce7f2;box-shadow:0 8px 20px rgba(8,22,38,.12)}
.verify-holder-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* v0.26.1 settings and credential layout */
.credential-strip{position:relative;z-index:1;margin:0 16px 16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.06);padding:12px;display:grid;gap:12px;align-items:center}
.credential-strip.has-logo{grid-template-columns:112px 1fr}
.installer-logo-box{height:58px;border-radius:14px;background:#fff;display:grid;place-items:center;overflow:hidden;padding:8px;box-shadow:0 8px 20px rgba(0,0,0,.12)}
.installer-logo-box img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.credential-facts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.credential-facts>div{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:14px;padding:10px;min-width:0}
.credential-facts span,.settings-row span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}
.credential-facts b,.settings-row b{display:block;margin-top:4px;font-size:14px;word-break:break-word}
.settings-row{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:16px;padding:12px;margin:10px 0 14px}
@media(max-width:390px){.credential-strip.has-logo{grid-template-columns:1fr}.installer-logo-box{height:52px}.credential-facts{grid-template-columns:1fr}}


/* v0.26.2: cog-only settings tab and corrected installer logo layout */
.credential-strip{margin:0 16px 16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.06);padding:12px;display:grid;gap:12px;align-items:stretch}
.credential-strip:not(.has-logo){grid-template-columns:1fr}.credential-strip:not(.has-logo) .credential-facts{grid-template-columns:1fr 1fr}
.credential-strip.has-logo{grid-template-columns:112px 1fr;grid-template-rows:auto auto;gap:12px;align-items:stretch}
.credential-strip.has-logo .installer-logo-box{grid-row:1 / span 2;height:auto;min-height:96px;align-self:stretch}
.credential-strip.has-logo .credential-facts{grid-template-columns:1fr;grid-template-rows:1fr 1fr;gap:10px}
.installer-logo-box img{max-width:100%;max-height:100%;object-fit:contain;display:block}
@media(max-width:390px){.credential-strip.has-logo{grid-template-columns:88px 1fr}.credential-strip.has-logo .installer-logo-box{min-height:88px}.credential-facts b{font-size:13px}}


/* v0.27.0 company/card-logo settings */
.settings-row.stacked{display:block}
.settings-row.stacked label{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.select-input{width:100%;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.08);color:var(--text);padding:12px 14px;font:inherit;outline:none}
.select-input option{background:#fff;color:#14263d}
.choose-logo-note{grid-column:1 / -1;color:var(--gold);font-size:12px;font-weight:750;margin-top:2px}

/* v0.27.3: QR/MFA modal intentionally excludes company logo. Company logos show on the card and public verification page only. */
.verify-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.verify-modal-logo .installer-logo-box{width:86px;min-height:42px;padding:6px;border-radius:12px}
.verify-modal-logo .installer-logo-box img{max-height:34px}

.verify-modal-head.no-logo{justify-content:flex-start;margin-right:42px}
.verify-modal-logo{display:none!important}
/* v0.85.1: hierarchical skill components */
.skill-components{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.skill-chip{display:inline-flex;align-items:center;border-radius:999px;border:1px solid rgba(47,111,159,.22);background:#fff;color:#14263d;font-size:12px;font-weight:700;padding:5px 8px}
.verify-acc.grouped{align-items:flex-start}.verify-acc.grouped span{display:block}

.cpd-rejected-card{background:#fff1f1!important;border-color:#f4c7c7!important}.cpd-rejected-card b{color:#9e1b1b!important}

/* v0.87.10 local audit trail controls */
.audit-scroll{max-height:320px;overflow:auto;padding-right:4px}
.audit-scroll::-webkit-scrollbar{width:8px}.audit-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:999px}
.login-help{margin-top:10px;background:transparent;border:0;color:var(--primary,#12385c);font-weight:700;text-decoration:underline;box-shadow:none;padding:8px 4px}
.login-help:hover{background:transparent;text-decoration:none}

/* v0.90.23 review fixes */
.settings-details{margin-top:12px;border:1px solid rgba(10,38,72,.12);border-radius:16px;background:#fff;padding:12px 14px}
.settings-details summary{cursor:pointer;font-weight:900;color:var(--ink);list-style:none}
.settings-details summary::-webkit-details-marker{display:none}
.settings-details summary:after{content:'+';float:right;color:var(--muted)}
.settings-details[open] summary:after{content:'-'}
.installer-association-row{gap:12px;align-items:center}
.installer-association-row span{display:grid;gap:2px}
.installer-association-row .danger{width:auto;min-height:40px;margin-top:0;padding:8px 12px}

/* v0.90.24: dark-theme settings accordions */
.settings-details{
  margin-top:12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.05);
  color:var(--text);
  padding:12px 14px;
}
.settings-details summary{
  cursor:pointer;
  font-weight:900;
  color:var(--text);
  list-style:none;
  min-height:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.settings-details summary::-webkit-details-marker{display:none}
.settings-details summary:after{content:'+';color:var(--muted);font-weight:900;margin-left:auto}
.settings-details[open] summary:after{content:'-'}
.settings-details[open]{background:rgba(255,255,255,.07)}
.settings-details .muted{color:var(--muted)}
.settings-details .settings-row{background:rgba(255,255,255,.05);border-color:var(--line)}
