:root{
  --bg:#f7f4fb;
  --bg-soft:#fcfbfe;
  --panel:#ffffff;
  --panel-2:#faf8fd;
  --line:#ddd6e8;
  --text:#1f1d2b;
  --muted:#696576;
  --primary:#5f2f86;
  --primary-2:#4a2469;
  --primary-soft:#f1eafb;
  --success:#1f7a4f;
  --success-soft:#eaf8f0;
  --warning:#a97913;
  --warning-soft:#fff7dd;
  --danger:#c93838;
  --danger-soft:#fff0f0;
  --accent:#2f8f5b;
  --accent-2:#bfe2cf;
  --navy:#4a2469;
  --radius:22px;
  --shadow:0 18px 50px rgba(38,22,55,.10);
  --shadow-soft:0 10px 28px rgba(38,22,55,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Sarabun',Tahoma,Arial,sans-serif;background:radial-gradient(circle at top left,#ffffff 0,#f5effc 30%,#eef7f1 64%,#fbfcfe 100%);color:var(--text);line-height:1.6}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-2)}
img{max-width:100%}
button,input,select,textarea{font:inherit}
.container{width:min(1240px,calc(100% - 32px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:20;background:linear-gradient(90deg,rgba(74,36,105,.96) 0,rgba(95,47,134,.95) 46%,rgba(31,122,79,.92) 100%);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 8px 24px rgba(41,20,59,.20)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 0}
.brand{display:flex;align-items:center;gap:14px;color:#fff;min-width:0}
.brand:hover{color:#fff}
.brand-mark{width:54px;height:54px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fffdf6 0,#f8e8b0 45%,#d1a42a 100%);display:grid;place-items:center;box-shadow:0 12px 30px rgba(0,0,0,.20);padding:7px;flex:none;border:2px solid rgba(255,255,255,.16)}
.brand-text{display:flex;flex-direction:column;min-width:0}
.brand-text strong{font-size:20px;line-height:1.08;letter-spacing:.2px}
.brand-text small{font-size:12px;color:rgba(255,255,255,.82);white-space:normal;overflow:hidden;text-overflow:ellipsis}
.nav-wrap{display:flex;align-items:center;gap:16px}
.nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.nav a{padding:10px 14px;border-radius:999px;color:#eef8f1;font-weight:600;transition:.2s ease}
.nav a:hover,.nav a.is-active{background:rgba(255,255,255,.14);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.10)}
.user-menu{display:flex;align-items:center;gap:12px}
.user-chip{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.10);color:#fff;min-width:0}
.user-avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#8b5db7,#1f7a4f);font-weight:800;color:#fff;flex:none}
.user-chip strong,.user-chip small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}
.user-chip small{color:rgba(255,255,255,.72);font-size:12px}
.nav-toggle{display:none;width:46px;height:46px;border:none;border-radius:14px;background:rgba(255,255,255,.10);padding:0;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;margin:5px auto;border-radius:999px;transition:.25s ease}
.main{padding:28px 0 48px}
.page-intro{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}
.eyebrow{display:inline-block;padding:7px 13px;border-radius:999px;background:linear-gradient(135deg,#f3ebfb,#edf8f2);color:var(--primary-2);font-size:12px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;border:1px solid rgba(95,47,134,.16)}
.page-title{margin:10px 0 0;font-size:clamp(24px,3vw,36px);line-height:1.15}
.hero{position:relative;overflow:hidden;padding:32px;border-radius:30px;background:linear-gradient(135deg,#4a2469 0,#5f2f86 38%,#1f7a4f 72%,#49a36e 100%);color:#fff;box-shadow:var(--shadow);margin-bottom:24px}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.10)}
.hero::before{width:220px;height:220px;right:-60px;top:-40px}
.hero::after{width:160px;height:160px;left:-30px;bottom:-50px}
.hero h1,.hero h2{margin:0 0 10px;font-size:clamp(30px,4vw,42px);line-height:1.12;position:relative;z-index:1}
.hero p{margin:0;color:rgba(255,255,255,.86);max-width:720px;position:relative;z-index:1}
.hero-actions,.btn-group{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.hero-kpis{position:relative;z-index:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:22px}
.hero-kpis .mini-card{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:14px 16px}
.hero-kpis .mini-card strong{display:block;font-size:26px;line-height:1.1;margin-top:8px}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:linear-gradient(180deg,#fff 0,#fdfbfe 100%);border:1px solid rgba(217,226,241,.85);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-soft)}
.card-soft{background:linear-gradient(180deg,#faf7fd 0,#fff 100%)}
.card-header,.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.section-title{margin:0;font-size:22px;line-height:1.2}
.section-subtitle{margin:4px 0 0;color:var(--muted);font-size:14px}
.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:24px}
.stat-card{position:relative;overflow:hidden;padding:22px;background:linear-gradient(180deg,#fff,#f9fbff);border-radius:24px;border:1px solid rgba(217,226,241,.85);box-shadow:var(--shadow-soft)}
.stat-card::after{content:"";position:absolute;inset:auto -32px -40px auto;width:120px;height:120px;border-radius:50%;background:var(--primary-soft)}
.stat-label{position:relative;z-index:1;color:var(--muted);font-weight:700;font-size:14px}
.kpi{position:relative;z-index:1;font-size:38px;font-weight:800;line-height:1.05;margin-top:8px;color:var(--text)}
.stat-note{position:relative;z-index:1;margin-top:8px;font-size:13px;color:var(--muted)}
.muted{color:var(--muted)}
.small{font-size:13px}
.meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;color:var(--muted);font-size:13px}
.meta span{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#f6f9ff;border:1px solid #eadff2}
.meta.grid-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.badge{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid transparent}
.badge::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.7}
.badge.draft{background:#fff5da;color:#9a6708;border-color:#f6d98c}
.badge.in_review{background:#e8f2ff;color:#1450b5;border-color:#b9d4ff}
.badge.published,.badge.ok,.badge.public{background:#e9fff5;color:#0e8d56;border-color:#a9ebc9}
.badge.archived,.badge.rejected,.badge.deprecated,.badge.broken{background:#fff0f0;color:#c62828;border-color:#f3b3b3}
.badge.org,.badge.redirect{background:#f1eafb;color:#1f7a4f;border-color:#cbe7d4}
.badge.unit,.badge.restricted{background:#f3ecff;color:#7248c9;border-color:#d5c5fb}
.badge.private,.badge.secret,.badge.internal,.badge.unknown{background:#eff3f7;color:#475569;border-color:#d4dde8}
.pill-list{display:flex;flex-wrap:wrap;gap:8px}
.pill{padding:7px 12px;border-radius:999px;background:#edf3ff;color:#5f2f86;font-size:13px;font-weight:700;border:1px solid #dbe8ff}
.toolbar{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;align-items:end}
.toolbar .field{grid-column:span 3}
.toolbar .field.field-wide{grid-column:span 4}
.toolbar .field.field-xl{grid-column:span 6}
.toolbar .btn-group{grid-column:span 12;margin-top:0}
.field label{display:block;margin-bottom:8px;font-weight:700;color:#4a2469}
.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1px solid var(--line);background:#fff;border-radius:16px;outline:none;transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;color:var(--text)}
.field input::placeholder,.field textarea::placeholder{color:#94a3b8}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#9d78c6;box-shadow:0 0 0 4px rgba(95,47,134,.12)}
.field textarea{min-height:160px;resize:vertical}
.form-section{margin-bottom:20px;padding:20px;border-radius:22px;background:linear-gradient(180deg,#faf7fd,#fff);border:1px solid #eadff2}
.form-section h3{margin:0 0 6px;font-size:18px}
.form-section p{margin:0 0 14px;color:var(--muted);font-size:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:14px;border:none;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;text-decoration:none}
.btn:hover{transform:translateY(-1px)}
.btn-sm{padding:9px 12px;border-radius:12px;font-size:14px}
.btn-primary{background:linear-gradient(135deg,#6a3b92,#4a2469);color:#fff;box-shadow:0 12px 22px rgba(95,47,134,.24)}
.btn-success{background:linear-gradient(135deg,#2f9a64,#1f7a4f);color:#fff;box-shadow:0 12px 22px rgba(31,122,79,.22)}
.btn-warning{background:linear-gradient(135deg,#e8a20d,#d88306);color:#fff;box-shadow:0 12px 22px rgba(216,131,6,.22)}
.btn-danger{background:linear-gradient(135deg,#e84545,#c82333);color:#fff;box-shadow:0 12px 22px rgba(200,35,51,.18)}
.btn-light{background:#f4eff9;color:#4a2469;border:1px solid #ddd1ea}
.btn-ghost{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.22)}
.btn-outline{background:#fff;color:var(--navy);border:1px solid #d7cbe6}
.link-list{padding-left:18px;margin:0}
.link-list li{margin-bottom:12px}
.list-plain{list-style:none;margin:0;padding:0}
.list-plain li+li{margin-top:12px}
.table-wrap{overflow:auto;border-radius:18px;border:1px solid #eadff2;background:#fff}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:14px 14px;border-bottom:1px solid #eee5f5;text-align:left;vertical-align:top}
.table th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:#756d88;background:#f7f2fb;font-weight:800;position:sticky;top:0}
.table tr:hover td{background:#fdfbfe}
.table tr:last-child td{border-bottom:none}
.table .actions{white-space:nowrap}
.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:18px;margin-bottom:16px;border:1px solid transparent;box-shadow:var(--shadow-soft)}
.alert.success{background:#effff6;color:#0d7a4c;border-color:#b8edd0}
.alert.error{background:#fff3f3;color:#b42318;border-color:#f4c0c0}
.alert-icon{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-weight:800;background:rgba(255,255,255,.65);flex:none}
.pagination{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 14px;border-radius:12px;background:#fff;border:1px solid #e0e8f5;color:#5f2f86;font-weight:700}
.pagination .active{background:linear-gradient(135deg,#6a3b92,#4a2469);color:#fff;border-color:transparent;box-shadow:0 12px 20px rgba(95,47,134,.20)}
.empty{padding:28px;border-radius:22px;border:1px dashed #d9cceb;background:#f7fbff;color:var(--muted);text-align:center}
.auth-box{max-width:1120px;margin:0 auto}
.auth-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:18px;align-items:stretch}
.auth-hero{background:linear-gradient(135deg,#4a2469 0,#5f2f86 42%,#1f7a4f 100%);color:#fff;border-radius:28px;padding:30px;position:relative;overflow:hidden;min-height:100%}
.auth-hero::after{content:"";position:absolute;inset:auto -40px -50px auto;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.12)}
.auth-hero h2{margin:0 0 10px;font-size:30px;line-height:1.15;position:relative;z-index:1}
.auth-hero p,.auth-hero ul{position:relative;z-index:1;color:rgba(255,255,255,.86)}
.auth-hero ul{padding-left:18px;margin:14px 0 0}
.auth-panel{padding:28px}
.split{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.95fr);gap:18px}
.insight-list{display:grid;gap:12px}
.insight-item{padding:14px 16px;border-radius:18px;background:#faf7fd;border:1px solid #eadff2}
.insight-item strong{display:block;color:#4a2469;margin-bottom:4px}
.km-card{display:flex;flex-direction:column;gap:16px;height:100%}
.km-card .card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.km-card .card-title{margin:0;font-size:22px;line-height:1.25}
.km-card .card-desc{margin:0;color:var(--muted)}
.km-card .card-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:auto}
.filter-summary{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.summary-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:#fff;border:1px solid #dfe8f6;color:#4a2469;font-size:13px;font-weight:700}
.stat-grid-note{margin-top:8px;font-size:13px;color:var(--muted)}
.progress-list{display:grid;gap:12px}
.progress-item{padding:14px 16px;border-radius:18px;background:#faf7fd;border:1px solid #eadff2}
.progress-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;font-weight:700}
.progress-bar{height:10px;background:#e8eef8;border-radius:999px;overflow:hidden}
.progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(135deg,#6a3b92,#2f9a64)}
.content-view{background:#fff;border:1px solid #eadff2;border-radius:20px;padding:20px;line-height:1.8;white-space:pre-wrap;word-break:break-word}
.timeline{display:grid;gap:14px}
.timeline-item{position:relative;padding-left:22px}
.timeline-item::before{content:"";position:absolute;left:4px;top:6px;bottom:-16px;width:2px;background:#dfd4ec}
.timeline-item::after{content:"";position:absolute;left:0;top:4px;width:10px;height:10px;border-radius:50%;background:#6a3b92;box-shadow:0 0 0 4px #f1eafb}
.timeline-item:last-child::before{display:none}
.timeline-item .time{font-size:12px;color:var(--muted);margin-bottom:2px}
.notice{padding:14px 16px;border-radius:18px;background:#f7f2fc;border:1px solid #e6daf2;color:#5c377d}
.footer{margin-top:24px;padding:32px 0;background:linear-gradient(135deg,#3f1d5f 0,#5f2f86 42%,#1f7a4f 100%);color:#efe8f8}
.footer-inner{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.footer p{margin:8px 0 0;color:#d9d0e8;max-width:720px}
.footer-credit{line-height:1.75}
.footer-credit a{color:#fff;font-weight:700;text-decoration:none;border-bottom:1px dashed rgba(255,255,255,.45)}
.footer-credit a:hover{color:#d6f2df;border-bottom-color:#fff}
.footer-links{display:flex;flex-wrap:wrap;gap:10px}
.footer-links a{color:#fff;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.10)}
.right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.pre{white-space:pre-wrap;background:#f8f4fc;color:#2d2340;padding:12px;border-radius:16px;font-size:13px;max-height:280px;overflow:auto;border:1px solid #e7def1}
.inline-form{display:inline}
.table-kv{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.table-kv .kv{padding:14px 16px;border-radius:18px;background:#f7fbff;border:1px solid #eadff2}
.table-kv .kv strong{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.result-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.dashboard-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.activity-list{display:grid;gap:12px}
.activity-item{padding:14px 16px;border-radius:18px;background:#f9fbff;border:1px solid #e8eef8}
.activity-item strong{display:block}
.quick-actions{display:flex;flex-wrap:wrap;gap:10px}
.status-ring{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#f6f0d2,#fffdf5);color:#0d5b46;font-weight:800;border:1px solid rgba(208,165,45,.28)}
@media (max-width:1080px){
  .stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split,.dashboard-layout,.auth-grid{grid-template-columns:1fr}
}
@media (max-width:860px){
  .nav-toggle{display:inline-block}
  .nav-wrap{position:absolute;left:16px;right:16px;top:76px;display:none;flex-direction:column;align-items:stretch;padding:16px;border-radius:22px;background:rgba(11,24,52,.97);box-shadow:var(--shadow)}
  .nav-wrap.is-open{display:flex}
  .nav,.user-menu{width:100%;flex-direction:column;align-items:stretch}
  .nav a,.user-menu .btn,.user-chip{width:100%}
  .user-chip strong,.user-chip small{max-width:none}
  .topbar-inner{position:relative}
  .toolbar{grid-template-columns:1fr}
  .toolbar .field,.toolbar .field.field-wide,.toolbar .field.field-xl,.toolbar .btn-group{grid-column:auto}
  .grid-2,.grid-3,.grid-4,.stats,.table-kv{grid-template-columns:1fr}
  .hero{padding:24px}
  .page-intro{margin-bottom:18px}
  .footer-inner{flex-direction:column}
}
@media (max-width:560px){
  .container{width:min(100% - 20px,1240px)}
  .brand-text strong{font-size:18px}
  .hero h1,.hero h2{font-size:28px}
  .page-title{font-size:26px}
  .card,.stat-card{padding:18px}
  .kpi{font-size:32px}
  .btn,.btn-sm{width:100%}
  .hero-actions .btn,.btn-group .btn{width:100%}
}
.hero-ecosystem{background:linear-gradient(135deg,#4a2469 0,#5f2f86 40%,#1f7a4f 74%,#58a877 100%)}
.process-steps{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.process-step{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;background:#faf7fd;border:1px solid #eadff2}
.process-step span{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#6a3b92,#2f9a64);color:#fff;font-weight:800;flex:none}
.quick-links-col{display:grid;gap:10px}
.quick-link{display:block;padding:14px 16px;border-radius:16px;background:#f6f1fb;border:1px solid #e6daf2;color:#4a2469;font-weight:700}
.quick-link:hover{background:#efe6f8}
.badge.overdue{background:#fff0f0;color:#b42318;border-color:#f3b3b3}
.badge.soon{background:#fff8dd;color:#9a6708;border-color:#f6d98c}
.badge.future{background:#e9fff5;color:#0e8d56;border-color:#a9ebc9}
@media (max-width:860px){.process-steps{grid-template-columns:1fr}}
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;margin-left:6px;border-radius:999px;background:#efe6f8;color:#4a2469;font-size:12px;font-weight:800;vertical-align:middle}
.pill.is-active{background:linear-gradient(135deg,#6a3b92,#4a2469);color:#fff;border-color:transparent;box-shadow:0 12px 20px rgba(95,47,134,.20)}
.request-actions{margin-top:14px;padding-top:14px;border-top:1px dashed #dfd4ec}
.approval-form{padding:14px;border:1px solid #eadff2;border-radius:18px;background:#fdfbfe}
.drive-picked-list{display:grid;gap:10px;margin-top:14px}
.drive-picked-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:18px;background:#faf7fd;border:1px solid #eadff2}
.drive-picked-item .btn{flex:none}
.auth-note{margin-top:20px;background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#fff}
.badge.pending{background:#fff5da;color:#9a6708;border-color:#f6d98c}
.badge.approved{background:#e9fff5;color:#0e8d56;border-color:#a9ebc9}
@media (max-width:860px){.drive-picked-item{flex-direction:column}}


.brand-mark img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}
.page-intro.is-login{margin-bottom:16px}
.eyebrow-light{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.16);color:#fff}
.auth-box-official{max-width:1180px}
.auth-grid-official{grid-template-columns:1.16fr .92fr}
@media (max-width:1080px){.auth-grid-official{grid-template-columns:1fr}}
@media (max-width:560px){.auth-panel-official,.auth-hero{padding:20px}.auth-identity{flex-direction:column;gap:12px;align-items:flex-start}}
.auth-hero-official::before{content:"";position:absolute;inset:-1px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,0));pointer-events:none}
.auth-identity{position:relative;z-index:1;display:flex;align-items:center;gap:18px;margin-bottom:18px}
.auth-seal{width:92px;height:92px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fffefb 0,#f9e8b1 48%,#cda129 100%);padding:10px;display:grid;place-items:center;box-shadow:0 14px 30px rgba(0,0,0,.18);flex:none}
.auth-seal img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.auth-subtitle{margin:8px 0 0;color:rgba(255,255,255,.90);font-size:18px;line-height:1.45}
.formal-divider{height:1px;border:0;background:linear-gradient(90deg,rgba(255,255,255,.45),rgba(255,255,255,.08));margin:18px 0}
.formal-divider.soft{background:linear-gradient(90deg,rgba(95,47,134,.20),rgba(31,122,79,.08))}
.login-guidance{display:grid;gap:12px;margin-top:18px;position:relative;z-index:1}
.guide-card{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(4px)}
.guide-card strong{display:block;margin-bottom:4px;color:#fff}
.guide-card span{display:block;color:rgba(255,255,255,.84);font-size:14px}
.official-login-note strong{color:#dff6e8}
.auth-panel-official{padding:30px;border:1px solid rgba(95,47,134,.16);background:linear-gradient(180deg,#ffffff 0,#fbf9fd 100%)}
.official-section-head{margin-bottom:18px}
.login-panel-title{font-size:26px}
.auth-actions{margin-top:4px}
.official-login-box{background:linear-gradient(180deg,#f6f1fb 0,#f2faf5 100%);border-color:rgba(95,47,134,.18);color:#485b58}
.footer-brand{max-width:760px}
.footer-brand-head{display:flex;align-items:center;gap:16px}
.footer-logo{width:64px;height:64px;object-fit:contain;display:block;flex:none;background:radial-gradient(circle at 35% 35%,#fffefb 0,#f9e8b1 48%,#cda129 100%);border-radius:50%;padding:6px;box-shadow:0 12px 30px rgba(0,0,0,.18)}
.footer-brand strong{display:block;font-size:22px;color:#fff}
.footer-brand small{display:block;margin-top:4px;color:rgba(255,255,255,.82)}
.footer p{max-width:760px}
.pill{background:#f0ebf8;color:#4a2469;border:1px solid #e0d6ef}
.summary-chip{background:#f4fbf6;border:1px solid #cfe8d8;color:#1f7a4f}
.stat-card::after{background:linear-gradient(135deg,#efe3fb,#edf8f2)}
.badge.in_review{background:#f1eafb;color:#5f2f86;border-color:#dac7f1}
.badge.org,.badge.redirect{background:#ecf8f0;color:#1f7a4f;border-color:#cbe7d4}
.badge.unit,.badge.restricted{background:#f3ebfb;color:#5f2f86;border-color:#dcc7f1}
@media (max-width:860px){
  .footer-brand-head,.auth-identity{align-items:flex-start}
}
@media (max-width:560px){
  .brand-mark{width:48px;height:48px;padding:6px}
  .footer-logo{width:56px;height:56px}
  .auth-seal{width:78px;height:78px}
  .auth-subtitle{font-size:16px}
}

/* v7 layout refresh: left sidebar + responsive shell */
:root{
  --sidebar-width:300px;
  --sidebar-collapsed-width:104px;
  --topbar-height:88px;
}
body.has-sidebar{background:linear-gradient(180deg,#f8f5fc 0,#f4f8f7 100%)}
body.guest-layout{background:radial-gradient(circle at top left,#ffffff 0,#f5effc 30%,#eef7f1 64%,#fbfcfe 100%)}
.app-layout{min-height:100vh}
.app-sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);padding:18px 16px 18px;background:linear-gradient(180deg,#3f1d5f 0,#5f2f86 48%,#1f7a4f 100%);color:#fff;display:flex;flex-direction:column;z-index:40;box-shadow:0 24px 60px rgba(42,20,60,.24);border-right:1px solid rgba(255,255,255,.08);transition:width .28s ease,transform .28s ease}
.sidebar-top{display:flex;align-items:center;gap:10px}
.brand-sidebar,.brand-guest{display:flex;align-items:center;gap:14px;min-width:0;color:#fff}
.brand-sidebar:hover,.brand-guest:hover{color:#fff}
.brand-copy{display:flex;flex-direction:column;min-width:0;transition:opacity .2s ease,transform .2s ease}
.brand-copy strong{font-size:17px;line-height:1.1;letter-spacing:.2px}
.brand-copy small{display:block;margin-top:4px;font-size:12px;color:rgba(255,255,255,.78)}
.sidebar-collapse-btn{width:42px;height:42px;border:none;border-radius:14px;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;display:inline-grid;place-items:center;flex:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);transition:transform .2s ease,background .2s ease}
.sidebar-collapse-btn:hover{background:rgba(255,255,255,.18);transform:translateX(-1px)}
.sidebar-user-card{display:flex;align-items:center;gap:12px;margin-top:20px;padding:14px;border-radius:22px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.10);backdrop-filter:blur(10px);overflow:hidden}
.sidebar-avatar{width:44px;height:44px;background:linear-gradient(135deg,rgba(255,255,255,.26),rgba(255,255,255,.08));border:1px solid rgba(255,255,255,.22)}
.sidebar-user-copy{min-width:0;transition:opacity .2s ease,transform .2s ease}
.sidebar-user-copy strong,.sidebar-user-copy small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-copy small{color:rgba(255,255,255,.8)}
.sidebar-scroll{flex:1;overflow:auto;padding:16px 2px 8px;margin:14px -2px 0}
.sidebar-scroll::-webkit-scrollbar{width:8px}
.sidebar-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.sidebar-nav{display:grid;gap:14px}
.nav-group{border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);overflow:hidden}
.nav-group summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;cursor:pointer;font-weight:800;color:#fff}
.nav-group summary::-webkit-details-marker{display:none}
.nav-group-arrow{display:inline-block;transition:transform .2s ease;color:rgba(255,255,255,.78)}
.nav-group[open] .nav-group-arrow{transform:rotate(180deg)}
.nav-group-items{display:grid;gap:6px;padding:0 10px 10px}
.sidebar-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:16px;color:#f4f2fb;font-weight:700;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}
.sidebar-link:hover{background:rgba(255,255,255,.12);color:#fff;transform:translateX(2px)}
.sidebar-link.is-active{background:rgba(255,255,255,.18);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12),0 12px 20px rgba(0,0,0,.10)}
.sidebar-link-icon{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.12);color:#fff;font-weight:800;font-size:14px;flex:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.sidebar-link-text{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .2s ease,transform .2s ease}
.sidebar-link-badge{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;padding:0 8px;border-radius:999px;background:#fff;color:#4a2469;font-size:12px;font-weight:800;transition:opacity .2s ease,transform .2s ease}
.sidebar-footer{padding-top:14px;border-top:1px solid rgba(255,255,255,.10)}
.sidebar-logout{width:100%;background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.16);color:#fff}
.sidebar-logout:hover{background:rgba(255,255,255,.24);color:#fff}
.sidebar-overlay{position:fixed;inset:0;background:rgba(20,14,31,.42);opacity:0;visibility:hidden;transition:.24s ease;z-index:35}
.app-main{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left .28s ease}
.app-topbar{position:sticky;top:0;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 26px;background:rgba(248,245,252,.86);backdrop-filter:blur(14px);border-bottom:1px solid rgba(95,47,134,.08)}
.app-topbar-left,.app-topbar-right{display:flex;align-items:center;gap:14px;min-width:0}
.app-topbar-eyebrow{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.28em;color:#6d5a83}
.app-topbar-title{display:block;font-size:22px;line-height:1.2;color:#251d33}
.topbar-user-mini{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:18px;background:#fff;border:1px solid rgba(95,47,134,.12);box-shadow:var(--shadow-soft)}
.topbar-user-dot{width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,#6a3b92,#2f9a64);box-shadow:0 0 0 6px rgba(95,47,134,.10)}
.topbar-user-mini strong,.topbar-user-mini small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-user-mini small{color:var(--muted)}
.sidebar-mobile-toggle{width:46px;height:46px;border:none;border-radius:16px;background:linear-gradient(135deg,#6a3b92,#2f9a64);padding:0;display:inline-grid;place-items:center;cursor:pointer;box-shadow:0 12px 26px rgba(74,36,105,.24)}
.sidebar-mobile-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:999px;margin:2px 0}
.main{padding:26px 0 42px}
.guest-main{padding-top:24px}
.guest-header{position:sticky;top:0;z-index:15;background:linear-gradient(135deg,rgba(63,29,95,.96) 0,rgba(95,47,134,.94) 52%,rgba(31,122,79,.92) 100%);backdrop-filter:blur(18px);box-shadow:0 8px 28px rgba(41,20,59,.20)}
.guest-header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.guest-header-actions{display:flex;align-items:center;gap:10px}
.footer{margin-top:26px;border-radius:28px 28px 0 0;background:linear-gradient(135deg,#3f1d5f 0,#5f2f86 42%,#1f7a4f 100%);box-shadow:0 -14px 40px rgba(49,23,70,.10)}
.footer-inner{padding-top:4px}
.footer-note{margin-top:12px;color:#dfd8ec;max-width:760px}
body.sidebar-collapsed .app-sidebar{width:var(--sidebar-collapsed-width)}
body.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed-width)}
body.sidebar-collapsed .brand-copy,
body.sidebar-collapsed .sidebar-user-copy,
body.sidebar-collapsed .nav-group-title,
body.sidebar-collapsed .sidebar-link-text,
body.sidebar-collapsed .sidebar-link-badge{opacity:0;transform:translateX(-8px);pointer-events:none}
body.sidebar-collapsed .sidebar-user-card{justify-content:center;padding-inline:10px}
body.sidebar-collapsed .sidebar-top{justify-content:center}
body.sidebar-collapsed .sidebar-collapse-btn{transform:rotate(180deg)}
body.sidebar-collapsed .nav-group{background:transparent;border-color:rgba(255,255,255,.06)}
body.sidebar-collapsed .nav-group summary{padding:10px 8px 0;justify-content:center}
body.sidebar-collapsed .nav-group summary .nav-group-arrow{display:none}
body.sidebar-collapsed .nav-group-items{padding:8px 0 10px}
body.sidebar-collapsed .sidebar-link{justify-content:center;padding-inline:10px}
body.sidebar-collapsed .sidebar-link:hover{transform:none}
body.sidebar-collapsed .sidebar-logout{padding-inline:8px;font-size:0}
body.sidebar-collapsed .sidebar-logout::before{content:'⎋';font-size:18px}
body.sidebar-collapsed .footer{margin-left:0}
@media (max-width:1200px){
  .app-sidebar{width:280px}
  .app-main{margin-left:280px}
}
@media (max-width:920px){
  .app-sidebar{transform:translateX(-110%);width:min(86vw,320px)}
  .app-main{margin-left:0}
  body.sidebar-open .app-sidebar{transform:translateX(0)}
  body.sidebar-open .sidebar-overlay{opacity:1;visibility:visible}
  body.sidebar-collapsed .app-main{margin-left:0}
  body.sidebar-collapsed .app-sidebar{width:min(86vw,320px)}
  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .sidebar-user-copy,
  body.sidebar-collapsed .nav-group-title,
  body.sidebar-collapsed .sidebar-link-text,
  body.sidebar-collapsed .sidebar-link-badge{opacity:1;transform:none;pointer-events:auto}
  body.sidebar-collapsed .sidebar-top,
  body.sidebar-collapsed .sidebar-user-card,
  body.sidebar-collapsed .sidebar-link{justify-content:flex-start}
  body.sidebar-collapsed .sidebar-logout{font-size:inherit}
  body.sidebar-collapsed .sidebar-logout::before{display:none}
  .app-topbar{padding:16px 18px}
  .topbar-user-mini{display:none}
}
@media (max-width:640px){
  .guest-header-inner{align-items:flex-start;flex-direction:column}
  .brand-copy strong{font-size:16px}
  .brand-copy small{font-size:11px}
  .app-topbar-title{font-size:20px}
  .page-intro{margin-bottom:18px}
  .footer{border-radius:22px 22px 0 0}
}

.app-main .container{width:min(1360px,calc(100% - 40px))}
@media (max-width:640px){.app-main .container{width:min(100% - 20px,1360px)}}


/* v7.4 minimal footer while keeping sidebar layout */
.footer.footer-minimal {
    margin-top: 24px;
    background: transparent;
    border-top: 1px solid rgba(95, 47, 134, 0.12);
    border-radius: 0;
    box-shadow: none;
}

.footer-minimal-inner {
    padding: 18px 0 24px;
}

.footer.footer-minimal .footer-credit {
    margin: 0;
    color: #5a5573;
    font-size: 14px;
    line-height: 1.7;
}

.footer.footer-minimal .footer-credit a {
    color: #5f2f86;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px dashed rgba(95, 47, 134, 0.35);
}

.footer.footer-minimal .footer-credit a:hover {
    color: #1c8b55;
    border-bottom-color: rgba(28, 139, 85, 0.45);
}

.xp-profile-card{background:linear-gradient(180deg,#fcfbfe,#fff)}
.xp-profile-grid{display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:center}
.xp-level-badge{width:120px;height:120px;border-radius:28px;display:grid;place-items:center;font-size:28px;font-weight:800;background:linear-gradient(135deg,#6a3b92,#1f7a4f);color:#fff;box-shadow:0 18px 32px rgba(79,42,117,.24)}
.xp-level-title{font-size:22px;font-weight:800;color:#4a2469;margin-bottom:6px}
.xp-big-number{font-size:32px;font-weight:800;color:var(--navy)}
.xp-progress-lg{height:14px}
.xp-earned{margin-top:8px;font-weight:800;color:#1f7a4f}
.xp-rank-item.is-self{border-color:#c4e8d2;background:linear-gradient(180deg,#f3fff8,#ffffff)}
.xp-rank-score{margin-top:6px;font-weight:800;color:#4a2469}
.pill-active{background:linear-gradient(135deg,#6a3b92,#1f7a4f);color:#fff;border-color:transparent}
@media (max-width:760px){.xp-profile-grid{grid-template-columns:1fr}.xp-level-badge{width:88px;height:88px;border-radius:24px;font-size:22px}}

/* Gamification Plus */
.topbar-bell{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:#fff;border:1px solid #e1d6ef;color:#4a2469;box-shadow:0 6px 16px rgba(95,47,134,.08)}
.topbar-bell:hover{background:#f6f1fb;border-color:#d5c3ea}
.topbar-bell-icon{font-size:18px;line-height:1}
.topbar-bell-badge{position:absolute;top:-6px;right:-6px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:linear-gradient(135deg,#6a3b92,#1f7a4f);color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;border:2px solid #fff}
.badge-grid,.achievement-grid,.challenge-list{display:grid;gap:12px}
.badge-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.achievement-grid{grid-template-columns:1fr}
.achievement-grid.compact,.badge-grid.admin-catalog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.badge-card,.achievement-card,.challenge-item,.notification-item{padding:16px;border-radius:18px;border:1px solid #eadff2;background:#faf7fd}
.badge-card.earned,.achievement-card.unlocked{background:linear-gradient(135deg,#fdf6ff,#f4fffa)}
.badge-card.compact,.achievement-card.compact{padding:14px}
.badge-icon,.achievement-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:#fff;border:1px solid #e6daf2;font-size:24px;box-shadow:0 8px 20px rgba(95,47,134,.08);flex:none}
.badge-card,.achievement-card{display:flex;gap:14px;align-items:flex-start}
.achievement-icon.muted{opacity:.8}
.achievement-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.challenge-item.is-complete{border-color:#b8e3cb;background:linear-gradient(135deg,#f7fff9,#f3fbf7)}
.challenge-head,.notification-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.notification-list.compact .notification-item{padding:14px}
.notification-item.is-read{opacity:.82}
.notification-item.is-unread{border-color:#d8c6ed;background:#fff}
.notification-check{padding-top:4px}
.notification-body{min-width:0;flex:1}
.notification-item label{cursor:pointer}
.notification-list .notification-item{display:flex;gap:12px;align-items:flex-start}
.xp-earned{margin-top:8px;font-weight:800;color:#1f7a4f}
.xp-profile-grid{display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:center}
.xp-level-badge{width:96px;height:96px;border-radius:28px;display:grid;place-items:center;background:linear-gradient(135deg,#6a3b92,#1f7a4f);color:#fff;font-size:28px;font-weight:800;box-shadow:0 18px 32px rgba(74,36,105,.18)}
.xp-level-title{font-size:22px;font-weight:800;color:#4a2469}
.xp-big-number{font-size:34px;font-weight:800;line-height:1.1;color:#13233f;margin-top:6px}
.xp-progress-lg{height:12px}
@media (max-width:960px){
  .badge-grid,.achievement-grid.compact,.badge-grid.admin-catalog-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .topbar-bell{width:38px;height:38px}
  .xp-profile-grid{grid-template-columns:1fr}
  .xp-level-badge{width:84px;height:84px;font-size:24px}
}


/* v8.2 UX / UI refresh */
html,body{overflow-x:hidden}
body.sidebar-open{overflow:hidden}
.card,.stat-card,.insight-item,.progress-item,.activity-item,.drive-picked-item,.table-wrap,.auth-panel,.guide-card,.mini-card,.topbar-user-mini,.user-chip{transition:transform .2s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}
.card:hover,.stat-card:hover,.insight-item:hover,.activity-item:hover,.drive-picked-item:hover,.auth-panel:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(46,24,67,.10)}
.hero{border:1px solid rgba(255,255,255,.08)}
.section-title{font-size:clamp(20px,2.2vw,26px)}
.section-subtitle{max-width:72ch}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.meta.grid-meta{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.content-view{font-size:15px;background:linear-gradient(180deg,#ffffff 0,#fcfbfe 100%)}
.table-wrap{position:relative}
.table-wrap::after{content:"";position:absolute;top:0;right:0;width:32px;height:100%;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.94))}
.table th{position:sticky;top:0;background:#faf7fd;z-index:1}
.table td{vertical-align:top}
.table td .btn,.table td .badge{white-space:nowrap}
.sidebar-scroll{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.28) transparent}
.sidebar-scroll::-webkit-scrollbar{width:8px}
.sidebar-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}
.sidebar-link-icon{box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.sidebar-link:hover,.sidebar-link.is-active{box-shadow:0 12px 24px rgba(20,10,31,.16)}
.app-topbar{background:linear-gradient(180deg,rgba(250,248,252,.96),rgba(246,243,250,.88))}
.topbar-user-mini{min-width:220px}
.auth-panel{background:linear-gradient(180deg,#fff 0,#fcfbfe 100%)}
.auth-panel .btn-group{align-items:stretch}
.auth-panel .btn-group .btn{min-height:48px}
.form-section{box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.field input,.field select,.field textarea{min-height:50px}
.field textarea{min-height:168px}
.field-error,.text-danger{color:#b91c1c}
.center-narrow{max-width:860px;margin-inline:auto}
.mt-1{margin-top:10px!important}
.mt-2{margin-top:14px!important}
.mt-3{margin-top:18px!important}
.mt-4{margin-top:24px!important}
.mb-4{margin-bottom:32px!important}
.word-break-anywhere{word-break:break-word;overflow-wrap:anywhere}
.form-actions-tight{margin-top:0!important;margin-bottom:12px!important}
.notice-inline{margin-top:12px}
.btn-group.wrap-mobile{width:100%}
.km-detail-title{margin-top:12px}
.content-view.mt-content{margin-top:18px}
.pill-list.mt-inline{margin-top:14px}
.auth-actions .btn{flex:1 1 220px}
.notice.official-login-box{line-height:1.8}
.page-shell{display:grid;gap:18px}
.table .muted{display:block}
@media (max-width:920px){
  .card:hover,.stat-card:hover,.insight-item:hover,.activity-item:hover,.drive-picked-item:hover,.auth-panel:hover{transform:none}
  .topbar-user-mini{min-width:0}
}
@media (max-width:760px){
  .meta.grid-meta{grid-template-columns:1fr}
  .table-wrap{overflow:visible;border:none;background:transparent}
  .table-wrap::after{display:none}
  .table,.table thead,.table tbody,.table th,.table td,.table tr{display:block;width:100%}
  .table thead{display:none}
  .table tbody{display:grid;gap:12px}
  .table tr{background:#fff;border:1px solid #eadff2;border-radius:18px;padding:10px 14px;box-shadow:var(--shadow-soft)}
  .table td{border:none;padding:10px 0;display:grid;grid-template-columns:minmax(110px,40%) 1fr;gap:10px;align-items:flex-start}
  .table td::before{content:attr(data-label);font-weight:800;color:#4a2469}
  .table td.actions,.table td:last-child{padding-top:14px;border-top:1px dashed #eadff2;grid-template-columns:1fr}
  .table td.actions::before,.table td:last-child::before{content:none}
  .table td .btn{width:100%}
  .table td:empty{display:none}
  .auth-actions .btn{width:100%}
}
@media (max-width:640px){
  .hero{padding:22px}
  .auth-hero,.auth-panel{padding:22px}
  .auth-identity{align-items:flex-start}
  .auth-seal{width:74px;height:74px}
  .guide-card{padding:14px 15px}
  .field input,.field select,.field textarea{border-radius:14px}
  .btn,.btn-sm{min-height:46px}
  .km-card .card-footer,.result-header,.progress-head{align-items:flex-start}
  .result-header{flex-direction:column}
  .content-view{padding:16px}
}
