:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#17212b;background:#f3f5f7;font-synthesis:none;text-rendering:optimizeLegibility;--ncai-blue: #2c5a88;--ncai-blue-deep: #1f4870;--ncai-blue-soft: #e7eef6;--ncai-orange: #dc8734;--ncai-orange-deep: #b86b21;--ncai-orange-soft: #fbecdc;--ncai-gray: #848688;--ncai-gray-soft: #ecedee;--surface: #ffffff;--surface-strong: #f9fafb;--line: #d9e0e7;--line-strong: #b9c4ce;--muted: #667382;--text: #17212b;--teal: var(--ncai-blue);--teal-soft: var(--ncai-blue-soft);--rose: #b83262;--rose-soft: #fde9f0;--amber: var(--ncai-orange-deep);--amber-soft: var(--ncai-orange-soft);--indigo: #4d5ec9;--indigo-soft: #eceefe;--danger: #b3261e;--danger-soft: #ffebe9;--shadow: 0 16px 38px rgba(22, 33, 43, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#ffffffb8,#f3f5f7e0),#f3f5f7}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}a{color:inherit;text-decoration:none}label{display:grid;gap:7px;color:#43505c;font-size:.9rem;font-weight:650}input,select,textarea{width:100%;min-height:42px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);padding:10px 12px;outline:none}textarea{min-height:92px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px #2c5a8829}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:13px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{color:#526170;font-size:.78rem;letter-spacing:0;text-transform:uppercase;background:#f7f9fb}.auth-page{min-height:100vh;display:grid;grid-template-columns:minmax(320px,1.05fr) minmax(320px,440px);align-items:center;gap:32px;padding:42px}.auth-hero{display:grid;gap:20px;max-width:760px}.auth-hero h1{margin:0;font-size:clamp(2.6rem,6vw,5rem);line-height:.96;letter-spacing:0}.auth-hero p{margin:0;max-width:620px;color:var(--muted);font-size:1.1rem;line-height:1.7}.auth-card,.auth-hero,.content>section,.page-grid>section,.workspace-main,.workspace-list{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.auth-card{padding:26px}.auth-card.compact{max-width:440px;width:100%;justify-self:center}.auth-hero{padding:36px;min-height:480px;justify-content:center;background:radial-gradient(circle at 88% 12%,rgba(220,135,52,.18),transparent 55%),radial-gradient(circle at 8% 92%,rgba(44,90,136,.18),transparent 60%),linear-gradient(135deg,#2c5a881a,#dc87340f),#fff}.brand-logo{width:200px;max-width:100%;height:auto;margin-bottom:8px}.brand-tagline{margin:-4px 0 14px;color:var(--ncai-blue-deep);font-weight:600;letter-spacing:.02em}.brand-mark{width:58px;height:58px;display:grid;place-items:center;border-radius:8px;background:#17212b;color:#fff}.brand-mark.small{width:38px;height:38px}.demo-grid{display:grid;gap:10px;margin-top:12px}.demo-grid span{display:inline-flex;width:fit-content;max-width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 11px;color:#33404d;background:#ffffffc7;overflow-wrap:anywhere}.auth-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:4px;margin-bottom:20px;background:#eef2f5;border-radius:8px}.auth-tabs button{border:0;border-radius:6px;padding:10px;background:transparent;color:#526170;font-weight:750}.auth-tabs button.active{background:#fff;color:var(--text);box-shadow:0 1px 4px #141f2b1f}.portal-shell{min-height:100vh;display:grid;grid-template-columns:270px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;padding:18px;color:#ecf2f1;background:#17212b;border-right:1px solid rgba(255,255,255,.08)}.sidebar-brand{display:flex;align-items:center;gap:12px;min-height:60px;margin-bottom:22px}.sidebar-brand-logo{width:44px;height:44px;object-fit:contain;background:#fff;border-radius:8px;padding:4px;flex:0 0 auto}.sidebar-brand strong,.sidebar-brand span{display:block}.sidebar-brand span{margin-top:3px;color:#a8b7c3;font-size:.82rem}.sidebar nav{display:grid;gap:6px}.sidebar nav button{display:flex;align-items:center;gap:10px;min-height:42px;padding:10px 11px;border:0;border-radius:8px;color:#cbd5df;background:transparent;text-align:left;font-weight:700}.sidebar nav button:hover,.sidebar nav button.active{color:#fff;background:#ffffff1a}.main-area{min-width:0}.topbar{position:sticky;top:0;z-index:15;display:grid;grid-template-columns:minmax(240px,620px) auto;align-items:center;gap:18px;min-height:76px;padding:14px 24px;background:#f3f5f7eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.mobile-menu{display:none!important}.topbar-user{display:flex;align-items:center;justify-self:end;gap:10px;min-width:0}.topbar-user div:not(.avatar){display:grid;min-width:0}.topbar-user strong,.topbar-user span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-user span{color:var(--muted);font-size:.82rem}.content{padding:24px}.content>section,.page-grid>section,.workspace-main,.workspace-list{padding:22px}.page-grid{display:grid;grid-template-columns:minmax(280px,.72fr) minmax(0,1.28fr);gap:20px}.page-grid.no-pad{margin-top:20px}.wide{grid-column:span 2}.section-title{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}.section-title>svg{flex:0 0 auto;color:var(--teal);margin-top:3px}.section-title h2{margin:0;font-size:1.25rem;line-height:1.25;letter-spacing:0}.section-title h3{margin:0}.section-title p{margin:3px 0 0;color:var(--muted);line-height:1.45}.section-action{margin-left:auto}.stack{display:grid;gap:14px}.two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.divider-top{margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}.check-line{display:flex;align-items:center;gap:9px}.check-line input{width:18px;min-height:18px}.button-row{display:flex;align-items:center;gap:9px}.button-row.wrap{flex-wrap:wrap}.primary,.secondary,.ghost,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:8px;border:1px solid transparent;padding:9px 13px;font-weight:800}.primary{color:#fff;background:var(--teal);border-color:var(--teal)}.primary:hover{background:#0d665f}.secondary{color:#21313f;background:#eef7f6;border-color:#b8ded9}.ghost{color:#263542;background:#fff;border-color:var(--line)}.ghost:hover{background:#f5f8fa}.danger-text{color:var(--danger)}.wide{width:100%}.icon-button{width:40px;min-width:40px;padding:0;color:#263542;background:#fff;border-color:var(--line)}.icon-button.solid{color:#fff;background:var(--teal);border-color:var(--teal)}.alert{padding:11px 12px;border-radius:8px;line-height:1.45;overflow-wrap:anywhere}.alert.danger{color:var(--danger);background:var(--danger-soft);border:1px solid #ffc7c2}.alert.success{color:#116149;background:#e4f7ef;border:1px solid #bde7d4}.loader{width:34px;height:34px;border:4px solid #dce5ea;border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search{position:relative;display:flex;align-items:center;gap:8px;min-width:0;background:#fff;border:1px solid var(--line);border-radius:8px;padding:0 12px}.search input{border:0;box-shadow:none;min-height:44px;padding-left:0}.search-results{position:absolute;z-index:30;top:calc(100% + 8px);left:0;right:0;display:grid;gap:4px;padding:8px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow)}.search-results a{display:grid;gap:3px;padding:9px;border-radius:6px}.search-results a:hover{background:#f4f7f9}.search-results span{color:var(--muted);font-size:.82rem}.avatar{width:38px;height:38px;border-radius:8px;object-fit:cover;flex:0 0 auto}.avatar.small{width:30px;height:30px}.avatar.tiny{width:24px;height:24px;border-radius:6px;font-size:.72rem}.avatar.large{width:116px;height:116px;border-radius:8px;font-size:2rem}.avatar.fallback{display:grid;place-items:center;background:#e8f2f1;color:#0d665f;font-weight:900}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px}.stat-card{display:flex;align-items:center;gap:12px;min-height:92px;padding:17px;border:1px solid var(--line);border-radius:8px}.stat-card span,.stat-card strong{display:block}.stat-card span{color:var(--muted);font-size:.86rem}.stat-card strong{margin-top:5px;font-size:1.65rem;letter-spacing:0}.stat-card.teal{background:var(--teal-soft)}.stat-card.rose{background:var(--rose-soft)}.stat-card.amber{background:var(--amber-soft)}.stat-card.indigo{background:var(--indigo-soft)}.stat-card.teal svg{color:var(--teal)}.stat-card.rose svg{color:var(--rose)}.stat-card.amber svg{color:var(--amber)}.stat-card.indigo svg{color:var(--indigo)}.list{display:grid;gap:9px}.list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:58px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.list-row div{display:grid;gap:3px;min-width:0}.list-row strong,.list-row span,.list-row p{overflow-wrap:anywhere}.list-row span,.list-row time{color:var(--muted);font-size:.86rem}.activity-table{display:grid;gap:0;border:1px solid var(--line);border-radius:8px;overflow:hidden}.activity-table div{display:grid;grid-template-columns:140px 190px minmax(0,1fr);gap:12px;padding:12px;background:#fff;border-bottom:1px solid var(--line)}.activity-table div:last-child{border-bottom:0}.activity-table span{color:var(--muted);font-size:.85rem}.activity-table p{margin:0}.program-list{display:grid;gap:13px}.compact-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.program-card{display:grid;grid-template-columns:110px minmax(0,1fr);border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden}.program-banner{display:grid;place-items:center;min-height:150px;color:#fff;background:linear-gradient(135deg,#2c5a88f5,#1f4870eb),#2c5a88}.program-banner.participant{background:linear-gradient(135deg,#b83262e6,#9a6200db),#b83262}.program-body{display:grid;gap:14px;padding:16px}.program-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.program-heading>div{display:grid;gap:4px;min-width:0}.program-heading strong{font-size:1rem;overflow-wrap:anywhere}.program-heading span:not(.status){color:var(--muted);line-height:1.4}.status{display:inline-flex;align-items:center;width:fit-content;max-width:100%;min-height:24px;padding:3px 8px;border-radius:999px;color:#33404d;background:#edf2f5;font-size:.76rem;font-weight:850;text-transform:capitalize;white-space:nowrap}.status.active,.status.reviewed{color:#0e6048;background:#dff4ed}.status.upcoming,.status.submitted{color:#704900;background:#ffefc2}.status.completed{color:#3442a5;background:#e5e8ff}.status.archived,.status.inactive,.status.needs-revision{color:var(--danger);background:var(--danger-soft)}.meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.meta-grid span,.chips span{min-height:28px;display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;color:#4d5b68;background:#f1f4f6;font-size:.82rem;overflow-wrap:anywhere}.chips{display:flex;flex-wrap:wrap;gap:7px}.batch-list{display:grid;gap:10px}.batch-row{display:grid;gap:9px;padding-top:10px;border-top:1px solid var(--line)}.batch-row:first-child{padding-top:0;border-top:0}.batch-row-header,.batch-row-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.batch-row-header>div{display:grid;gap:3px;min-width:0}.batch-row-header span:not(.status),.batch-row-meta{color:var(--muted);font-size:.84rem}.batch-row-meta{display:flex;flex-wrap:wrap;gap:10px}.batch-date-controls{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:10px}.batch-date-controls label{gap:5px;color:var(--muted);font-size:.78rem}.batch-date-controls input{min-height:38px}.compact-fields{display:grid;gap:12px}.batch-row-actions{align-items:center;flex-wrap:wrap}.batch-row-actions select{min-width:150px;max-width:190px}.table-wrap{width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:8px}.person-cell{display:flex;align-items:center;gap:8px;min-width:180px}.credential-box{display:grid;gap:5px;margin-top:16px;padding:13px;border:1px solid #b8ded9;border-radius:8px;background:#eef7f6;overflow-wrap:anywhere}.bulk-textarea{min-height:150px}.bulk-result{gap:10px}.credential-row{display:grid;grid-template-columns:minmax(120px,1.2fr) minmax(90px,1fr) minmax(110px,1fr);gap:8px;padding:8px;border:1px solid #b8ded9;border-radius:8px;background:#fff}.credential-row span,.credential-row strong{overflow-wrap:anywhere}.module-list{display:grid;gap:12px}.module-row{display:grid;gap:14px;padding:15px;border:1px solid var(--line);border-radius:8px;background:#fff}.module-row.selected{border-color:var(--teal);box-shadow:0 0 0 3px #2c5a8829}.module-row.locked{background:#fafbfc}.module-row>div:first-child{display:grid;gap:6px}.module-row span{color:var(--muted)}.content-header{display:flex!important;align-items:flex-start;justify-content:space-between;gap:14px}.content-header>div:first-child{display:grid;gap:6px;min-width:0}.content-subsection{display:grid;gap:9px}.content-subsection h3{margin:0;color:#43505c;font-size:.9rem}.content-items{display:grid;gap:8px}.content-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd}.content-item>div:first-child{display:grid;gap:3px;min-width:0}.content-item strong,.content-item span{overflow-wrap:anywhere}.content-item.editable,.edit-panel{display:grid;gap:10px}.edit-panel{padding:12px;border:1px solid #b8ded9;border-radius:8px;background:#eef7f6}.assignment-editor{margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}.target-note{min-height:34px;display:flex;align-items:center;padding:7px 10px;border:1px solid #b8ded9;border-radius:8px;color:#0d665f;background:#eef7f6;font-weight:750;overflow-wrap:anywhere}.muted-text{color:var(--muted);font-size:.9rem}.material-list{display:flex;flex-wrap:wrap;gap:8px}.material-list a,.file-link{display:inline-flex;align-items:center;gap:7px;min-height:34px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#263542;font-weight:700;overflow-wrap:anywhere}.tool-grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px;margin-top:18px}.tool-grid form{padding:14px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd}.tool-grid h3,.stack h3{margin:0;font-size:1rem}.submission-grid,.certificate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.submission-card,.assignment-card,.certificate-card{display:grid;gap:12px;padding:15px;border:1px solid var(--line);border-radius:8px;background:#fff}.certificate-card{align-items:center;grid-template-columns:auto minmax(0,1fr) auto}.certificate-card>svg{color:var(--amber)}.certificate-card div{display:grid;gap:4px;min-width:0}.certificate-card span,.certificate-card small{color:var(--muted);overflow-wrap:anywhere}.workspace-layout{display:grid;grid-template-columns:310px minmax(0,1fr);gap:20px}.workspace-list{align-self:start;display:grid;gap:10px;position:sticky;top:100px}.workspace-item{display:grid;gap:6px;width:100%;padding:13px;border:1px solid var(--line);border-radius:8px;background:#fff;text-align:left}.workspace-item.active{border-color:var(--teal);background:#eef7f6}.workspace-item span{color:var(--muted)}.program-workspace{display:grid;gap:18px}.progress{position:relative;height:13px;border-radius:999px;background:#e2e8ee;overflow:hidden}.progress.compact{height:8px}.progress span{display:block;height:100%;background:var(--teal)}.progress strong{position:absolute;top:-2px;right:7px;color:#17212b;font-size:.73rem}.lesson-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.lesson{display:inline-flex;align-items:center;gap:7px;max-width:100%;min-height:36px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;color:#263542;background:#fff;font-weight:750}.lesson.done{color:#0e6048;background:#e4f7ef;border-color:#bde7d4}.lesson span{color:inherit}.lock-note{display:inline-flex;align-items:center;gap:5px;width:fit-content;color:var(--danger)!important}.comments{display:grid;gap:9px;padding-top:10px;border-top:1px solid var(--line)}.comment,.chat-message{display:flex;gap:8px;align-items:flex-start}.comment div,.chat-message div{display:grid;gap:2px;min-width:0}.comment p,.chat-message p{margin:0;color:#3c4a57;overflow-wrap:anywhere}.comment-form,.chat-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.chat-box{display:grid;grid-template-rows:minmax(220px,360px) auto;gap:10px}.chat-box.tall{grid-template-rows:minmax(360px,calc(100vh - 330px)) auto}.chat-messages{display:grid;align-content:start;gap:10px;overflow-y:auto;padding:12px;border:1px solid var(--line);border-radius:8px;background:#f8fafb}.chat-message{max-width:80%;padding:8px;border-radius:8px;background:#fff;border:1px solid var(--line)}.chat-message.mine{justify-self:end;background:#eaf7f6;border-color:#b8ded9}.compact-label{max-width:420px;margin-bottom:14px}.profile-card{display:grid;justify-items:start;gap:14px}.upload-label{display:inline-flex;align-items:center;gap:8px;width:fit-content;min-height:40px;padding:9px 13px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}.upload-label input{display:none}.empty-state{display:grid;justify-items:center;gap:8px;padding:34px 16px;border:1px dashed var(--line-strong);border-radius:8px;color:var(--muted);text-align:center}.empty-state strong{color:var(--text)}.dot{width:9px;height:9px;border-radius:999px;background:var(--rose);flex:0 0 auto}@media(max-width:1180px){.stats-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.tool-grid{grid-template-columns:1fr}}@media(max-width:960px){.auth-page,.portal-shell,.page-grid,.workspace-layout{grid-template-columns:1fr}.auth-page{padding:20px}.auth-hero{min-height:auto}.wide{grid-column:auto}.sidebar{position:fixed;z-index:40;left:0;top:0;width:270px;transform:translate(-100%);transition:transform .18s ease}.sidebar.open{transform:translate(0)}.topbar{grid-template-columns:auto minmax(0,1fr);grid-template-areas:"menu user" "search search"}.mobile-menu{display:inline-flex!important;grid-area:menu}.search{grid-area:search}.topbar-user{grid-area:user}.workspace-list{position:static}.activity-table div{grid-template-columns:1fr}}@media(max-width:680px){.content,.topbar{padding:14px}.auth-card,.auth-hero,.content>section,.page-grid>section,.workspace-main,.workspace-list{padding:16px}.stats-grid,.two-column,.compact-list,.program-card{grid-template-columns:1fr}.program-banner{min-height:76px}.meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.program-heading,.list-row,.content-header,.content-item,.credential-row,.certificate-card{align-items:stretch;flex-direction:column;grid-template-columns:1fr}.certificate-card .primary{width:100%}.chat-message{max-width:100%}}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:18px 14px;border:1px dashed #b8c2cc;border-radius:10px;color:#54616d;background:#f8fafc;cursor:pointer;text-align:center}.drop-zone.active{border-color:#2c5a88;background:#e8f1f1;color:#2c5a88}.drop-zone .file-list{list-style:none;margin:4px 0 0;padding:0;font-size:12px;color:#374151;max-height:120px;overflow-y:auto;width:100%;text-align:left}.drop-zone .file-list li{padding:2px 0;border-top:1px solid #e5e7eb}.bulk-action-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:10px;font-size:13px}.bulk-action-bar select{flex:1;min-width:0}.filter-bar{display:flex;gap:8px;margin:8px 0 12px;flex-wrap:wrap}.filter-bar input,.filter-bar select{padding:8px 10px;border:1px solid #d1d5db;border-radius:8px;font:inherit;background:#fff}.filter-bar input{flex:1;min-width:220px}.row-editing td{vertical-align:top;padding-top:10px;background:#f8fafc}.material-card-pinned{border-left:3px solid #f59e0b}.material-tag{display:inline-block;padding:2px 7px;margin:0 4px 4px 0;border-radius:999px;background:#e0e7ff;color:#3730a3;font-size:11px}.material-description{display:block;color:#4b5563;font-size:12px;margin-top:4px}.preview-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.preview-modal .preview-frame{background:#fff;border-radius:12px;width:min(1100px,100%);height:min(80vh,800px);display:flex;flex-direction:column;overflow:hidden}.preview-modal .preview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e5e7eb}.preview-modal iframe,.preview-modal img{width:100%;height:100%;border:0;object-fit:contain;background:#1f2937}.drag-handle{cursor:grab;color:#9ca3af;padding:4px 6px;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.row-dragging{opacity:.5}.kv-grid{display:grid;grid-template-columns:minmax(140px,max-content) 1fr;gap:6px 14px;font-size:13px;align-items:baseline}.kv-grid>span{color:var(--muted);font-weight:600}.kv-grid>strong{color:var(--text);font-weight:500;word-break:break-word}.material-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:6px;background:#fff}.material-row>div:first-child{flex:1;min-width:0}.material-row strong{display:block}.list-row.pinned{border-left:3px solid #f59e0b}.portal-footer{margin-top:28px;border-top:1px solid var(--line);background:linear-gradient(180deg,#fff0,#e7eef699);padding:22px 32px 26px;font-size:.82rem;color:var(--muted)}.portal-footer-row{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr auto;gap:18px;align-items:center}.portal-footer-brand{display:flex;align-items:center;gap:12px}.portal-footer-brand img{width:40px;height:40px;object-fit:contain;background:#fff;border-radius:6px;padding:3px}.portal-footer-brand strong{color:var(--ncai-blue);display:block;font-size:.92rem}.portal-footer-brand span{display:block;margin-top:2px}.portal-footer-meta{display:flex;flex-direction:column;gap:4px;text-align:left}.portal-footer-meta a{color:var(--ncai-blue);font-weight:600;width:fit-content}.portal-footer-meta a:hover{text-decoration:underline}.portal-footer-social{display:flex;gap:8px}.portal-footer-social a{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;background:var(--ncai-blue-soft);color:var(--ncai-blue);transition:background .15s ease}.portal-footer-social a:hover{background:var(--ncai-blue);color:#fff}@media(max-width:760px){.portal-footer-row{grid-template-columns:1fr;text-align:left}.portal-footer-social{justify-content:flex-start}}.cert-field-row{border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;margin-bottom:8px;background:#fff}.cert-field-row>strong{display:block;text-transform:capitalize;margin-bottom:6px;color:#1f2937;font-size:13px}.cert-field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;align-items:end}.cert-field-grid label{display:flex;flex-direction:column;gap:2px;font-size:11px;color:#6b7280}.cert-field-grid input,.cert-field-grid select{font:inherit;padding:6px 8px;border:1px solid #d1d5db;border-radius:6px}.cert-preview{position:relative;width:100%;aspect-ratio:842 / 595;background-color:#fff;background-size:cover;background-position:center;background-repeat:no-repeat;border:1px solid #d1d5db;border-radius:6px;overflow:hidden;margin-bottom:16px}.cert-field-marker{position:absolute;pointer-events:none;white-space:nowrap;transform:translate(-50%,-50%);outline:1px dashed rgba(44,90,136,.45);padding:1px 4px;background:#fff9}.cert-field-marker.text{min-width:6px}.cert-field-marker.qr{background:#2c5a8826;border:1px solid rgba(44,90,136,.5);outline:none;display:flex;align-items:center;justify-content:center;font-size:10px;color:#2c5a88;transform:translate(0)}.cert-field-marker.qr:after{content:"QR"}.cert-field-marker.sig{background:#f59e0b2e;border:1px dashed rgba(245,158,11,.6);outline:none;font-size:11px;color:#92400e;text-align:center;padding:6px 0;transform:translate(0)}.batch-checklist{display:flex;flex-direction:column;gap:4px;max-height:140px;overflow-y:auto;padding:4px 6px;border:1px solid #e5e7eb;border-radius:6px;font-size:12px}.batch-checklist .check-line{gap:6px;margin:0}.cert-preview-watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:88px;color:#dc26264d;font-weight:700;transform:rotate(-22deg);pointer-events:none}
