:root{--text:#cbd5e1;--text-muted:#94a3b8;--text-subtle:#64748b;--text-heading:#f8fafc;--bg:#0b0f14;--bg-elevated:#111827;--bg-subtle:#0f1419;--surface-hover:#94a3b814;--border:#1e293b;--accent:#38bdf8;--accent-secondary:#818cf8;--accent-muted:#38bdf81f;--accent-border:#38bdf859;--max-width:72rem;--header-height:4rem;--space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2.5rem;--space-xl:3.5rem;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-height:100svh;margin:0}#root{min-height:100svh}a{color:inherit;text-decoration:none}ul{margin:0;padding:0;list-style:none}h1,h2,h3,p{margin:0}h1{color:var(--text-heading);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:600}.layout{flex-direction:column;min-height:100svh;display:flex}.layout__content{width:100%;max-width:var(--max-width);padding:var(--space-lg) var(--space-md);flex:1;margin:0 auto}.layout__content:has(.home-page){max-width:none;padding:var(--space-lg) 0 0}.page{width:100%}.page-header{gap:var(--space-xs);flex-direction:column;display:flex}.page-header p{max-width:40rem;color:var(--text-muted)}.async-state{padding:var(--space-lg);text-align:center;border:1px solid var(--border);background:#0f1e3759;border-radius:.75rem}.async-state--loading{color:var(--text-muted)}.async-state--error{color:#f87171}.async-state__retry{margin-top:var(--space-sm);border:1px solid var(--border);color:var(--text-heading);cursor:pointer;background:0 0;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem}.async-state__retry:hover{border-color:var(--accent-border);color:var(--accent)}@media (width<=640px){.layout__content{padding:var(--space-md) var(--space-sm)}}.admin-layout{background:var(--bg);min-height:100svh;display:flex}.admin-layout__main{min-width:0;padding:var(--space-md);flex:1;overflow-x:auto}@media (width>=900px){.admin-layout__main{padding:var(--space-lg)}}.admin-sidebar{width:min(16rem,88vw);padding:var(--space-md);border-right:1px solid var(--border);background:var(--bg-elevated);flex-direction:column;flex-shrink:0;display:flex}.admin-sidebar__brand{margin-bottom:var(--space-lg)}.admin-sidebar__logo{color:var(--text-heading);margin-bottom:.375rem;font-size:1.125rem;font-weight:700;display:block}.admin-sidebar__badge{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-muted);border:1px solid var(--accent-border);border-radius:.25rem;padding:.2rem .5rem;font-size:.6875rem;font-weight:600;display:inline-block}.admin-sidebar__list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.admin-sidebar__link{color:var(--text-muted);border-radius:.5rem;padding:.625rem .875rem;font-size:.9375rem;font-weight:500;transition:background-color .15s,color .15s;display:block}.admin-sidebar__link:hover{background:var(--surface-hover);color:var(--text-heading)}.admin-sidebar__link--active{background:var(--accent-muted);color:var(--accent);font-weight:600}.admin-sidebar__footer{padding-top:var(--space-md);border-top:1px solid var(--border);margin-top:auto}.admin-sidebar__back{color:var(--text-subtle);font-size:.875rem;transition:color .15s}.admin-sidebar__back:hover{color:var(--accent)}.admin-page{max-width:72rem}.admin-page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.admin-page-header__title{color:var(--text-heading);margin-bottom:.375rem;font-size:clamp(1.375rem,3vw,1.75rem);font-weight:700}.admin-page-header__description{color:var(--text-muted);max-width:36rem;font-size:.9375rem}.admin-card{padding:var(--space-md);-webkit-backdrop-filter:blur(12px);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem}.admin-card--form{max-width:40rem}.admin-stats-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:1fr;display:grid}@media (width>=540px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.admin-stats-grid{grid-template-columns:repeat(4,1fr)}}.admin-stat-card{padding:var(--space-md);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:.75rem}.admin-stat-card__label{color:var(--text-subtle);margin-bottom:.375rem;font-size:.8125rem}.admin-stat-card__value{color:var(--text-heading);font-size:1.75rem;font-weight:700}.admin-stat-card__value--sm{font-size:1.125rem}.admin-overview-panels{gap:var(--space-md);display:grid}@media (width>=768px){.admin-overview-panels{grid-template-columns:1fr 1fr}}.admin-panel{padding:var(--space-md);border:1px solid var(--border);background:#0f1e3759;border-radius:.75rem}.admin-panel__title{color:var(--text-heading);margin-bottom:var(--space-sm);font-size:1rem;font-weight:600}.admin-overview-list{margin:0;padding:0;list-style:none}.admin-overview-list li{justify-content:space-between;gap:var(--space-sm);border-bottom:1px solid var(--border);color:var(--text-muted);padding:.625rem 0;font-size:.875rem;display:flex}.admin-overview-list li:last-child{border-bottom:none}.admin-overview-list span:first-child{color:var(--text-heading);font-weight:500}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.admin-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);background:#0003;font-size:.75rem;font-weight:600}.admin-table tbody tr{transition:background-color .15s}.admin-table tbody tr:hover{background:#38bdf80a}.admin-table-empty{text-align:center;color:var(--text-muted);padding:var(--space-lg)}.admin-table-actions{flex-wrap:wrap;gap:.375rem;display:flex}@media (width<=768px){.admin-layout{flex-direction:column}.admin-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%}.admin-sidebar__list{flex-flow:wrap}.admin-sidebar__footer,.admin-table thead{display:none}.admin-table tr{margin-bottom:var(--space-md);border:1px solid var(--border);border-radius:.5rem;display:block;overflow:hidden}.admin-table td{justify-content:space-between;gap:var(--space-sm);border-bottom:1px solid var(--border);display:flex}.admin-table td:before{content:attr(data-label);color:var(--text-subtle);text-transform:uppercase;font-size:.6875rem;font-weight:600}.admin-table td:last-child{border-bottom:none}}.admin-badge{text-transform:uppercase;border-radius:999px;padding:.2rem .5rem;font-size:.6875rem;font-weight:600;display:inline-block}.admin-badge--completed{color:#4ade80;background:#22c55e26}.admin-badge--in-progress{color:#38bdf8;background:#38bdf826}.admin-btn{cursor:pointer;border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;padding:.625rem 1.125rem;font-size:.875rem;font-weight:600;transition:transform .15s,background-color .15s,border-color .15s;display:inline-flex}.admin-btn:hover{transform:translateY(-1px)}.admin-btn--primary{color:#fff;background:linear-gradient(135deg,#0ea5e9,#6366f1)}.admin-btn--ghost{border-color:var(--border);color:var(--text-heading);background:0 0}.admin-btn--ghost:hover{background:var(--surface-hover)}.admin-btn--danger{color:#f87171;background:#ef444426;border-color:#ef444466}.admin-btn--danger:hover{background:#ef444440}.admin-btn--sm{padding:.375rem .75rem;font-size:.8125rem}.admin-form{gap:var(--space-sm);flex-direction:column;display:flex}.admin-form__row{gap:var(--space-sm);display:grid}@media (width>=540px){.admin-form__row{grid-template-columns:1fr 1fr}}.admin-form__field{flex-direction:column;gap:.375rem;display:flex}.admin-form__field span{color:var(--text-muted);font-size:.8125rem;font-weight:500}.admin-form__field input,.admin-form__field textarea,.admin-form__field select{border:1px solid var(--border);color:var(--text-heading);font:inherit;background:#00000040;border-radius:.5rem;padding:.625rem .75rem}.admin-form__field input:focus,.admin-form__field textarea:focus,.admin-form__field select:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-muted);outline:none}.admin-form__actions{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border);flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.admin-modal{z-index:200;padding:var(--space-md);place-items:center;display:grid;position:fixed;inset:0}.admin-modal__backdrop{cursor:pointer;background:#000000a6;border:none;position:absolute;inset:0}.admin-modal__dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:1rem;width:min(32rem,100%);max-height:90vh;position:relative;overflow-y:auto;box-shadow:0 24px 64px #00000080}.admin-modal__header{padding:var(--space-md);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.admin-modal__title{color:var(--text-heading);font-size:1.125rem;font-weight:600}.admin-modal__close{width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.375rem;font-size:1.5rem;line-height:1}.admin-modal__close:hover{background:var(--surface-hover);color:var(--text-heading)}.admin-modal__body{padding:var(--space-md)}.admin-confirm__message{color:var(--text-muted);margin-bottom:var(--space-md);line-height:1.55}.admin-alert{margin-bottom:var(--space-md);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.admin-alert--success{color:#4ade80;background:#22c55e1f;border:1px solid #4ade8059}.site-footer{border-top:1px solid var(--border);background:var(--bg-subtle);margin-top:auto}.site-footer__inner{gap:var(--space-lg);max-width:var(--max-width);padding:var(--space-xl) var(--space-md) var(--space-lg);margin:0 auto;display:grid}.footer-profile{gap:var(--space-md);align-items:flex-start;display:flex}.footer-profile__avatar{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:3.5rem;height:3.5rem;font-size:1.25rem;font-weight:700;display:grid}.footer-profile__content{flex-direction:column;gap:.375rem;display:flex}.footer-profile__name{color:var(--text-heading);font-size:1.125rem;font-weight:600}.footer-profile__role{color:var(--accent);font-size:.875rem;font-weight:500}.footer-profile__bio{max-width:36rem;color:var(--text-muted);font-size:.9375rem;line-height:1.6}.footer-profile__email{color:var(--text-heading);width:fit-content;font-size:.875rem;transition:color .15s}.footer-profile__email:hover{color:var(--accent)}.social-links{gap:var(--space-xs);flex-wrap:wrap;display:flex}.social-links__item{color:var(--text-muted)}.social-links__item:hover{color:var(--accent);border-color:var(--accent-border)}.footer-copyright{padding-top:var(--space-md);border-top:1px solid var(--border);color:var(--text-subtle);font-size:.8125rem}@media (width>=768px){.site-footer__inner{grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:start}.footer-profile{grid-area:1/1/span 2}.site-footer__right{flex-direction:column;grid-area:1/2/span 2;align-items:flex-end;gap:.75rem;display:flex}.footer-copyright{grid-column:1/-1}}.cart-page__layout{gap:var(--space-lg);display:grid}@media (width>=900px){.cart-page__layout{grid-template-columns:1fr min(22rem,100%);align-items:start}}.cart-list{gap:var(--space-md);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.cart-item{gap:var(--space-md);padding:var(--space-md);-webkit-backdrop-filter:blur(12px);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem;grid-template-columns:auto 1fr auto;align-items:start;transition:border-color .2s,box-shadow .2s;display:grid}.cart-item:hover{border-color:#7dd3fc38}.cart-item__media{aspect-ratio:1;background:#0c1929;border-radius:.5rem;flex-shrink:0;width:5.5rem;overflow:hidden}.cart-item__image{object-fit:cover;width:100%;height:100%}.cart-item__image-fallback{width:100%;height:100%;color:var(--text-muted);text-align:center;background:linear-gradient(135deg,#0c4a6e,#312e81);place-items:center;padding:.25rem;font-size:.75rem;font-weight:600;display:grid}.cart-item__name{color:var(--text-heading);margin-bottom:.25rem;font-size:1rem;font-weight:600}.cart-item__price{color:var(--text-subtle);margin-bottom:.75rem;font-size:.8125rem}.cart-item__controls{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.cart-qty{border:1px solid var(--border);background:#00000040;border-radius:.5rem;align-items:center;display:inline-flex;overflow:hidden}.cart-qty__btn{width:2rem;height:2rem;color:var(--text-heading);cursor:pointer;background:0 0;border:none;place-items:center;font-size:1.125rem;transition:background-color .15s;display:grid}.cart-qty__btn:hover{background:var(--surface-hover)}.cart-qty__value{text-align:center;min-width:2rem;color:var(--text-heading);font-size:.875rem;font-weight:600}.cart-item__remove{color:#f87171;cursor:pointer;background:0 0;border:none;border-radius:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;transition:background-color .15s}.cart-item__remove:hover{background:#ef44441f}.cart-item__total{color:var(--accent);white-space:nowrap;font-size:1.0625rem;font-weight:700}@media (width<=540px){.cart-item{grid-template-columns:auto 1fr}.cart-item__total{grid-column:2;justify-self:start}}.cart-summary{padding:var(--space-md);-webkit-backdrop-filter:blur(12px);top:calc(var(--header-height) + var(--space-md));background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem;position:sticky}.cart-summary__title{color:var(--text-heading);margin-bottom:var(--space-md);border-bottom:1px solid var(--border);padding-bottom:.75rem;font-size:1.125rem;font-weight:600}.cart-summary__rows{margin:0 0 var(--space-md)}.cart-summary__row{justify-content:space-between;gap:var(--space-sm);color:var(--text-muted);padding:.5rem 0;font-size:.9375rem;display:flex}.cart-summary__row dd{color:var(--text-heading);margin:0;font-weight:500}.cart-summary__row--total{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.75rem;font-size:1.0625rem}.cart-summary__row--total dt,.cart-summary__row--total dd{color:var(--text-heading);font-weight:700}.cart-summary__row--total dd{color:var(--accent);font-size:1.25rem}.cart-summary__checkout{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#6366f1);border:none;border-radius:.5rem;width:100%;padding:.75rem 1.25rem;font-size:.9375rem;font-weight:600;transition:transform .2s,box-shadow .2s}.cart-summary__checkout:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0ea5e959}.cart-summary__continue{margin-top:var(--space-sm);text-align:center;color:var(--accent);font-size:.875rem;font-weight:500;transition:color .15s;display:block}.cart-summary__continue:hover{color:#7dd3fc}.cart-empty{padding:var(--space-xl) var(--space-md);text-align:center;border:1px dashed var(--border);background:#0f1e374d;border-radius:1rem}.cart-empty__title{color:var(--text-heading);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.cart-empty__text{color:var(--text-muted);margin-bottom:var(--space-md);max-width:28rem;margin-inline:auto}.cart-empty__link{color:#fff;background:linear-gradient(135deg,#0ea5e9,#6366f1);border-radius:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.cart-empty__link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0ea5e959}.cart-button{position:relative}.cart-button__badge{color:#fff;text-align:center;border:2px solid var(--bg-elevated);background:linear-gradient(135deg,#0ea5e9,#6366f1);border-radius:999px;min-width:1.125rem;height:1.125rem;padding:0 .25rem;font-size:.625rem;font-weight:700;line-height:1.125rem;position:absolute;top:.125rem;right:.125rem}.navbar{z-index:100;border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--bg-elevated) 88%, transparent);-webkit-backdrop-filter:blur(12px);position:sticky;top:0}.navbar__inner{justify-content:space-between;align-items:center;gap:var(--space-md);max-width:var(--max-width);min-height:var(--header-height);padding:0 var(--space-md);margin:0 auto;display:flex}.navbar__nav--desktop{flex:1;justify-content:center;display:flex}.navbar__actions{align-items:center;gap:var(--space-xs);display:flex}.nav-logo{color:var(--text-heading);align-items:center;gap:.625rem;font-weight:700;transition:opacity .15s;display:inline-flex}.nav-logo:hover{opacity:.9}.nav-logo__mark{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));color:#fff;border-radius:.5rem;place-items:center;width:2rem;height:2rem;font-size:.875rem;font-weight:700;display:grid}.nav-logo__text{letter-spacing:-.02em;font-size:1.0625rem}.nav-links{align-items:center;gap:.25rem;display:flex}.nav-links--vertical{flex-direction:column;align-items:stretch;gap:.375rem}.nav-link{color:var(--text-muted);border-radius:.5rem;align-items:center;padding:.5rem .875rem;font-size:.9375rem;font-weight:500;transition:color .15s,background-color .15s;display:inline-flex}.nav-links--vertical .nav-link{padding:.75rem 1rem;font-size:1rem}.nav-link:hover{color:var(--text-heading);background:var(--surface-hover)}.nav-link--active{color:var(--accent);background:var(--accent-muted)}.nav-link--active:hover{color:var(--accent)}.icon-button{width:2.5rem;height:2.5rem;color:var(--text-heading);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;padding:0;transition:background-color .15s,border-color .15s,color .15s;display:inline-flex}.icon-button:hover{background:var(--surface-hover);border-color:var(--border)}.cart-button{color:var(--text-heading)}.hamburger-button{display:none}.mobile-menu__backdrop{z-index:110;cursor:pointer;background:#0009;border:none;position:fixed;inset:0}.mobile-menu{z-index:120;gap:var(--space-lg);width:min(18rem,88vw);height:100%;padding:calc(var(--header-height) + var(--space-md)) var(--space-md) var(--space-lg);border-left:1px solid var(--border);background:var(--bg-elevated);flex-direction:column;animation:.22s ease-out slide-in;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 32px #00000059}.mobile-menu__actions{padding-top:var(--space-md);border-top:1px solid var(--border);margin-top:auto}.mobile-menu__actions .cart-button{border:1px solid var(--border);border-radius:.5rem;width:100%;height:2.75rem}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}body.nav-open{overflow:hidden}@media (width<=768px){.navbar__nav--desktop{display:none}.hamburger-button{display:inline-flex}}@media (width>=769px){.hamburger-button{display:none}}.zalo-floating-btn{z-index:9999;color:#fff;cursor:pointer;background-color:#0068ff;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;text-decoration:none;transition:transform .3s,box-shadow .3s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #0068ff66}.zalo-floating-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #0068ff99}.zalo-floating-btn:before,.zalo-floating-btn:after{content:"";opacity:.8;pointer-events:none;border:2px solid #0068ff;border-radius:50%;animation:2s ease-out infinite zalo-pulse;position:absolute;inset:0}.zalo-floating-btn:after{animation-delay:1s}@keyframes zalo-pulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.6)}}.zalo-floating-btn svg{width:32px;height:32px}@media (width<=640px){.zalo-floating-btn{width:50px;height:50px;bottom:16px;right:16px}.zalo-floating-btn svg{width:26px;height:26px}}.home-page{--home-gradient:linear-gradient(160deg, #020617 0%, #0a1628 28%, #0c2347 52%, #0f2d5c 72%, #071422 100%);--glass-bg:#0f1e3773;--glass-border:#7dd3fc1f;--glass-shadow:0 8px 32px #00000059;--glow-cyan:#38bdf859;--glow-violet:#818cf840;margin:calc(-1 * var(--space-lg)) calc(-1 * var(--space-md)) 0;width:calc(100% + 2 * var(--space-md));background:var(--home-gradient);max-width:100vw;overflow-x:hidden}.home-container{width:100%;max-width:var(--max-width);padding-inline:var(--space-md);margin:0 auto}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);box-shadow:var(--glass-shadow);border-radius:1rem;transition:transform .25s,border-color .25s,box-shadow .25s}.glass-card:hover{box-shadow:var(--glass-shadow), 0 0 40px #38bdf814;border-color:#7dd3fc47}.btn{cursor:pointer;border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;transition:transform .2s,background-color .2s,border-color .2s,box-shadow .2s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn--primary{color:#fff;background:linear-gradient(135deg,#0ea5e9,#6366f1);box-shadow:0 4px 20px #0ea5e959}.btn--primary:hover{box-shadow:0 8px 28px #0ea5e973}.btn--secondary{border-color:var(--glass-border);color:var(--text-heading);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f1e3799}.btn--secondary:hover{background:#1e3a5f80;border-color:#7dd3fc59}.section-header{margin-bottom:var(--space-lg);max-width:40rem}.section-header__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.section-header__title{color:var(--text-heading);letter-spacing:-.02em;margin-bottom:.75rem;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:700}.section-header__description{color:var(--text-muted);margin-bottom:1rem;line-height:1.65}.section-header__action{color:var(--accent);font-size:.9375rem;font-weight:600;transition:color .2s,transform .2s;display:inline-flex}.section-header__action:hover{color:#7dd3fc;transform:translate(4px)}.home-section{padding-block:var(--space-xl)}.home-section--stats{padding-block:var(--space-lg)}.hero-section{padding-block:clamp(3rem,8vw,5rem);position:relative;overflow:hidden}.hero-section__bg{pointer-events:none;position:absolute;inset:0}.hero-section__grid{background-image:linear-gradient(#38bdf80a 1px,#0000 1px),linear-gradient(90deg,#38bdf80a 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70% at 50% 40%,#000,#0000);mask-image:radial-gradient(80% 70% at 50% 40%,#000,#0000)}.hero-section__orb{filter:blur(80px);opacity:.5;border-radius:50%;position:absolute}.hero-section__orb--1{background:var(--glow-cyan);width:400px;height:400px;top:-10%;right:-5%}.hero-section__orb--2{background:var(--glow-violet);width:300px;height:300px;bottom:0;left:-5%}.hero-section__inner{gap:var(--space-lg);align-items:center;display:grid;position:relative}@media (width>=900px){.hero-section__inner{grid-template-columns:1.1fr .9fr}}.hero-section__eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-size:.8125rem;font-weight:600}.hero-section__title{letter-spacing:-.03em;color:var(--text-heading);margin-bottom:1.25rem;font-size:clamp(2rem,5vw,3.25rem);font-weight:800;line-height:1.1}.hero-section__highlight{background:linear-gradient(135deg,#38bdf8,#818cf8);color:#0000;-webkit-background-clip:text;background-clip:text}.hero-section__description{color:var(--text-muted);max-width:36rem;margin-bottom:2rem;font-size:clamp(1rem,2vw,1.125rem);line-height:1.7}.hero-section__actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.hero-section__panel{padding:var(--space-md)}.hero-section__stats-preview{gap:var(--space-sm);margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.hero-section__stats-preview li{text-align:center;padding:var(--space-sm);border:1px solid var(--glass-border);background:#0003;border-radius:.5rem;transition:border-color .2s}.hero-section__panel:hover .hero-section__stats-preview li{border-color:#7dd3fc33}.hero-section__stat-value{color:var(--text-heading);font-size:1.25rem;font-weight:700;display:block}.hero-section__stat-label{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem;font-size:.6875rem;display:block}.hero-section__panel-caption{color:var(--text-muted);font-size:.875rem;line-height:1.6}.product-grid{gap:var(--space-md);grid-template-columns:1fr;display:grid}@media (width>=540px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.product-grid{grid-template-columns:repeat(3,1fr)}}.product-card__link{height:100%;color:inherit;flex-direction:column;display:flex}.product-card:hover{transform:translateY(-4px)}.product-card__visual{border-radius:1rem 1rem 0 0;place-items:center;height:8rem;display:grid;position:relative;overflow:hidden}.product-card--uav .product-card__visual{background:linear-gradient(135deg,#0c4a6e,#0369a1)}.product-card--iot .product-card__visual{background:linear-gradient(135deg,#312e81,#4f46e5)}.product-card--agriculture .product-card__visual{background:linear-gradient(135deg,#14532d,#15803d)}.product-card__icon{z-index:1;filter:drop-shadow(0 4px 12px #0000004d);font-size:2.5rem}.product-card__glow{filter:blur(40px);background:#ffffff26;border-radius:50%;width:120px;height:120px;transition:transform .3s;position:absolute}.product-card:hover .product-card__glow{transform:scale(1.4)}.product-card__body{padding:var(--space-md);flex-direction:column;flex:1;display:flex}.product-card__category{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:.6875rem;font-weight:600}.product-card__title{color:var(--text-heading);margin-bottom:.5rem;font-size:1.0625rem;font-weight:600}.product-card__description{color:var(--text-muted);flex:1;margin-bottom:1rem;font-size:.875rem;line-height:1.55}.product-card__cta{color:var(--accent);font-size:.8125rem;font-weight:600;transition:color .2s}.product-card:hover .product-card__cta{color:#7dd3fc}.project-grid{gap:var(--space-md);display:grid}@media (width>=768px){.project-grid{grid-template-columns:repeat(3,1fr)}}.project-card:hover{transform:translateY(-4px)}.project-card__link{height:100%;padding:var(--space-md);color:inherit;flex-direction:column;display:flex}.project-card__meta{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.project-card__year{color:var(--text-subtle);font-size:.8125rem;font-weight:500}.project-card__status{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.25rem .625rem;font-size:.6875rem;font-weight:600}.project-card__status--completed{color:#4ade80;background:#22c55e26;border:1px solid #4ade804d}.project-card__status--in-progress{color:#38bdf8;background:#38bdf826;border:1px solid #38bdf84d}.project-card__title{color:var(--text-heading);margin-bottom:.625rem;font-size:1.125rem;font-weight:600;line-height:1.35}.project-card__description{color:var(--text-muted);margin-bottom:var(--space-sm);flex:1;font-size:.875rem;line-height:1.6}.project-card__tags{margin-bottom:var(--space-md);flex-wrap:wrap;gap:.375rem;display:flex}.project-card__tags li{border:1px solid var(--glass-border);color:var(--text-muted);background:#00000040;border-radius:.25rem;padding:.25rem .5rem;font-size:.6875rem}.project-card__cta{color:var(--accent);margin-top:auto;font-size:.8125rem;font-weight:600;transition:color .2s}.project-card:hover .project-card__cta{color:#7dd3fc}.stats-grid{gap:var(--space-md);grid-template-columns:1fr;display:grid}@media (width>=640px){.stats-grid{grid-template-columns:repeat(3,1fr)}}.stat-card{padding:var(--space-lg) var(--space-md);text-align:center}.stat-card:hover{transform:translateY(-4px)}.stat-card__value{background:linear-gradient(135deg,#38bdf8,#a5b4fc);color:#0000;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:clamp(2.5rem,6vw,3.5rem);font-weight:800;line-height:1}.stat-card__suffix{font-size:.6em;font-weight:700}.stat-card__label{color:var(--text-muted);font-size:.9375rem;font-weight:500}.home-section--contact{padding-bottom:var(--space-xl)}.contact-cta{gap:var(--space-lg);padding:var(--space-lg);display:grid;position:relative;overflow:hidden}@media (width>=768px){.contact-cta{padding:var(--space-xl);grid-template-columns:1fr auto;align-items:center}}.contact-cta__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.75rem;font-weight:600}.contact-cta__title{color:var(--text-heading);letter-spacing:-.02em;margin-bottom:.75rem;font-size:clamp(1.5rem,3vw,2rem);font-weight:700}.contact-cta__description{color:var(--text-muted);max-width:32rem;margin-bottom:var(--space-md);line-height:1.65}.contact-cta__actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.contact-cta__visual{place-items:center;width:10rem;height:10rem;margin:0 auto;display:grid;position:relative}.contact-cta__ring{border:2px solid #38bdf840;border-radius:50%;animation:3s ease-in-out infinite pulse-ring;position:absolute;inset:0}.contact-cta__core{width:4rem;height:4rem;box-shadow:0 0 40px var(--glow-cyan);background:linear-gradient(135deg,#0ea5e9,#6366f1);border-radius:50%}@keyframes pulse-ring{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}@media (width<=480px){.hero-section__stats-preview{grid-template-columns:1fr}.hero-section__actions{flex-direction:column}.hero-section__actions .btn{width:100%}.contact-cta__actions{flex-direction:column}.contact-cta__actions .btn{width:100%}}.products-page__toolbar{gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-md);-webkit-backdrop-filter:blur(16px);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem;flex-direction:column;display:flex}@media (width>=900px){.products-page__toolbar{flex-direction:row;justify-content:space-between;align-items:flex-end}.product-search{flex:1;max-width:28rem}}.product-search__label{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:block}.product-search__field{position:relative}.product-search__icon{color:var(--text-subtle);pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.product-search__input{border:1px solid var(--border);width:100%;color:var(--text-heading);background:#00000040;border-radius:.5rem;padding:.75rem 1rem .75rem 2.75rem;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.product-search__input::placeholder{color:var(--text-subtle)}.product-search__input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-muted);outline:none}.product-search__meta{color:var(--text-subtle);margin-top:.5rem;font-size:.8125rem}.product-filter__label{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.product-filter__list{flex-wrap:wrap;gap:.5rem;display:flex}.product-filter__btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:#0003;border-radius:999px;padding:.5rem .875rem;font-size:.8125rem;font-weight:500;transition:background-color .2s,border-color .2s,color .2s,transform .2s}.product-filter__btn:hover{border-color:var(--accent-border);color:var(--text-heading);transform:translateY(-1px)}.product-filter__btn--active{background:var(--accent-muted);border-color:var(--accent-border);color:var(--accent);font-weight:600}.catalog-product-grid{gap:var(--space-md);grid-template-columns:1fr;margin:0;padding:0;list-style:none;display:grid}@media (width>=540px){.catalog-product-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.catalog-product-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1200px){.catalog-product-grid{grid-template-columns:repeat(4,1fr)}}.catalog-product-card{-webkit-backdrop-filter:blur(12px);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem;flex-direction:column;height:100%;transition:transform .25s,border-color .25s,box-shadow .25s;display:flex;overflow:hidden}.catalog-product-card:hover{border-color:#7dd3fc47;transform:translateY(-4px);box-shadow:0 12px 40px #00000059}.catalog-product-card__media{aspect-ratio:4/3;background:#0c1929;position:relative;overflow:hidden}.catalog-product-card__image{object-fit:cover;width:100%;height:100%;transition:transform .35s}.catalog-product-card:hover .catalog-product-card__image{transform:scale(1.05)}.catalog-product-card__image-fallback{width:100%;height:100%;color:var(--text-muted);background:linear-gradient(135deg,#0c4a6e,#312e81);place-items:center;font-size:.875rem;font-weight:600;display:grid}.catalog-product-card__badge{text-transform:uppercase;letter-spacing:.04em;color:var(--text-heading);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000008c;border:1px solid #ffffff1a;border-radius:999px;padding:.25rem .625rem;font-size:.6875rem;font-weight:600;position:absolute;top:.75rem;left:.75rem}.catalog-product-card__body{padding:var(--space-md);flex-direction:column;flex:1;gap:.5rem;display:flex}.catalog-product-card__name{color:var(--text-heading);font-size:1rem;font-weight:600;line-height:1.35}.catalog-product-card__price{color:var(--accent);font-size:1.125rem;font-weight:700}.catalog-product-card__description{color:var(--text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;font-size:.8125rem;line-height:1.55;display:-webkit-box;overflow:hidden}.catalog-product-card__cart-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#6366f1);border:none;border-radius:.5rem;width:100%;margin-top:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;transition:transform .2s,box-shadow .2s,opacity .2s}.catalog-product-card__cart-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0ea5e959}.catalog-product-card__cart-btn:disabled{opacity:.85;cursor:default}.product-grid-empty{padding:var(--space-xl) var(--space-md);text-align:center;border:1px dashed var(--border);background:#0f1e374d;border-radius:1rem}.product-grid-empty__title{color:var(--text-heading);margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.product-grid-empty__text{color:var(--text-muted);font-size:.9375rem}.catalog-product-card__actions{gap:.5rem;margin-top:.5rem;display:flex}.catalog-product-card__zalo-btn{color:#fff;cursor:pointer;background:#0068ff;border:none;border-radius:.5rem;flex:1.2;justify-content:center;align-items:center;gap:.25rem;padding:.625rem .5rem;font-size:.8125rem;font-weight:700;transition:transform .2s,box-shadow .2s,background-color .2s;display:flex}.catalog-product-card__zalo-btn:hover{background:#0056d6;transform:translateY(-2px);box-shadow:0 6px 15px #0068ff59}.catalog-product-card__zalo-btn--success{background:#22c55e!important;box-shadow:0 6px 15px #22c55e59!important}.catalog-product-card__media-link{width:100%;height:100%;display:block}.catalog-product-card__name-link{color:inherit;transition:color .15s}.catalog-product-card__name-link:hover{color:var(--accent)}.product-detail-page{width:100%}.product-detail__back{color:var(--text-muted);margin-bottom:var(--space-lg);align-items:center;gap:.5rem;font-size:.9375rem;font-weight:500;transition:color .2s,transform .2s;display:inline-flex}.product-detail__back:hover{color:var(--accent);transform:translate(-4px)}.product-detail__grid{gap:var(--space-xl);display:grid}@media (width>=768px){.product-detail__grid{grid-template-columns:minmax(280px,1.1fr) 1fr;align-items:start}}.product-detail__media{aspect-ratio:4/3;background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1.25rem;width:100%;overflow:hidden;box-shadow:0 10px 30px #0006}.product-detail__image{object-fit:cover;width:100%;height:100%;transition:transform .5s}.product-detail__media:hover .product-detail__image{transform:scale(1.03)}.product-detail__image-fallback{width:100%;height:100%;color:var(--text-muted);background:linear-gradient(135deg,#0c4a6e,#312e81);place-items:center;font-size:1.25rem;font-weight:700;display:grid}.product-detail__info{flex-direction:column;display:flex}.product-detail__badge{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-muted);border:1px solid var(--accent-border);margin-bottom:var(--space-sm);border-radius:9999px;align-self:flex-start;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.product-detail__name{color:var(--text-heading);letter-spacing:-.02em;margin-bottom:.5rem;font-size:clamp(1.75rem,3vw,2.5rem);font-weight:700}.product-detail__price{color:var(--accent);margin-bottom:var(--space-md);font-size:1.5rem;font-weight:700}.product-detail__description{color:var(--text-muted);margin-bottom:var(--space-lg);font-size:1rem;line-height:1.7}.product-detail__actions{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.product-detail__btn-cart{cursor:pointer;border:1px solid var(--border);min-width:160px;color:var(--text-heading);background:#0f1e3799;border-radius:.5rem;flex:1;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;transition:all .2s}.product-detail__btn-cart:hover:not(:disabled){background:var(--surface-hover);border-color:var(--accent-border);color:var(--accent)}.product-detail__btn-cart:disabled{color:var(--text-subtle);cursor:not-allowed;background:#0f1e374d}.product-detail__btn-zalo{cursor:pointer;color:#fff;background:#0068ff;border:none;border-radius:.5rem;flex:1.2;justify-content:center;align-items:center;gap:.5rem;min-width:190px;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #0068ff4d}.product-detail__btn-zalo:hover{background:#0056d6;transform:translateY(-2px);box-shadow:0 6px 18px #0068ff73}.product-detail__btn-zalo--success{background:#22c55e!important;box-shadow:0 4px 12px #22c55e4d!important}.product-detail__specs-card{border:1px solid var(--border);padding:var(--space-md);margin-top:var(--space-sm);background:#0f1e374d;border-radius:.75rem}.product-detail__specs-title{color:var(--text-heading);margin-bottom:var(--space-sm);font-size:.9375rem;font-weight:600}.product-detail__specs-list{flex-direction:column;gap:.625rem;display:flex}.product-detail__specs-item{color:var(--text-muted);align-items:center;gap:.625rem;font-size:.875rem;display:flex}.product-detail__specs-icon{color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.catalog-project-grid{gap:var(--space-md);grid-template-columns:1fr;margin:0;padding:0;list-style:none;display:grid}@media (width>=640px){.catalog-project-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.catalog-project-grid{grid-template-columns:repeat(3,1fr)}}.catalog-project-card{-webkit-backdrop-filter:blur(12px);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem;flex-direction:column;height:100%;transition:transform .25s,border-color .25s,box-shadow .25s;display:flex;overflow:hidden}.catalog-project-card:hover{border-color:#7dd3fc47;transform:translateY(-4px);box-shadow:0 12px 40px #00000059}.catalog-project-card__media{aspect-ratio:16/10;background:#0c1929;position:relative;overflow:hidden}.catalog-project-card__image{object-fit:cover;width:100%;height:100%;transition:transform .35s}.catalog-project-card:hover .catalog-project-card__image{transform:scale(1.05)}.catalog-project-card__image-fallback{width:100%;height:100%;padding:var(--space-md);text-align:center;color:var(--text-muted);background:linear-gradient(135deg,#0c4a6e,#312e81);place-items:center;font-size:.875rem;font-weight:600;display:grid}.catalog-project-card__year{color:var(--text-heading);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000008c;border:1px solid #ffffff1a;border-radius:999px;padding:.25rem .625rem;font-size:.6875rem;font-weight:600;position:absolute;top:.75rem;left:.75rem}.catalog-project-card__status{text-transform:uppercase;letter-spacing:.04em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;padding:.25rem .625rem;font-size:.6875rem;font-weight:600;position:absolute;top:.75rem;right:.75rem}.catalog-project-card__status--completed{color:#4ade80;background:#22c55e33;border:1px solid #4ade8059}.catalog-project-card__status--in-progress{color:#38bdf8;background:#38bdf833;border:1px solid #38bdf859}.catalog-project-card__body{padding:var(--space-md);flex-direction:column;flex:1;gap:.75rem;display:flex}.catalog-project-card__title{color:var(--text-heading);font-size:1.125rem;font-weight:600;line-height:1.35}.catalog-project-card__description{color:var(--text-muted);flex:1;font-size:.875rem;line-height:1.6}.catalog-project-card__technologies{flex-wrap:wrap;gap:.375rem;margin:0;padding:0;list-style:none;display:flex}.tech-badge{color:var(--accent);background:#00000040;border:1px solid #7dd3fc26;border-radius:.25rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:500;transition:background-color .2s,border-color .2s}.catalog-project-card:hover .tech-badge{border-color:#7dd3fc4d}.catalog-project-card__actions{flex-wrap:wrap;gap:.5rem;margin-top:auto;padding-top:.25rem;display:flex}.catalog-project-card__btn{cursor:pointer;border-radius:.5rem;flex:1;justify-content:center;align-items:center;gap:.375rem;min-width:7rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;transition:transform .2s,background-color .2s,border-color .2s,box-shadow .2s;display:inline-flex}.catalog-project-card__btn:hover{transform:translateY(-2px)}.catalog-project-card__btn--github{border:1px solid var(--border);color:var(--text-heading);background:#00000059}.catalog-project-card__btn--github:hover{background:#00000080;border-color:#ffffff40}.catalog-project-card__btn--demo{color:#fff;background:linear-gradient(135deg,#0ea5e9,#6366f1);border:1px solid #0000}.catalog-project-card__btn--demo:hover{box-shadow:0 6px 20px #0ea5e959}@media (width<=400px){.catalog-project-card__actions{flex-direction:column}.catalog-project-card__btn{width:100%}}.about-page__intro{margin-bottom:var(--space-lg)}.about-page__grid,.about-page__sidebar{gap:var(--space-md);display:grid}@media (width>=900px){.about-page__grid{grid-template-columns:1fr 1fr;align-items:start}.about-profile-card,.about-experience-card{grid-column:1/-1}}.about-card{padding:var(--space-md);-webkit-backdrop-filter:blur(16px);background:#0f1e3773;border:1px solid #7dd3fc1f;border-radius:1rem;transition:border-color .25s,box-shadow .25s;box-shadow:0 8px 32px #00000040}.about-card:hover{border-color:#7dd3fc38;box-shadow:0 12px 40px #0000004d}.about-card__title{color:var(--text-heading);margin-bottom:var(--space-md);border-bottom:1px solid var(--border);padding-bottom:.75rem;font-size:1.125rem;font-weight:600}.about-card__content{min-width:0}.about-profile{gap:var(--space-md);text-align:center;flex-direction:column;align-items:center;display:flex}@media (width>=640px){.about-profile{text-align:left;flex-direction:row;align-items:flex-start}}.about-profile__avatar{color:#fff;background:linear-gradient(135deg, var(--accent), var(--accent-secondary));border:3px solid #7dd3fc33;border-radius:50%;flex-shrink:0;place-items:center;width:7rem;height:7rem;font-size:1.75rem;font-weight:700;display:grid;box-shadow:0 0 40px #38bdf840}.about-profile__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.375rem;font-size:.75rem;font-weight:600}.about-profile__name{color:var(--text-heading);letter-spacing:-.02em;margin-bottom:.25rem;font-size:clamp(1.5rem,3vw,2rem);font-weight:700}.about-profile__title{color:var(--accent);margin-bottom:.5rem;font-size:1.0625rem;font-weight:500}.about-profile__location{color:var(--text-subtle);margin-bottom:1rem;font-size:.875rem}.about-profile__description{color:var(--text-muted);max-width:52rem;font-size:.9375rem;line-height:1.7}.skills-list{flex-direction:column;gap:1rem;margin:0;padding:0;list-style:none;display:flex}.skill-item__header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.skill-item__name{color:var(--text-heading);font-size:.9375rem;font-weight:600}.skill-item__level{color:var(--accent);font-size:.8125rem;font-weight:600}.skill-item__track{border:1px solid var(--border);background:#00000059;border-radius:999px;height:.5rem;overflow:hidden}.skill-item__bar{background:linear-gradient(90deg, var(--accent), var(--accent-secondary));border-radius:999px;height:100%;transition:width .6s}.about-card:hover .skill-item__bar{filter:brightness(1.1)}.experience-timeline{margin:0;padding:0;list-style:none}.timeline-item{gap:var(--space-md);padding-bottom:var(--space-lg);grid-template-columns:auto 1fr;display:grid;position:relative}.timeline-item--last{padding-bottom:0}.timeline-item__marker{flex-direction:column;align-items:center;padding-top:.25rem;display:flex}.timeline-item__marker:after{content:"";background:linear-gradient(180deg, var(--accent-border), transparent);flex:1;width:2px;margin-top:.5rem}.timeline-item--last .timeline-item__marker:after{display:none}.timeline-item__dot{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));width:.875rem;height:.875rem;box-shadow:0 0 12px var(--glow-cyan,#38bdf866);border:2px solid var(--bg);border-radius:50%}.timeline-item__period{letter-spacing:.04em;color:var(--accent);background:var(--accent-muted);border:1px solid var(--accent-border);border-radius:999px;margin-bottom:.5rem;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-block}.timeline-item__role{color:var(--text-heading);margin-bottom:.25rem;font-size:1.0625rem;font-weight:600}.timeline-item__company{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.timeline-item__description{color:var(--text-muted);font-size:.875rem;line-height:1.6}.contact-list{gap:var(--space-sm);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.contact-list__item{align-items:flex-start;gap:var(--space-sm);background:#0003;border:1px solid #0000;border-radius:.5rem;padding:.75rem;transition:border-color .2s,background-color .2s;display:flex}.contact-list__item:hover{border-color:var(--border);background:#0000004d}.contact-list__icon{background:var(--accent-muted);width:2.5rem;height:2.5rem;color:var(--accent);border-radius:.5rem;flex-shrink:0;place-items:center;display:grid}.contact-list__label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);margin-bottom:.125rem;font-size:.6875rem;font-weight:600;display:block}.contact-list__value{color:var(--text-heading);font-size:.9375rem;transition:color .2s}a.contact-list__value:hover{color:var(--accent)}.about-social__text{color:var(--text-muted);margin-bottom:var(--space-md);font-size:.875rem;line-height:1.55}.about-social__links{gap:var(--space-sm)}.about-social__links .social-links__item{border:1px solid var(--border);background:#0003;border-radius:.5rem;width:2.75rem;height:2.75rem}.about-social__links .social-links__item:hover{border-color:var(--accent-border);background:var(--accent-muted);transform:translateY(-2px)}.zalo-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:10000;padding:var(--space-md);background-color:#05080fd9;justify-content:center;align-items:center;animation:.25s ease-out zalo-fade-in;display:flex;position:fixed;inset:0}.zalo-modal-box{width:100%;max-width:500px;padding:var(--space-lg);background:#0b1220fa;border:1px solid #38bdf840;border-radius:1.25rem;animation:.3s cubic-bezier(.34,1.56,.64,1) zalo-scale-in;position:relative;overflow:hidden;box-shadow:0 20px 50px #0009,0 0 30px #38bdf80d}@keyframes zalo-fade-in{0%{opacity:0}to{opacity:1}}@keyframes zalo-scale-in{0%{opacity:0;transform:scale(.9)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.zalo-modal__header{margin-bottom:var(--space-md);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.zalo-modal__title{color:var(--text-heading);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.zalo-modal__title svg{color:#0068ff;width:24px;height:24px}.zalo-modal__close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.25rem;transition:background-color .2s,color .2s;display:flex}.zalo-modal__close-btn:hover{background-color:var(--surface-hover);color:var(--text-heading)}.zalo-modal__description{color:var(--text-muted);margin-bottom:var(--space-md);font-size:.875rem;line-height:1.5}.zalo-modal__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);margin-bottom:.5rem;font-size:.8125rem;font-weight:600;display:block}.zalo-modal__preview-container{margin-bottom:var(--space-md);position:relative}.zalo-modal__message-preview{white-space:pre-wrap;border:1px solid var(--border);padding:var(--space-sm);color:var(--text);background:#00000073;border-radius:.5rem;max-height:180px;margin:0;font-family:inherit;font-size:.9rem;line-height:1.6;overflow-y:auto}.zalo-modal__copy-overlay-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:#0f172acc;border-radius:.375rem;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600;transition:all .2s;display:flex;position:absolute;top:8px;right:8px}.zalo-modal__copy-overlay-btn:hover{border-color:var(--accent-border);color:var(--accent);background:#0f172af2}.zalo-modal__copy-overlay-btn--success{color:#22c55e!important;border-color:#22c55e!important}.zalo-modal__actions{margin-top:var(--space-lg);flex-direction:column;gap:.75rem;display:flex}.zalo-modal__btn-zalo{color:#fff;cursor:pointer;background:#0068ff;border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.875rem 1.25rem;font-size:.9375rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #0068ff4d}.zalo-modal__btn-zalo:hover{background:#0056d6;transform:translateY(-2px);box-shadow:0 6px 18px #0068ff73}.zalo-modal__btn-secondary{border:1px solid var(--border);width:100%;color:var(--text-heading);cursor:pointer;background:0 0;border-radius:.5rem;padding:.875rem 1.25rem;font-size:.9375rem;font-weight:600;transition:all .2s}.zalo-modal__btn-secondary:hover{background:var(--surface-hover);border-color:var(--text-muted)}
