/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--radius-lg:.5rem;--radius-xl:.75rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#07111f;--bg-soft:#0d1d34;--bg-panel:#071222eb;--bg-panel-strong:#081629fa;--bg-card:#ffffffe0;--bg-card-hover:#fffffff2;--ccb-gold:#c9a84c;--ccb-gold-strong:#d4b05e;--ccb-gold-soft:#c9a84c26;--ccb-gold-border:#c9a84c52;--xjtu-red:#b5322b;--xjtu-red-soft:#b5322b26;--foreground:#ebf3ff;--foreground-strong:#f8fbff;--ink:#12233f;--ink-muted:#566c8f;--ink-light:#8aa3c2;--primary:#0056b8;--primary-strong:#0b6fda;--primary-soft:#207fff24;--secondary:#0c2f66;--accent:#6cc0ff;--accent-strong:#9bddff;--border:#7da6d342;--border-strong:#6ab3ff7a;--border-card:#a1bddc5c;--success:#22c55e;--success-soft:#22c55e26;--warning:#f59e0b;--warning-soft:#f59e0b26;--danger:#ef4444;--danger-soft:#ef444426;--shadow-strong:0 28px 70px #020b1873;--shadow-soft:0 8px 32px #0b1c3829;--shadow-gold:0 8px 24px #c9a84c47;--shadow-blue:0 16px 40px #0056b83d;--radius-xl:32px;--radius-lg:24px;--radius-md:18px;--radius-sm:14px;--radius-xs:10px;--font-display:"DengXian","Microsoft YaHei UI","PingFang SC","Segoe UI",sans-serif;--font-body:"Microsoft YaHei UI","PingFang SC","Segoe UI",sans-serif;--font-mono:"Bahnschrift","Consolas",monospace;--transition:.22s cubic-bezier(.16,1,.3,1)}*{box-sizing:border-box}html{color-scheme:dark;scroll-behavior:smooth}body{min-height:100vh;color:var(--foreground);font-family:var(--font-body);letter-spacing:.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#207fff57,#0000 26%),radial-gradient(circle at 100% 0,#4ca8ff2e,#0000 22%),radial-gradient(circle at 50% 100%,#11428c6b,#0000 28%),linear-gradient(140deg,#07111f,#0a1830 38%,#081626);margin:0}body:before{opacity:.4;background-color:#0000;background-image:linear-gradient(#84addd0f 1px,#0000 0),linear-gradient(90deg,#84addd0f 1px,#0000 0);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:36px 36px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;-webkit-mask-image:linear-gradient(#000000b3,#0000 85%);mask-image:linear-gradient(#000000b3,#0000 85%)}body:after,body:before{content:"";pointer-events:none;z-index:0;position:fixed;inset:0}body:after{mix-blend-mode:soft-light;opacity:.18;background:radial-gradient(circle,#ffffff24 0,#0000 58%) 0 0/8px 8px}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #c9a84c00}50%{box-shadow:0 0 0 8px #c9a84c1f}}@keyframes fillBar{0%{opacity:0;width:0}to{opacity:1}}.app-shell{z-index:1;width:min(1440px,100% - 40px);margin:0 auto;position:relative}.page-section{padding:24px 0 32px}.glass-panel{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);color:var(--ink);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);background:#ffffffe6;border:1px solid #a1bddc5c}.glass-panel:hover{border-color:#0056b82e;transform:translateY(-2px);box-shadow:0 16px 40px #0056b81f}.ccb-shell{grid-template-columns:280px minmax(0,1fr);gap:22px;min-height:calc(100vh - 56px);display:grid}.ccb-sidebar{border-radius:var(--radius-xl);height:calc(100vh - 48px);box-shadow:var(--shadow-strong);background:linear-gradient(#08182ef5,#061224f0);border:1px solid #77b5ff2e;padding:26px 22px;position:sticky;top:24px;overflow:hidden}.ccb-sidebar:before{content:"";pointer-events:none;background:radial-gradient(circle at 0 0,#7dc4ff3d,#0000 28%),linear-gradient(#ffffff0f,#0000 30%);position:absolute;inset:0}.ccb-sidebar-inner{z-index:1;flex-direction:column;height:100%;display:flex;position:relative}.ccb-brand{border-bottom:1px solid #84b4e52e;padding-bottom:20px}.ccb-brand-mark{width:48px;height:48px;color:var(--foreground-strong);font-family:var(--font-display);background:linear-gradient(135deg,#c9a84c66,#0056b880);border:1px solid #c9a84c52;border-radius:18px;justify-content:center;align-items:center;font-size:18px;font-weight:800;display:inline-flex;box-shadow:0 4px 16px #c9a84c33}.ccb-brand h1{font-family:var(--font-display);white-space:nowrap;margin:16px 0 8px;font-size:24px;line-height:1.15}.ccb-brand h1,.ccb-brand p{text-overflow:ellipsis;overflow:hidden}.ccb-brand p{color:#deecffb8;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:14px;line-height:1.7;display:-webkit-box}.ccb-role-chip{color:#ecf5ffe6;background:#c9a84c1f;border:1px solid #c9a84c3d;border-radius:999px;align-items:center;gap:8px;margin-top:16px;padding:8px 12px;font-size:13px;display:inline-flex}.ccb-nav{gap:6px;margin-top:26px;display:grid}.ccb-nav-link{color:#e1eeffb8;transition:var(--transition);border:1px solid #0000;border-radius:16px;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;font-size:14px;font-weight:500;display:flex;position:relative}.ccb-nav-link span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.ccb-nav-link small{flex-shrink:0}.ccb-nav-link:hover{color:var(--foreground-strong);background:#ffffff0f;border-color:#91cbff29}.ccb-nav-link-active{color:var(--foreground-strong);background:linear-gradient(135deg,#0f63d275,#54adff24);border-color:#91cbff47;box-shadow:inset 0 0 0 1px #b1ddff14}.ccb-nav-link-active:before{content:"";background:linear-gradient(180deg,var(--ccb-gold),var(--primary-strong));border-radius:999px;width:4px;position:absolute;top:10px;bottom:10px;left:-6px}.ccb-sidebar-footer{color:#cde1f9b8;border-top:1px solid #84b4e52e;margin-top:auto;padding:18px 0 0;font-size:13px;line-height:1.7}.ccb-sidebar-footer,.ccb-sidebar-footer div{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ccb-main{gap:18px;min-width:0;display:grid}.ccb-topbar{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#081427b3;border:1px solid #7ba8da29;justify-content:space-between;gap:18px;padding:16px 22px}.ccb-topbar,.ccb-topbar-meta{align-items:center;display:flex}.ccb-topbar-meta{color:#dbe9fbc2;flex-wrap:wrap;gap:12px;min-width:0;font-size:13px}.ccb-topbar-meta span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ccb-topbar-slot{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ccb-chip{color:#d9ecff;letter-spacing:.02em;background:#70b5ff1f;border:1px solid #7cbcff38;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.ccb-chip-light{color:var(--ink);background:#0466cc14;border-color:#0568c91f}.ccb-chip-gold{color:var(--ccb-gold);background:#c9a84c1a;border-color:#c9a84c33}.ccb-badge-excellent{background:var(--success-soft);color:var(--success)}.ccb-badge-excellent,.ccb-badge-good{border-radius:20px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.ccb-badge-good{background:var(--ccb-gold-soft);color:var(--ccb-gold)}.ccb-badge-average{background:var(--primary-soft);color:var(--accent)}.ccb-badge-average,.ccb-badge-warning{border-radius:20px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.ccb-badge-warning{background:var(--warning-soft);color:var(--warning)}.ccb-badge-danger{background:var(--danger-soft);color:var(--danger);border-radius:20px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.ccb-hero{border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);color:var(--ink);background:linear-gradient(135deg,#f7fbfff7,#e0ecfae0);border:1px solid #a6c1e057;padding:44px 40px;position:relative;overflow:hidden}.ccb-hero:before{background:radial-gradient(circle at 100% 0,#006eff29,#0000 30%),radial-gradient(circle at 0 100%,#c9a84c14,#0000 35%),linear-gradient(90deg,#ffffff8c,#0000 50%);inset:0}.ccb-hero:after,.ccb-hero:before{content:"";pointer-events:none;position:absolute}.ccb-hero:after{background:radial-gradient(circle,#0056b81f 0,#0000 70%);border-radius:999px;width:320px;height:320px;top:-40px;right:-40px}.ccb-hero-grid{z-index:1;grid-template-columns:minmax(0,1.5fr) minmax(280px,.9fr);align-items:center;gap:28px;display:grid;position:relative}.ccb-eyebrow{color:#7a5c10;letter-spacing:.02em;background:linear-gradient(135deg,#c9a84c1f,#0056b814);border:1px solid #c9a84c3d;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:700;display:inline-flex}.ccb-hero h1,.ccb-page-title{color:#091a34;font-family:var(--font-display);letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;margin:18px 0 14px;font-size:clamp(28px,3.5vw,42px);line-height:1.1;overflow:hidden}.ccb-hero p,.ccb-page-subtitle{color:var(--ink-muted);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:520px;margin:0;font-size:15px;line-height:1.85;display:-webkit-box;overflow:hidden}.ccb-hero-actions{flex-wrap:wrap;gap:12px;margin-top:26px;display:flex}.ccb-button,.ccb-button-ghost,.ccb-button-secondary{letter-spacing:.02em;cursor:pointer;min-height:46px;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition),background var(--transition);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:0 22px;font-size:14px;font-weight:700;display:inline-flex}.ccb-button{background:linear-gradient(135deg,var(--primary) 0,var(--primary-strong) 100%);color:#fff;box-shadow:var(--shadow-blue)}.ccb-button:hover{transform:translateY(-2px);box-shadow:0 20px 48px #0056b85c}.ccb-button-secondary{color:#10345f;background:#ffffffd1;border:1.5px solid #0056b82e}.ccb-button-secondary:hover{background:#fffffff5;border-color:#0056b852;transform:translateY(-2px);box-shadow:0 8px 24px #0056b81f}.ccb-button-ghost{color:#10345f;background:#ffffff24;border:1.5px solid #0056b847;font-weight:700}.ccb-button-ghost:hover{background:#ffffff47;border-color:#0056b870;transform:translateY(-2px)}.ccb-button-gold{cursor:pointer;background:linear-gradient(135deg,var(--ccb-gold) 0,#a88a3a 100%);color:#1a0e00;min-height:46px;box-shadow:var(--shadow-gold);transition:transform var(--transition),box-shadow var(--transition);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:0 22px;font-size:14px;font-weight:700;display:inline-flex}.ccb-button-gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px #c9a84c66}.ccb-stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.ccb-stat-card{transition:transform var(--transition),box-shadow var(--transition);background:linear-gradient(135deg,#c9a84c14,#ffffffb8);border:1px solid #c9a84c2e;border-radius:20px;padding:22px 20px;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff80,0 4px 12px #0000000f}.ccb-stat-card:before{content:"";background:linear-gradient(90deg,var(--ccb-gold),transparent);border-radius:20px 20px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.ccb-stat-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #c9a84c29}.ccb-stat-card strong{font-family:var(--font-mono);color:var(--ccb-gold);letter-spacing:-.02em;font-size:38px;line-height:1;display:block}.ccb-stat-card span{color:#416385;white-space:nowrap;margin-top:10px;font-size:13px;font-weight:500;display:block}.ccb-stat-card p,.ccb-stat-card span{text-overflow:ellipsis;overflow:hidden}.ccb-stat-card p{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box}.ccb-section{gap:18px;display:grid}.ccb-panel{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);color:var(--ink);background:#f6fafff2;border:1px solid #b2cce95c;padding:28px;animation:fadeIn .4s forwards}.ccb-panel-dark{color:var(--foreground);background:linear-gradient(160deg,#09182cf5,#061224fa);border-color:#7cbaff29}.ccb-panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.ccb-panel-header h2,.ccb-panel-header h3{font-family:var(--font-display);letter-spacing:.02em;margin:0;font-size:22px;line-height:1.15}.ccb-panel-header p{color:var(--ink-muted);margin:8px 0 0;font-size:14px;line-height:1.7}.ccb-panel-header h2:before{content:"";background:linear-gradient(180deg,var(--ccb-gold),var(--primary));vertical-align:middle;border-radius:2px;width:4px;height:20px;margin-right:10px;display:inline-block}.ccb-panel-dark .ccb-panel-header h2:before{background:linear-gradient(180deg,var(--ccb-gold),var(--accent))}.ccb-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.ccb-toolbar-group{flex-wrap:wrap;gap:10px;display:flex}.ccb-input,.ccb-search,.ccb-select{color:#173154;background:#ffffffd1;border:1.5px solid #8fb5dc52;border-radius:12px;outline:none;min-height:44px;padding:0 14px;font-size:14px;transition:border-color .18s,box-shadow .18s,background .18s}.ccb-input:focus,.ccb-search:focus,.ccb-select:focus{background:#fffffff5;border-color:#0056b86b;box-shadow:0 0 0 4px #0056b81a}.ccb-grid{gap:16px;display:grid}.ccb-grid-columns-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.ccb-grid-columns-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.ccb-table-wrap{border:1px solid #b2cce957;border-radius:18px;overflow:auto;box-shadow:0 2px 12px #0000000a}.ccb-table{border-collapse:collapse;background:#ffffffc7;width:100%}.ccb-table thead th{color:#33537c;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;background:linear-gradient(#e4eefafa,#d6e5f6eb);border-bottom:1px solid #b2cce957;padding:14px 18px;font-size:12px;font-weight:800}.ccb-table tbody tr{border-top:1px solid #b2cce938;transition:background-color .16s}.ccb-table tbody tr:hover{background:#0056b80a}.ccb-table td{color:#173154;vertical-align:middle;text-overflow:ellipsis;white-space:nowrap;max-width:260px;padding:14px 18px;font-size:14px;overflow:hidden}.ccb-td-wrap{white-space:normal!important;max-width:480px!important}.ccb-table td a{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.ccb-kpi{align-items:baseline;gap:10px;display:flex}.ccb-kpi strong{font-family:var(--font-mono);color:var(--ccb-gold);font-size:36px;line-height:1}.ccb-kpi span{color:var(--ink-muted);font-size:13px}.ccb-person-card{box-shadow:var(--shadow-soft);color:var(--ink);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);background:linear-gradient(160deg,#f8fbfffa,#e7eff9eb);border:1px solid #adcbec57;border-radius:22px;padding:22px;display:block;position:relative;overflow:hidden}.ccb-person-card:hover{border-color:var(--ccb-gold-border);transform:translateY(-4px);box-shadow:0 20px 48px #c9a84c24}.ccb-person-card:before{content:"";background:radial-gradient(circle,#c9a84c14,#0000 64%);border-radius:999px;width:160px;height:160px;position:absolute;inset:auto -30px -50px auto}.ccb-person-head{align-items:flex-start;gap:14px;display:flex}.ccb-avatar{color:#0a3f82;width:56px;height:56px;font-family:var(--font-display);background:linear-gradient(135deg,#c9a84c38,#0056b838);border:1.5px solid #c9a84c3d;border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:800;display:inline-flex}.ccb-person-meta h3{text-overflow:ellipsis;white-space:nowrap;margin:4px 0 0;font-size:18px;font-weight:700;overflow:hidden}.ccb-person-meta p{color:var(--ink-muted);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:6px 0 0;font-size:14px;line-height:1.7;display:-webkit-box;overflow:hidden}.ccb-channel-list{gap:10px;margin-top:16px;display:grid}.ccb-channel-item{background:#ffffff9e;border:1px solid #b3cce942;border-radius:12px;justify-content:space-between;gap:10px;min-width:0;padding:12px 14px;font-size:14px;transition:background .16s;display:flex}.ccb-channel-item>div:first-child{min-width:0;overflow:hidden}.ccb-channel-item strong,.ccb-channel-item>div:first-child small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.ccb-channel-item:hover{background:#ffffffe0}.ccb-channel-item small{color:var(--ink-muted)}.ccb-stack{gap:14px;display:grid}.ccb-timeline{gap:20px;display:grid}.ccb-timeline-item{padding-left:28px;position:relative}.ccb-timeline-item:before{content:"";background:linear-gradient(135deg,var(--ccb-gold),var(--accent));border-radius:999px;width:12px;height:12px;position:absolute;top:5px;left:4px;box-shadow:0 0 0 5px #c9a84c24,0 0 0 9px #c9a84c0f}.ccb-timeline-item:after{content:"";background:linear-gradient(#c9a84c66,#699ad633);width:2px;position:absolute;top:24px;bottom:-20px;left:9px}.ccb-timeline-item:last-child:after{display:none}.ccb-form{gap:18px;display:grid}.ccb-form label{color:#20416d;gap:8px;font-size:14px;font-weight:600;display:grid}.ccb-form-note{color:var(--ink-muted);margin:0;font-size:14px;line-height:1.7}.ccb-error{color:#a1293f;background:#ca4b5714;border:1px solid #ca4b5733;border-radius:14px}.ccb-error,.ccb-success{padding:14px 16px;font-size:14px;line-height:1.6}.ccb-success{color:#0f6d43;background:#1c8a5614;border:1px solid #1c8a5638;border-radius:14px}.ccb-metric-strip{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.ccb-metric-pill{transition:transform var(--transition),box-shadow var(--transition);background:#ffffffb8;border:1px solid #c9a84c2e;border-radius:18px;padding:20px;position:relative;overflow:hidden}.ccb-metric-pill:after{content:"";background:linear-gradient(90deg,var(--ccb-gold),transparent);height:2px;position:absolute;bottom:0;left:0;right:0}.ccb-metric-pill:hover{transform:translateY(-2px);box-shadow:0 8px 24px #c9a84c1f}.ccb-metric-pill span{color:var(--ink-muted);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:700;display:block}.ccb-metric-pill strong{color:#0d2548;font-size:30px;font-family:var(--font-mono);letter-spacing:-.02em;margin-top:12px;display:block}.ccb-metric-pill p{color:var(--ink-muted);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:8px 0 0;font-size:12px;line-height:1.6;display:-webkit-box;overflow:hidden}.ccb-split{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:18px;display:grid}.ccb-bar-card{background:#ffffffc2;border:1px solid #a3c1e357;border-radius:16px;padding:18px 20px}.ccb-bar-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.ccb-bar-header strong{color:#0d2548;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:14px;overflow:hidden}.ccb-bar-header span{color:var(--ccb-gold);font-size:14px;font-weight:700;font-family:var(--font-mono);flex-shrink:0}.ccb-detail-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.ccb-detail-item{transition:transform var(--transition);background:#ffffffc7;border:1px solid #a3c1e357;border-radius:16px;padding:18px}.ccb-detail-item:hover{transform:translateY(-2px)}.ccb-detail-item span{color:var(--ink-muted);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700;display:block}.ccb-detail-item strong{color:#0d2548;text-overflow:ellipsis;white-space:nowrap;margin-top:10px;font-size:18px;line-height:1.4;display:block;overflow:hidden}.ccb-group-stack{gap:24px;display:grid}.ccb-group-block{gap:14px;display:grid}.ccb-group-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.ccb-group-heading h3{color:#0d2548;font-family:var(--font-display);margin:0;font-size:20px;line-height:1.2}.ccb-table-group-row td{color:#10345f;letter-spacing:.02em;background:linear-gradient(#d5e4f6eb,#e5eefae0);font-size:12px;font-weight:800}.ccb-file-input{padding:10px 14px}.ccb-textarea{resize:vertical;min-height:156px;padding:14px}.ccb-toggle-field{align-items:center;gap:12px;display:flex!important}.ccb-toggle-field input{width:18px;height:18px}.ccb-profile-hero-card,.ccb-profile-preview-card{background:#ffffffc2;border:1px solid #a3c1e357;border-radius:20px;align-items:flex-start;gap:16px;padding:20px;display:flex}.ccb-profile-avatar-frame{color:#0a3f82;width:92px;height:92px;font-family:var(--font-display);background:linear-gradient(135deg,#c9a84c38,#0056b838);border:2px solid #c9a84c33;border-radius:28px;justify-content:center;align-items:center;font-size:30px;font-weight:800;display:inline-flex;overflow:hidden}.ccb-profile-avatar-frame-small{border-radius:22px;width:72px;height:72px;font-size:24px}.ccb-avatar-image{object-fit:cover;width:100%;height:100%}.ccb-bar-track{background:#07478c14;border-radius:999px;height:8px;position:relative;overflow:hidden}.ccb-bar-fill{border-radius:inherit;background:linear-gradient(90deg,var(--ccb-gold),#e8c96a);height:100%;transition:width .6s cubic-bezier(.16,1,.3,1)}.ccb-bar-fill-soft{background:linear-gradient(90deg,#0d5fc3,#6fc7ff)}.ccb-divider{background:#b2cce947;height:1px;margin:16px 0}.fade-in-up{animation:fadeInUp .5s cubic-bezier(.16,1,.3,1) both}.fade-in-up:first-child{animation-delay:60ms}.fade-in-up:nth-child(2){animation-delay:.12s}.fade-in-up:nth-child(3){animation-delay:.18s}.fade-in-up:nth-child(4){animation-delay:.24s}.fade-in-up:nth-child(5){animation-delay:.3s}.fade-in-up:nth-child(6){animation-delay:.36s}.badge-score-excellent{color:var(--success);font-weight:700}.badge-score-good{color:var(--ccb-gold);font-weight:700}.badge-score-pass{color:var(--primary-strong);font-weight:600}.badge-score-fail{color:var(--danger);font-weight:700}@media (max-width:1180px){.ccb-shell{grid-template-columns:1fr}.ccb-sidebar{height:auto;position:static}}@media (max-width:860px){.app-shell{width:min(100%,100% - 24px)}.page-section{padding:12px 0 24px}.ccb-hero{padding:28px 24px}.ccb-panel,.glass-panel{padding:20px}.ccb-hero-grid,.ccb-split{grid-template-columns:1fr}.ccb-topbar{padding:14px 16px}.ccb-stat-card strong{font-size:30px}.ccb-kpi strong{font-size:28px}}@media (max-width:560px){.ccb-hero h1,.ccb-page-title,.ccb-stat-card strong{font-size:26px}.ccb-button,.ccb-button-ghost,.ccb-button-secondary{min-height:42px;padding:0 16px;font-size:13px}}.ccb-truncate{white-space:nowrap}.ccb-truncate,.ccb-truncate-multiline{text-overflow:ellipsis;overflow:hidden}.ccb-truncate-multiline{-webkit-box-orient:vertical;display:-webkit-box}.ccb-line-clamp-1{-webkit-line-clamp:1}.ccb-line-clamp-2{-webkit-line-clamp:2}.ccb-line-clamp-3{-webkit-line-clamp:3}.ccb-td-course-name{text-overflow:ellipsis;white-space:nowrap;max-width:200px;display:table-cell;overflow:hidden}.ccb-person-card .ccb-person-meta{flex:1;min-width:0}.ccb-timeline-item p{-webkit-line-clamp:2}.ccb-timeline-item p,.ccb-timeline-item span{text-overflow:ellipsis;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.ccb-timeline-item span{-webkit-line-clamp:3}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}