/*
Theme Name: Cong thong tin dieu huong Viet Nam
Theme URI: https://vietnamnavigation.com
Author: Quan tri vien
Author URI: https://vietnamnavigation.com
Description: Giao dien cong thong tin dieu huong tong hop website pho bien tai Viet Nam.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: cong-thong-tin-vn
*/

:root{
  --nen:#f8f9fb;
  --the:#ffffff;
  --chu:#0f1419;
  --phu:#6b7280;
  --vien:#e5e7eb;
  --do:#DA251D;
  --nhan:#b81d17;
  --vang:#FFCC00;
  --xanh:#1976d2;
  --luc:#388e3c;
  --tim:#7c3aed;
  --hong:#ec4899;
  --bong:0 4px 12px rgba(15,20,25,.08);
  --bong-lg:0 12px 32px rgba(15,20,25,.12);
  --ease-time:.3s;
  --ease-func:ease;
}

body.che-do-toi{
  --nen:#0f1419;
  --the:#1a1f2e;
  --chu:#f5f7fa;
  --phu:#9ca3af;
  --vien:#2d3748;
  --do:#ef5350;
  --nhan:#d32f2f;
  --vang:#ffb74d;
  --xanh:#42a5f5;
  --luc:#66bb6a;
  --tim:#ab47bc;
  --hong:#f06292;
  --bong:0 4px 12px rgba(0,0,0,.24);
  --bong-lg:0 12px 32px rgba(0,0,0,.32);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:
    radial-gradient(circle at 12% -10%, rgba(200,16,46,.18), transparent 44%),
    radial-gradient(circle at 88% 0%, rgba(246,200,0,.15), transparent 38%),
    linear-gradient(180deg,#fff6f7 0%,var(--nen) 220px);
  color:var(--chu);
  font-family:"Noto Sans","Be Vietnam Pro","Segoe UI","Tahoma",sans-serif;
  line-height:1.5;
  overflow-x:hidden;
}
body.che-do-toi{
  background:
    radial-gradient(circle at 15% -8%, rgba(239,83,80,.16), transparent 42%),
    radial-gradient(circle at 85% 2%, rgba(255,183,77,.12), transparent 34%),
    linear-gradient(180deg,#121826 0%, var(--nen) 260px);
}

a{text-decoration:none;color:inherit;transition:color var(--ease-time) var(--ease-func), transform var(--ease-time) var(--ease-func), box-shadow var(--ease-time) var(--ease-func), filter var(--ease-time) var(--ease-func)}
img{max-width:100%;display:block}
button, a{-webkit-tap-highlight-color:transparent}
button{touch-action:manipulation}

.vn-clickable,
a,
button,
[role="button"],
.vn-card,
.vn-box,
.vn-category-item,
.vn-site-item,
.vn-rank-item,
.vn-tool,
.vn-life-item,
.vn-action-btn,
.vn-search-btn,
.vn-news-btn,
.vn-arrow,
.vn-dot,
.vn-core-menu > li > a,
.vn-quick-nav a,
.vn-tool-secondary,
.vn-card-cta a,
.vn-weather-tab,
.vn-news-cat,
.vn-category-tab,
.vn-mini-tab,
.vn-ghim-btn,
.vn-voice-btn{
  transition:
    color var(--ease-time) var(--ease-func),
    background-color var(--ease-time) var(--ease-func),
    border-color var(--ease-time) var(--ease-func),
    transform var(--ease-time) var(--ease-func),
    box-shadow var(--ease-time) var(--ease-func),
    filter var(--ease-time) var(--ease-func),
    opacity var(--ease-time) var(--ease-func);
}

.vn-clickable:hover,
a:hover,
button:hover,
[role="button"]:hover,
.vn-card:hover,
.vn-box:hover,
.vn-site-item:hover,
.vn-rank-item:hover,
.vn-tool:hover,
.vn-life-item:hover,
.vn-tool-secondary:hover{
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 12px 24px rgba(15,20,25,.12);
}

.vn-clickable:active,
a:active,
button:active,
[role="button"]:active{
  transform:translateY(1px) scale(.985);
}

.vn-clickable:not(.vn-news-track a):active,
a:not(.vn-news-track a):active,
button:active,
[role="button"]:active{
  box-shadow:0 4px 10px rgba(15,20,25,.10);
}

.vn-container{max-width:1280px;margin:0 auto;padding:0 16px}

.vn-topbar{
  position:sticky;
  top:0;
  z-index:999;
  backdrop-filter:blur(10px);
  background:color-mix(in srgb,var(--the) 84%, transparent);
  border-bottom:1px solid var(--vien);
  box-shadow:0 8px 20px rgba(19,31,48,.08);
  transition:background var(--ease-time) var(--ease-func), box-shadow var(--ease-time) var(--ease-func);
}
.vn-topbar.nen-ro{
  background:color-mix(in srgb,var(--the) 96%, transparent);
  box-shadow:0 10px 22px rgba(19,31,48,.12);
}
.vn-topbar-inner{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:70px;
}
.vn-logo{display:flex;align-items:center;gap:10px;white-space:nowrap}
.vn-logo-text{display:flex;flex-direction:column;line-height:1.2}
.vn-logo-text strong{font-size:16px;font-weight:800;color:var(--chu)}
.vn-logo-text em{font-size:11px;color:var(--phu);font-style:normal;font-weight:500}
.vn-logo-badge{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(145deg,var(--do),var(--vang));
  box-shadow:var(--bong);
}
.vn-logo span{font-size:17px}
.vn-core-nav{flex:1;min-width:0}
.vn-core-menu{display:flex;gap:10px;list-style:none;margin:0;padding:0}
.vn-core-menu > li{position:relative}
.vn-core-menu > li > a{
  display:inline-flex;align-items:center;height:42px;padding:0 12px;border-radius:10px;
  border:1px solid var(--vien);background:linear-gradient(180deg,var(--the),color-mix(in srgb,var(--the) 90%, #eaf0ff));font-size:13px;color:var(--phu)
}
.vn-core-menu > li > a:hover{color:var(--do);border-color:#f2b3bc;transform:translateY(-1px)}
.vn-sub-menu{
  position:absolute;left:0;top:calc(100% + 8px);min-width:260px;max-height:320px;overflow:auto;
  background:linear-gradient(180deg,var(--the),color-mix(in srgb,var(--the) 92%, #eef3ff));border:1px solid var(--vien);border-radius:12px;box-shadow:var(--bong-lg);
  padding:8px;display:none;z-index:1001;
  opacity:0;transform:translateY(6px);
  transition:opacity var(--ease-time) var(--ease-func), transform var(--ease-time) var(--ease-func);
}
.vn-sub-menu a{display:block;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--phu)}
.vn-sub-menu a:hover{background:rgba(200,16,46,.07);color:var(--do)}
.vn-core-menu > li:hover .vn-sub-menu{display:block;opacity:1;transform:translateY(0)}
.vn-search-wrap{display:flex;gap:8px;align-items:center;min-width:0;padding-bottom:10px}
.vn-search-input-wrap{position:relative;flex:1;min-width:160px}
.vn-spell-suggest{
  position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:20;
  background:var(--the);border:1px solid var(--vien);border-radius:10px;box-shadow:var(--bong);padding:6px;
}
.vn-spell-item{display:block;width:100%;text-align:left;border:none;background:transparent;padding:7px 8px;border-radius:8px;color:var(--chu);cursor:pointer}
.vn-spell-item:hover{background:rgba(200,16,46,.08);color:var(--do)}
.vn-voice-btn{height:42px;min-width:42px;border:1px solid var(--vien);border-radius:10px;background:var(--the);cursor:pointer}
.vn-voice-status{font-size:12px;color:var(--phu);min-width:120px}
.vn-search-engine,
.vn-search-input,
.vn-search-btn,
.vn-action-btn{
  height:42px;border:1px solid var(--vien);border-radius:10px;background:var(--the);color:var(--chu);
}
.vn-search-engine{padding:0 10px;min-width:145px}
.vn-search-input{flex:1;padding:0 12px;min-width:140px}
.vn-search-btn{padding:0 14px;font-weight:600;background:var(--do);border-color:var(--do);color:#fff;cursor:pointer}
.vn-search-btn:hover{background:var(--nhan)}
.vn-search-btn:active,
.vn-action-btn:active,
.vn-news-btn:active,
.vn-ghim-btn:active,
.vn-arrow:active,
.vn-site-item a:active{
  transform:translateY(1px) scale(.98);
}
.vn-search-btn:focus-visible,
.vn-action-btn:focus-visible,
.vn-news-btn:focus-visible,
.vn-arrow:focus-visible,
.vn-site-item a:focus-visible,
.vn-tool:focus-visible,
.vn-life-item:focus-visible,
.vn-quick-nav a:focus-visible{
  outline:2px solid color-mix(in srgb,var(--xanh) 70%, #fff);
  outline-offset:2px;
}
.vn-action-btn{padding:0 12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.vn-actions{display:flex;gap:8px;align-items:center}

.vn-mobile-toggle{display:none}

body.vn-menu-open{
  overflow:hidden;
  touch-action:none;
}
body.vn-search-focus{
  overflow:hidden;
}

.vn-quick-nav{
  display:flex;gap:8px;flex-wrap:wrap;
  padding:10px 0 14px;
}
.vn-quick-nav a{
  padding:8px 12px;border-radius:999px;border:1px solid var(--vien);background:var(--the);font-size:13px;color:var(--phu)
}
.vn-quick-nav a:hover{color:var(--do);border-color:#f2b3bc}
.vn-quick-nav a.duoc-chon{color:var(--do);border-color:#f2b3bc;background:rgba(200,16,46,.08)}

.vn-hero-core{margin:14px 0 12px}
.vn-hero-search{display:flex;gap:8px;align-items:center;margin:10px 0 14px}
.vn-core-shortcuts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.vn-core-shortcut{border:1px solid var(--vien);border-radius:12px;background:var(--the);padding:12px;transition:all var(--ease-time) var(--ease-func)}
.vn-core-shortcut:hover{transform:translateY(-2px);box-shadow:0 10px 18px rgba(15,22,34,.1)}
.vn-core-shortcut h3{margin:0 0 6px;font-size:16px}
.vn-core-shortcut p{margin:0 0 10px;font-size:12px;color:var(--phu);min-height:36px}
.vn-core-shortcut a{display:inline-flex;padding:7px 11px;border-radius:10px;background:linear-gradient(135deg,var(--do),var(--nhan));color:#fff;font-size:12px}
.vn-core-shortcut a:hover{opacity:.92}

.vn-banner{
  position:relative;
  border:1px solid var(--vien);
  background:var(--the);
  border-radius:16px;
  box-shadow:var(--bong);
  overflow:hidden;
  margin:10px 0 18px;
}
.vn-banner::after{
  content:"";
  position:absolute;inset:auto 0 0 0;height:64px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.22));
  pointer-events:none;
}
.vn-slides{position:relative;height:320px}
.vn-slide{
  position:absolute;inset:0;padding:26px;
  opacity:0;transform:translateX(24px);
  transition:opacity var(--ease-time) var(--ease-func), transform var(--ease-time) var(--ease-func);
  display:flex;align-items:flex-end;
  background-image:linear-gradient(110deg, rgba(12,18,30,.62), rgba(12,18,30,.15)), var(--slide-bg);
  background-size:cover;
  background-position:center;
}
.vn-slide.hien{opacity:1;transform:translateX(0)}
.vn-slide-1{}
.vn-slide-2{}
.vn-slide-3{}
.vn-slide-content{max-width:680px}
.vn-slide-content h2{margin:0 0 8px;font-size:32px;color:#fff;text-shadow:0 4px 14px rgba(0,0,0,.35)}
.vn-slide-content p{margin:0 0 12px;color:rgba(255,255,255,.92);max-width:620px}
.vn-slide-content a{display:inline-block;padding:9px 14px;border-radius:10px;background:var(--do);color:#fff;box-shadow:0 8px 18px rgba(200,16,46,.35)}
.vn-slide-content a:hover{background:var(--nhan)}

.vn-slide-controls{
  position:absolute;right:12px;bottom:12px;display:flex;gap:6px;align-items:center
}
.vn-dot{width:10px;height:10px;border-radius:50%;border:none;background:#cdd3e0;cursor:pointer}
.vn-dot.hien{background:var(--do)}
.vn-arrow{width:34px;height:34px;border:none;border-radius:9px;background:var(--the);border:1px solid var(--vien);cursor:pointer}

.vn-layout{
  display:grid;grid-template-columns:1fr 300px;gap:14px;margin-bottom:16px;
}
.vn-sidebar-inline{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}

.vn-card,
.vn-box{
  background:linear-gradient(180deg, color-mix(in srgb,var(--the) 96%, #ffffff 4%), var(--the));
  border:1px solid var(--vien);border-radius:14px;box-shadow:var(--bong)
}
.vn-card{padding:14px}
main.vn-container > section.vn-card{margin-bottom:18px}
main.vn-container > .vn-ad{margin:18px 0}
.vn-box{padding:14px}
.vn-title{
  margin:0 0 12px;
  font-size:22px;
  display:flex;align-items:center;gap:8px;
}
.vn-title::before{
  content:"";width:6px;height:24px;border-radius:4px;background:linear-gradient(var(--do),var(--vang));display:inline-block
}
.vn-card > p:first-of-type{
  margin:0 0 14px !important;
  padding-bottom:12px;
  border-bottom:1px solid var(--vien);
}

.vn-category-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px
}
.vn-category-item{
  display:block;
  border:1px solid var(--vien);border-radius:12px;background:linear-gradient(180deg,var(--the),#fff);
  padding:12px;transition:all var(--ease-time) var(--ease-func);position:relative;overflow:hidden;cursor:pointer
}
.vn-category-item::before{
  content:"";
  position:absolute;
  width:140px;height:140px;
  right:-56px;top:-64px;
  background:radial-gradient(circle, rgba(200,16,46,.16), transparent 68%);
}
.vn-category-item:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 32px rgba(200,16,46,.18)}
.vn-category-item:active{transform:translateY(-4px) scale(1.01)}
.vn-category-item .icon{
  width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:8px;
  border:1px solid color-mix(in srgb,var(--xanh) 25%, var(--vien));
  background:linear-gradient(145deg, color-mix(in srgb,var(--xanh) 12%, #fff), transparent);
  position:relative;transition:transform .3s ease, background .3s ease;
}
.vn-category-item:hover .icon{transform:scale(1.15) rotate(8deg)}
.vn-category-item .icon::before{line-height:1}
.icon-tim-kiem::before{content:"🔎"}
.icon-tin-tuc::before{content:"📰"}
.icon-video::before{content:"🎬"}
.icon-mang-xa-hoi::before{content:"💬"}
.icon-mua-sam::before{content:"🛍️"}
.icon-tro-choi::before{content:"🎮"}
.icon-ngan-hang::before{content:"🏦"}
.icon-viec-lam::before{content:"💼"}
.icon-du-lich::before{content:"✈️"}
.icon-giao-duc::before{content:"🎓"}
.icon-o-to::before{content:"🚗"}
.icon-nha-dat::before{content:"🏠"}
.vn-category-item:nth-child(2n) .icon{background:linear-gradient(145deg, color-mix(in srgb,var(--luc) 14%, #fff), transparent)}
.vn-category-item:nth-child(3n) .icon{background:linear-gradient(145deg, color-mix(in srgb,var(--tim) 14%, #fff), transparent)}
.vn-category-item:nth-child(4n) .icon{background:linear-gradient(145deg, color-mix(in srgb,var(--hong) 14%, #fff), transparent)}
.vn-category-item h3{margin:0 0 4px;font-size:15px}
.vn-category-item p{margin:0;color:var(--phu);font-size:12px}

.vn-site-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.vn-site-item{
  border:1px solid var(--vien);border-radius:12px;background:var(--the);padding:12px;transition:all var(--ease-time) var(--ease-func)
}
.vn-site-item:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(15,22,34,.1)}
.vn-site-item h4{margin:0 0 6px;font-size:15px;display:flex;align-items:center;gap:8px}
.vn-site-item h4::before{
  content:"";width:14px;height:14px;border-radius:5px;
  border:1.5px solid color-mix(in srgb,var(--luc) 70%, #fff);
  box-shadow:inset 0 0 0 3px color-mix(in srgb,var(--luc) 20%, transparent);
}
.vn-site-item p{margin:0 0 8px;color:var(--phu);font-size:12px;min-height:36px}
.vn-site-item a{display:inline-flex;padding:7px 10px;border-radius:9px;background:linear-gradient(135deg,var(--xanh),#3f83f8);color:#fff;font-size:12px}
.vn-pay-tag{display:inline-flex;margin:0 8px 8px 0;padding:6px 9px;border-radius:999px;background:rgba(200,16,46,.1);color:var(--do);font-size:11px;border:1px solid #efb7c0}
.vn-pay-tag:hover{background:rgba(200,16,46,.16)}
.vn-ghim-btn{
  margin-left:8px;border:1px solid var(--vien);background:var(--the);color:var(--phu);
  border-radius:9px;padding:6px 8px;font-size:12px;cursor:pointer;transition:all var(--ease-time) var(--ease-func);
}
.vn-ghim-btn:hover{color:var(--do);border-color:#efb7c0}
.vn-ghim-btn.da-ghim{background:rgba(200,16,46,.09);color:var(--do);border-color:#efb7c0}

.vn-rank-list{display:grid;grid-auto-flow:column;grid-template-rows:repeat(2,minmax(0,1fr));grid-auto-columns:minmax(220px,1fr);gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}
.vn-rank-scroll{overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}
.vn-rank-grid{display:grid;grid-template-rows:repeat(2,minmax(0,1fr));grid-auto-flow:column;grid-auto-columns:minmax(250px,1fr);gap:10px;min-width:max-content}
.vn-rank-item{
  display:flex;gap:10px;align-items:flex-start;padding:10px;border:1px solid var(--vien);border-radius:12px;
  background:linear-gradient(180deg,color-mix(in srgb,var(--the) 97%, #fff 3%), var(--the));
}
.vn-rank-no{
  font-weight:700;color:var(--do);min-width:30px;height:30px;border-radius:10px;
  background:rgba(200,16,46,.08);display:flex;align-items:center;justify-content:center;
}
.vn-rank-no.top{background:linear-gradient(145deg,var(--do),var(--vang));color:#fff}
.vn-rank-content{flex:1}
.vn-rank-item h4{margin:0 0 3px;font-size:14px}
.vn-rank-item p{margin:0;color:var(--phu);font-size:12px}
.vn-rank-meter{margin-top:8px;height:6px;border-radius:999px;background:#e8ecf5;overflow:hidden}
.vn-rank-meter span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--do),var(--vang))}

.vn-weather{margin:12px 0 16px}
.vn-weather-head{margin-bottom:10px}
.vn-weather-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.vn-weather-tab{
  border:1px solid var(--vien);background:var(--the);border-radius:999px;
  padding:7px 12px;font-size:13px;color:var(--phu);cursor:pointer
}
.vn-weather-tab.hien{background:rgba(200,16,46,.1);border-color:#f1b6bf;color:var(--do)}
.vn-weather-panel{display:none;border:1px solid var(--vien);border-radius:12px;padding:12px;background:var(--the);opacity:0;transform:translateY(8px)}
.vn-weather-panel.hien{display:block;opacity:1;transform:translateY(0)}
.vn-weather-panel h3{margin:0 0 8px;font-size:18px}
.vn-weather-panel h3 a{color:inherit;text-decoration:none}
.vn-weather-panel h3 a:hover{color:var(--do)}
.vn-weather-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.vn-weather-meta p{margin:0;font-size:13px;color:var(--phu)}
.vn-weather-more{margin:10px 0 0}
.vn-weather-more a{display:inline-flex;padding:7px 11px;border-radius:10px;background:rgba(200,16,46,.1);border:1px solid #f0bcc4;color:var(--do);font-size:12px}
.vn-weather-more a:hover{background:rgba(200,16,46,.16)}
.vn-weather-detail-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.vn-weather-detail-item{border:1px solid var(--vien);border-radius:12px;padding:10px;background:var(--the)}
.vn-weather-detail-item h4{margin:0 0 8px;font-size:14px}
.vn-weather-detail-item p{margin:0 0 6px;font-size:12px;color:var(--phu)}

.vn-api-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}
.vn-api-card{border:1px solid var(--vien);border-radius:12px;background:var(--the);padding:12px}
.vn-api-card h3{margin:0 0 6px;font-size:16px}
.vn-api-sub{margin:0 0 8px;color:var(--phu);font-size:12px}
.vn-rate-list p,
.vn-more-rate p,
.vn-holiday-list p{margin:0 0 6px;display:flex;justify-content:space-between;gap:10px;font-size:13px}
.vn-more-rate{margin-top:6px}
.vn-more-rate summary{cursor:pointer;color:var(--do);font-size:13px}
.vn-holiday-near{border:1px solid #f0bcc4;background:rgba(200,16,46,.08);border-radius:10px;padding:10px;margin-bottom:8px;display:flex;justify-content:space-between;gap:10px}
.vn-holiday-list p.hien{color:var(--do);font-weight:700}
.vn-aqi-now{border:1px solid var(--vien);border-radius:10px;padding:10px;display:flex;justify-content:space-between;gap:10px;margin-bottom:8px;background:rgba(56,142,60,.08)}
.vn-aqi-inline{margin-top:8px;border-top:1px dashed var(--vien);padding-top:8px}
.vn-aqi-inline p{margin:0 0 4px;font-size:13px}
.vn-dict-form{display:grid;grid-template-columns:1.2fr .8fr .8fr auto;gap:8px;margin:8px 0}
.vn-dict-form input,
.vn-dict-form select{min-width:0;height:40px;border:1px solid var(--vien);border-radius:10px;padding:0 10px;background:var(--the);color:var(--chu)}
.vn-dict-form button{height:40px;padding:0 12px;border:none;border-radius:10px;background:var(--do);color:#fff;cursor:pointer}
.vn-dict-result{font-size:13px;color:var(--phu)}
.vn-dict-result p{margin:0 0 6px}
.vn-mini-tools{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.vn-mini-tab{border:1px solid var(--vien);background:var(--the);color:var(--phu);border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer}
.vn-mini-tab.hien{border-color:#efb7c0;background:rgba(200,16,46,.1);color:var(--do)}
.vn-mini-panel{display:none;opacity:0;transform:translateY(8px)}
.vn-mini-panel.hien{display:block;opacity:1;transform:translateY(0)}
.vn-mini-panel input,.vn-mini-panel select{width:100%;height:38px;border:1px solid var(--vien);border-radius:10px;padding:0 10px;background:var(--the);margin-bottom:7px}
.vn-mini-panel button{height:38px;border:none;border-radius:10px;background:var(--do);color:#fff;padding:0 12px;cursor:pointer}
.vn-mini-panel p{margin:6px 0 0;font-size:12px;color:var(--phu)}
.vn-bank-card{border:1px solid var(--vien);border-radius:12px;background:var(--the);padding:12px;margin:0 0 10px}
.vn-bank-card h4{margin:0 0 8px;font-size:15px}
.vn-bank-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.vn-bank-list a{display:block;padding:8px;border:1px solid var(--vien);border-radius:10px;background:var(--the);font-size:12px}
.vn-bank-list a span{display:block;color:var(--phu);font-size:11px;margin-top:4px}
.vn-speak-btn{border:1px solid var(--vien);background:var(--the);color:var(--chu);border-radius:8px;padding:2px 6px;font-size:12px;cursor:pointer;margin-left:4px}
.vn-api-note{margin:4px 0 0;color:var(--phu);font-size:12px}
.vn-cap-nhat{margin:10px 0 0;font-size:12px;color:var(--phu)}
.vn-card-cta{margin:10px 0 0}
.vn-card-cta a{display:inline-flex;padding:7px 11px;border-radius:10px;background:rgba(200,16,46,.1);border:1px solid #f0bcc4;color:var(--do);font-size:12px;font-weight:600}

.vn-fx-layout{display:grid;grid-template-columns:1.35fr .9fr;gap:14px;margin-top:12px}
.vn-fx-card h3{margin:0 0 10px;font-size:18px}
.vn-fx-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:10px 0 14px}
.vn-fx-metric{border:1px solid var(--vien);border-radius:12px;background:linear-gradient(180deg,var(--the),color-mix(in srgb,var(--the) 92%,#eef3ff));padding:11px 12px}
.vn-fx-metric h3{margin:0 0 4px;font-size:18px;color:var(--do)}
.vn-fx-metric p{margin:0;font-size:12px;color:var(--phu)}
.vn-fx-table-wrap{overflow:auto;border:1px solid var(--vien);border-radius:12px}
.vn-fx-table{width:100%;border-collapse:collapse;min-width:620px;background:var(--the)}
.vn-fx-table th,.vn-fx-table td{padding:10px 12px;border-bottom:1px solid var(--vien);font-size:13px;text-align:left}
.vn-fx-table thead th{font-size:12px;color:var(--phu);text-transform:uppercase;letter-spacing:.2px;background:color-mix(in srgb,var(--the) 90%,#f4f7ff)}
.vn-fx-table tbody tr:hover{background:color-mix(in srgb,var(--the) 94%,#fff2f3)}
.vn-fx-table td a{color:var(--xanh);font-weight:600}
.vn-fx-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;border:1px solid var(--vien);font-size:12px;color:var(--phu);background:var(--the)}
.vn-fx-badge.is-up{border-color:#cce8d2;color:var(--luc);background:rgba(56,142,60,.1)}
.vn-fx-badge.is-down{border-color:#f5c5ca;color:var(--do);background:rgba(218,37,29,.08)}
.vn-fx-note-list{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--vien);background:color-mix(in srgb,var(--the) 92%,#f7f9ff)}
.vn-fx-note-list p{margin:0 0 7px;font-size:13px;color:var(--phu)}
.vn-fx-note-list p:last-child{margin-bottom:0}
.vn-fx-faq{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.vn-fx-faq article{border:1px solid var(--vien);border-radius:12px;padding:10px 12px;background:var(--the)}
.vn-fx-faq h4{margin:0 0 6px;font-size:14px}
.vn-fx-faq p{margin:0;font-size:13px;color:var(--phu)}
.vn-fx-pairs-block{background:linear-gradient(145deg,color-mix(in srgb,var(--the) 94%,#fff),color-mix(in srgb,var(--the) 88%,#eef5ff))}
.vn-fx-pairs-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.vn-fx-pairs-head h3{margin:0}
.vn-fx-chip-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}
.vn-fx-chip{display:flex;flex-direction:column;gap:4px;padding:10px 11px;border-radius:12px;border:1px solid var(--vien);background:var(--the);min-height:68px}
.vn-fx-chip strong{font-size:14px;color:var(--chu)}
.vn-fx-chip span{font-size:11px;color:var(--phu)}
.vn-fx-chip:hover{border-color:#f0bcc4;background:rgba(200,16,46,.06)}
.vn-fx-quick-pairs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px dashed var(--vien)}
.vn-fx-quick-pairs a{display:inline-flex;padding:7px 11px;border-radius:999px;border:1px solid var(--vien);background:var(--the);font-size:12px;color:var(--phu)}
.vn-fx-quick-pairs a:hover{color:var(--do);border-color:#f0bcc4;background:rgba(200,16,46,.06)}

@media (max-width:980px){
  .vn-fx-layout{grid-template-columns:1fr}
  .vn-fx-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-fx-faq{grid-template-columns:1fr}
  .vn-fx-chip-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width:640px){
  .vn-fx-metrics{grid-template-columns:1fr}
  .vn-fx-chip-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

.vn-card-cta a:hover{background:rgba(200,16,46,.16)}

.vn-tools{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.vn-tool{
  border:1px dashed var(--vien);border-radius:12px;padding:12px;background:var(--the);transition:all var(--ease-time) var(--ease-func);
  position:relative;overflow:hidden;
}
.vn-tool::after{
  content:"";position:absolute;inset:auto -30px -52px auto;width:110px;height:110px;
  background:radial-gradient(circle, rgba(75,141,255,.22), transparent 70%);
}
.vn-tool:hover{border-style:solid;transform:translateY(-2px)}
.vn-tool h4{margin:0 0 5px;font-size:14px;display:flex;align-items:center;gap:8px}
.vn-tool h4::before{
  content:"";width:16px;height:16px;border-radius:6px;
  border:1.5px solid color-mix(in srgb,var(--xanh) 70%, #fff);
  box-shadow:inset 0 0 0 3px color-mix(in srgb,var(--xanh) 20%, transparent);
}
.vn-tool p{margin:0;color:var(--phu);font-size:12px}
.vn-tool-cta{display:inline-flex;margin-top:10px;padding:6px 10px;border-radius:9px;background:rgba(25,118,210,.12);border:1px solid color-mix(in srgb,var(--xanh) 35%, var(--vien));color:var(--xanh);font-size:12px;font-weight:600}
.vn-tools-secondary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:10px}
.vn-tool-secondary{display:flex;align-items:center;justify-content:center;text-align:center;min-height:42px;border:1px solid var(--vien);border-radius:10px;background:var(--the);font-size:12px;color:var(--phu);padding:8px}
.vn-tool-secondary:hover{color:var(--do);border-color:#f2b3bc;background:rgba(200,16,46,.06)}

.vn-news-cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.vn-news-cat{
  border:1px solid var(--vien);background:var(--the);border-radius:999px;
  padding:7px 12px;font-size:13px;color:var(--phu);cursor:pointer
}
.vn-news-cat.hien{background:rgba(200,16,46,.1);border-color:#f1b6bf;color:var(--do)}
.vn-news-wrap{display:none;opacity:0;transform:translateY(10px)}
.vn-news-wrap.hien{display:block;opacity:1;transform:translateY(0)}
.vn-news-ticker{
  border:1px solid var(--vien);border-radius:12px;padding:10px;background:var(--the);
  overflow-x:auto;overflow-y:hidden;scrollbar-width:none;scroll-snap-type:x mandatory;
}
.vn-news-ticker::-webkit-scrollbar{display:none}
.vn-news-controls{display:flex;gap:8px;justify-content:flex-end;margin-top:10px;flex-wrap:wrap}
.vn-news-btn{
  height:34px;padding:0 12px;border-radius:10px;border:1px solid var(--vien);
  background:linear-gradient(180deg,var(--the),color-mix(in srgb,var(--the) 90%, #eef3ff));
  color:var(--chu);cursor:pointer;font-size:12px;
}
.vn-news-btn:hover{border-color:#f2b3bc;color:var(--do)}
.vn-news-track{
  display:flex;gap:22px;white-space:nowrap;animation:chay 42s linear infinite;will-change:transform;
}
.vn-news-track.tam-dung{animation-play-state:paused}
.vn-news-track a{
  color:var(--chu);font-size:14px;display:flex;flex-direction:column;gap:6px;
  min-width:340px;padding:8px 10px;border:1px solid var(--vien);border-radius:10px;background:var(--the);scroll-snap-align:start
}
.vn-news-track a.dang-chon{
  border-color:color-mix(in srgb,var(--do) 45%, var(--vien));
  box-shadow:0 10px 20px rgba(200,16,46,.12);
  transform:translateY(-1px);
}
.vn-news-track a img{width:100%;height:110px;object-fit:cover;border-radius:8px}
.vn-news-track a:hover{color:var(--do);border-color:#f2b3bc}
.vn-news-title{font-weight:600;line-height:1.4;white-space:normal}
.vn-news-meta{font-size:12px;color:var(--phu)}
@keyframes chay{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* News: richer cards on homepage */
.vn-news-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.vn-news-card{
  border:1px solid var(--vien);
  border-radius:14px;
  background:linear-gradient(180deg, color-mix(in srgb,var(--the) 97%, #fff 3%), var(--the));
  padding:12px;
  box-shadow:var(--bong);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.vn-news-card img{width:100%;height:140px;object-fit:cover;border-radius:10px}
.vn-news-card .vn-news-title{margin:0;font-size:14px}
.vn-news-excerpt{margin:0;color:var(--phu);font-size:12px;line-height:1.45}
.vn-news-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}
.vn-news-btn-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid var(--vien);
  background:var(--the);
  color:var(--chu);
  font-size:12px;
  font-weight:600;
}
.vn-news-btn-link:hover{border-color:#f2b3bc;color:var(--do)}
.vn-news-btn-link:first-child{background:rgba(200,16,46,.10);border-color:#efb7c0;color:var(--do)}

.vn-category-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 12px}
.vn-category-tab{border:1px solid var(--vien);background:var(--the);border-radius:999px;padding:7px 12px;font-size:13px;color:var(--phu);cursor:pointer}
.vn-category-tab.hien{background:rgba(200,16,46,.1);border-color:#f1b6bf;color:var(--do)}
.vn-category-panel{display:none;opacity:0;transform:translateY(8px)}
.vn-category-panel.hien{display:block;opacity:1;transform:translateY(0)}

.vn-breadcrumb{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--phu);margin-bottom:8px}
.vn-detail-filter{margin:10px 0 14px;display:flex;gap:8px}
.vn-detail-filter select{min-width:240px;border:1px solid var(--vien);background:var(--nen);border-radius:10px;padding:8px;color:var(--chu)}
.vn-hour-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}
.vn-hour-grid span{border:1px solid var(--vien);background:var(--the);border-radius:10px;padding:8px;font-size:12px;color:var(--phu);text-align:center}
.vn-convert-box{display:grid;grid-template-columns:1fr 160px 160px;gap:8px;margin:10px 0}
.vn-postal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.vn-related{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.vn-related a{display:inline-flex;padding:7px 11px;border:1px solid var(--vien);border-radius:10px;background:var(--the);font-size:12px;color:var(--phu)}
.vn-related a:hover{color:var(--do);border-color:#f2b3bc}
.vn-pagination .vn-page-num,.vn-pagination .vn-page-current,.vn-pagination .vn-page-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;padding:0 10px;border:1px solid var(--vien);border-radius:10px;font-size:13px;box-sizing:border-box}
.vn-pagination .vn-page-current{background:var(--do);color:#fff;border-color:var(--do);font-weight:600}
.vn-pagination .vn-page-ellipsis{border:none;background:transparent;color:var(--phu);min-width:auto}
.vn-pagination .vn-page-summary{margin-left:auto;color:var(--phu);font-size:13px;align-self:center}
@media (max-width:640px){.vn-pagination .vn-page-summary{width:100%;margin-left:0;text-align:center;order:10}}
button.dang-tai,
.vn-search-btn.dang-tai,
.vn-user-btn.dang-tai{
  opacity:.7;
  cursor:wait;
  filter:saturate(.85);
}

.vn-life-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
.vn-life-item{
  border:1px solid var(--vien);border-radius:12px;padding:12px;text-align:center;background:var(--the);transition:all var(--ease-time) var(--ease-func);
  position:relative;overflow:hidden;
}
.vn-life-item::before{
  content:"";position:absolute;left:-25px;top:-38px;width:90px;height:90px;
  background:radial-gradient(circle, rgba(246,200,0,.18), transparent 72%);
}
.vn-life-item:hover{transform:translateY(-3px)}
.vn-life-item .icon{font-size:24px;margin-bottom:4px}
.vn-life-item h4{margin:0 0 2px;font-size:14px}
.vn-life-item p{margin:0;color:var(--phu);font-size:12px}
.vn-life-cta{display:inline-flex;margin-top:8px;padding:6px 10px;border-radius:9px;background:rgba(25,118,210,.12);border:1px solid color-mix(in srgb,var(--xanh) 35%, var(--vien));color:var(--xanh);font-size:12px;font-weight:600}

.vn-ad{display:none;border:1px dashed #e6a5af;background:linear-gradient(120deg,#fff2f4,#fff9ec);border-radius:12px;padding:14px;color:#8e4150;font-size:13px;box-shadow:0 8px 16px rgba(182,26,53,.08)}
.vn-ad.vn-ad-rent{display:block}
.vn-ad.vn-ad-rent a{color:var(--do);font-weight:700}
.vn-ad.vn-ad-rent a:hover{text-decoration:underline}
.vn-ad + .vn-ad{margin-top:10px}

.vn-footer{
  margin-top:20px;padding:18px 0 26px;color:var(--phu)
}
.vn-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:12px}
.vn-footer h4{margin:0 0 8px;color:var(--chu);font-size:15px}
.vn-footer p,.vn-footer a{font-size:13px;color:var(--phu)}
.vn-footer a:hover{color:var(--do)}

main.vn-container > .vn-ad,
main.vn-container > .vn-banner,
main.vn-container > .vn-card,
main.vn-container > .vn-layout{
  animation:noi-len .55s ease both;
}
main.vn-container > .vn-banner{animation-delay:.04s}
main.vn-container > #danh-muc{animation-delay:.08s}
main.vn-container > #xep-hang{animation-delay:.12s}
main.vn-container > #cong-cu{animation-delay:.16s}
main.vn-container > #tin-tuc{animation-delay:.20s}
main.vn-container > #doi-song{animation-delay:.24s}
main.vn-container > #lien-ket-day-du{animation-delay:.28s}

@keyframes noi-len{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important; animation:none !important;}
  main.vn-container > .vn-ad,
  main.vn-container > .vn-banner,
  main.vn-container > .vn-card,
  main.vn-container > .vn-layout{animation:none}
}

.vn-loading{
  position:fixed;inset:0;background:var(--nen);display:flex;align-items:center;justify-content:center;z-index:1200;transition:opacity var(--ease-time) var(--ease-func), visibility var(--ease-time) var(--ease-func);
  opacity:1;visibility:visible;pointer-events:auto;
}
.vn-loading.an{opacity:0;visibility:hidden;pointer-events:none}
.vn-spinner{width:42px;height:42px;border-radius:50%;border:3px solid #f2c7cf;border-top-color:var(--do);animation:quay .8s linear infinite}
@keyframes quay{to{transform:rotate(360deg)}}

.vn-len-dau{
  position:fixed;right:18px;bottom:20px;z-index:30;
  width:42px;height:42px;border:none;border-radius:12px;
  background:linear-gradient(140deg,var(--do),var(--nhan));color:#fff;
  box-shadow:0 12px 20px rgba(183,13,41,.32);cursor:pointer;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.25s;
}
.vn-len-dau.hien{opacity:1;visibility:visible;transform:translateY(0)}

.sr-only{
  position:absolute !important;
  width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

@media (max-width:1080px){
  .vn-core-menu{gap:6px}
  .vn-core-menu > li > a{padding:0 10px;font-size:12px}
  .vn-layout{grid-template-columns:1fr}
  .vn-sidebar{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .vn-sidebar-inline{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-hour-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .vn-convert-box{grid-template-columns:1fr 1fr}
  .vn-postal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-weather-meta{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-weather-detail-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-api-grid{grid-template-columns:1fr}
  .vn-category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .vn-core-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-site-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-tools{grid-template-columns:repeat(3,minmax(0,1fr))}
  .vn-life-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .vn-news-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:760px){
  .vn-topbar-inner{flex-wrap:wrap;padding:8px 0}
  .vn-news-track a{min-width:86vw}
  .vn-core-nav{display:none}
  .vn-search-wrap{order:3;width:100%;flex-wrap:wrap}
  .vn-hero-search{flex-wrap:wrap}
  .vn-core-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-search-input-wrap{width:100%;order:2}
  .vn-search-input{width:100%}
  .vn-voice-status{min-width:0;order:5;width:100%}
  .vn-actions{margin-left:auto}
  .vn-mobile-toggle{display:inline-flex}
  .vn-quick-nav{display:none;width:100%}
  .vn-quick-nav.mo{display:flex}

  /* Mobile drawer: show full categories/navigation */
  body.vn-menu-open .vn-core-nav{
    display:block;
    position:fixed;
    left:0;
    right:0;
    top:0;
    height:100dvh;
    padding:88px 16px 18px;
    background:color-mix(in srgb,var(--the) 96%, transparent);
    backdrop-filter:blur(10px);
    z-index:1200;
    overflow:auto;
  }
  body.vn-menu-open .vn-topbar{z-index:1201}
  body.vn-menu-open::before{
    content:"";
    position:fixed;
    inset:0;
    background:rgba(15,20,25,.52);
    z-index:1199;
  }
  body.vn-menu-open .vn-core-menu{
    flex-direction:column;
    gap:10px;
  }
  body.vn-menu-open .vn-core-menu > li > a{
    width:100%;
    height:48px;
    justify-content:space-between;
    font-size:14px;
  }
  body.vn-menu-open .vn-sub-menu{
    position:static;
    display:none;
    opacity:1;
    transform:none;
    max-height:none;
    min-width:0;
    margin-top:8px;
  }
  body.vn-menu-open .vn-core-menu > li.vn-open .vn-sub-menu{display:block}
  body.vn-menu-open .vn-sub-menu a{
    min-height:48px;
    display:flex;
    align-items:center;
    padding:10px 12px;
    font-size:13px;
  }

  /* 48px touch targets on mobile */
  .vn-action-btn,
  .vn-search-btn,
  .vn-voice-btn,
  .vn-quick-nav a,
  .vn-news-btn,
  .vn-tool-secondary,
  .vn-ghim-btn{
    min-height:48px;
  }
  .vn-search-engine,
  .vn-search-input{
    height:48px;
    font-size:16px;
  }

  /* Fullscreen search on mobile focus */
  body.vn-search-focus .vn-topbar{
    position:fixed;
    left:0;right:0;top:0;
  }
  body.vn-search-focus::after{
    content:"";
    position:fixed;
    inset:0;
    background:rgba(15,20,25,.45);
    z-index:1299;
  }
  body.vn-search-focus .vn-search-wrap{
    position:fixed;
    left:0;right:0;top:0;
    padding:14px 16px 16px;
    gap:10px;
    background:color-mix(in srgb,var(--the) 98%, transparent);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--vien);
    z-index:1300;
  }
  body.vn-search-focus .vn-search-input,
  body.vn-search-focus .vn-search-engine{
    height:54px;
    font-size:17px;
  }
  body.vn-search-focus .vn-search-btn,
  body.vn-search-focus .vn-voice-btn{
    height:54px;
    min-height:54px;
  }
  body.vn-search-focus .vn-spell-suggest{
    top:calc(100% + 6px);
  }
  .vn-slides{height:270px}
  .vn-slide-content h2{font-size:24px}
  .vn-weather-meta{grid-template-columns:1fr}
  .vn-weather-detail-list{grid-template-columns:1fr}
  .vn-sidebar-inline{grid-template-columns:1fr}
  .vn-hour-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-convert-box{grid-template-columns:1fr}
  .vn-postal-grid{grid-template-columns:1fr}
  .vn-dict-form{grid-template-columns:1fr}
  .vn-bank-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-category-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-tools-secondary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-tools{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-life-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-footer-grid{grid-template-columns:1fr 1fr}
  .vn-title{font-size:20px}
  .vn-card > p:first-of-type{font-size:12px}
  .vn-news-controls{justify-content:flex-start}
  .vn-news-btn{height:36px;padding:0 10px}
  .vn-news-grid{grid-template-columns:1fr}
  .vn-news-card img{height:160px}
}

@media (max-width:480px){
  .vn-search-engine{min-width:112px}
  .vn-search-input{min-width:0}
  .vn-search-btn{padding:0 11px}
  .vn-site-grid{grid-template-columns:1fr}
  .vn-core-shortcuts{grid-template-columns:1fr}
  .vn-tools-secondary{grid-template-columns:1fr}
  .vn-tools{grid-template-columns:1fr}
  .vn-bank-list{grid-template-columns:1fr}
  .vn-life-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vn-footer-grid{grid-template-columns:1fr}
  .vn-len-dau{right:12px;bottom:14px}
  .vn-title{font-size:18px}
  .vn-card > p:first-of-type{font-size:11px;padding-bottom:10px}
  .vn-action-btn,
  .vn-search-btn,
  .vn-news-btn,
  .vn-site-item a,
  .vn-ghim-btn{min-height:40px}
}

.vn-user-box{max-width:560px;margin:28px auto}
.vn-user-card{
  background:var(--the);border:1px solid var(--vien);border-radius:16px;
  box-shadow:var(--bong);padding:20px;
}
.vn-user-card h2{margin:0 0 12px;font-size:24px;color:var(--chu)}
.vn-user-card label{display:block;margin:10px 0 6px;font-size:13px;color:var(--phu)}
.vn-user-card input{
  width:100%;height:44px;border:1px solid var(--vien);border-radius:10px;
  padding:0 12px;background:var(--the);color:var(--chu)
}
.vn-user-btn{
  margin-top:14px;width:100%;height:44px;border:none;border-radius:10px;
  background:linear-gradient(135deg,var(--do),var(--nhan));color:#fff;font-weight:700;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
}
.vn-user-sub{margin:12px 0 0;font-size:13px;color:var(--phu)}
.vn-user-sub a{color:var(--do);font-weight:600}
.vn-user-note{margin:0 0 10px;padding:10px 12px;border-radius:10px;font-size:13px}
.vn-user-note.loi{background:rgba(211,47,47,.10);color:#b71c1c}
.vn-user-note.thanh-cong{background:rgba(56,142,60,.12);color:#1b5e20}

.vn-api-note,
.vn-status-note{
  margin:10px 0 0;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--vien);
  background:var(--the);
  color:var(--phu);
  font-size:13px;
}
.vn-status-note.loi{background:rgba(211,47,47,.10);border-color:rgba(211,47,47,.25);color:#b71c1c}
.vn-status-note.thanh-cong{background:rgba(56,142,60,.12);border-color:rgba(56,142,60,.28);color:#1b5e20}
.vn-status-note.dang-tai{
  background:rgba(25,118,210,.10);
  border-color:rgba(25,118,210,.28);
  color:var(--xanh);
}
