/* KT DECAL — Dark Premium Auto Care — v3.0 */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&family=Manrope:wght@400;500;600;700;800&display=swap');
:root{--bg:#0D0B0A;--surface:#1A1614;--surface2:#231E1B;--glass:rgba(26,22,20,.72);--glass2:rgba(26,22,20,.88);--border:rgba(255,255,255,.06);--border-accent:rgba(255,107,44,.18);--text:#F5F2F0;--text2:#A69B96;--text3:#6B5F58;--accent:#ff6b2c;--accent2:#ff8f4c;--accent-glow:rgba(255,107,44,.25);--gold:#ffd700;--green:#10b981;--red:#ef4444;--radius:20px;--radius-sm:12px;--radius-lg:28px;--radius-pill:999px;--shadow:0 20px 60px rgba(0,0,0,.5);--shadow-accent:0 16px 40px rgba(255,107,44,.2);--font-head:'Outfit',sans-serif;--font-body:'Manrope',sans-serif;--header-h:60px;--bottom-h:72px;--safe-b:env(safe-area-inset-bottom,0px)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}
body.ktd-body{font-family:var(--font-body);color:var(--text);background:var(--bg);min-height:100vh;min-height:100dvh;overflow-x:hidden;line-height:1.6;padding-bottom:calc(var(--bottom-h) + var(--safe-b) + 16px);-webkit-font-smoothing:antialiased}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:99px}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none;transition:.2s}

/* Shell */
.ktd-shell{width:min(1140px,100% - 24px);margin-inline:auto}

/* Typography */
.ktd-h1{font-family:var(--font-head);font-size:clamp(32px,8vw,64px);font-weight:900;line-height:1;letter-spacing:-.04em;color:var(--text)}
.ktd-h2{font-family:var(--font-head);font-size:clamp(24px,5vw,42px);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--text)}
.ktd-h3{font-family:var(--font-head);font-size:clamp(18px,3vw,24px);font-weight:700;letter-spacing:-.02em;color:var(--text)}
.ktd-lead{font-size:clamp(15px,2vw,18px);color:var(--text2);line-height:1.7;max-width:560px}

/* Header */
.ktd-topbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-h);background:var(--glass2);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);transition:height .3s,box-shadow .3s}
.ktd-topbar.scrolled{height:52px;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.ktd-topbar-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:12px}
.ktd-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);min-width:0}
.ktd-brand-logo{width:40px;height:40px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;overflow:hidden;flex:none;box-shadow:var(--shadow-accent)}
.ktd-brand-logo img{width:100%;height:100%;object-fit:cover}
.ktd-brand-logo.has-img i{display:none}
.ktd-brand-logo.no-img i{display:block;font-size:18px;color:#fff}
.ktd-brand-text{display:flex;flex-direction:column;min-width:0;line-height:1.15}
.ktd-brand-text strong{font-family:var(--font-head);font-size:16px;font-weight:900;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.ktd-brand-text small{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.ktd-top-actions{display:flex;align-items:center;gap:8px}
.ktd-call-mini{display:none;text-decoration:none;color:var(--accent);font-weight:800;align-items:center;gap:6px;font-size:14px}
.ktd-menu-btn{width:44px;height:44px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:22px;display:grid;place-items:center;cursor:pointer;transition:.2s}
.ktd-menu-btn:active{transform:scale(.92)}

/* Desktop Nav */
.ktd-desktop-nav{display:none;align-items:center;gap:2px}
.ktd-desktop-nav a{text-decoration:none;color:var(--text2);font-family:var(--font-head);font-weight:700;font-size:14px;padding:10px 14px;border-radius:var(--radius-sm);transition:.2s}
.ktd-desktop-nav a:hover,.ktd-desktop-nav a.active{color:var(--accent);background:rgba(255,107,44,.08)}
.ktd-btn-header{display:none;align-items:center;gap:7px;padding:10px 18px;border-radius:var(--radius-sm);background:var(--accent);color:#fff!important;font-weight:800;font-size:13px;border:0;box-shadow:var(--shadow-accent);white-space:nowrap}

/* Drawer */
.ktd-drawer{position:fixed;inset:0;z-index:2000;pointer-events:none;visibility:hidden}
.ktd-drawer.is-open{pointer-events:auto;visibility:visible}
.ktd-drawer-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);opacity:0;transition:.3s}
.ktd-drawer.is-open .ktd-drawer-backdrop{opacity:1}
.ktd-drawer-panel{position:absolute;right:0;top:0;bottom:0;width:min(320px,85vw);background:var(--surface);border-left:1px solid var(--border);padding:20px;transform:translateX(100%);transition:.35s cubic-bezier(.22,.68,.18,1)}
.ktd-drawer.is-open .ktd-drawer-panel{transform:none}
.ktd-drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.ktd-drawer-head strong{font-family:var(--font-head);font-size:18px;font-weight:800}
.ktd-drawer-head button{width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text);cursor:pointer}
.ktd-drawer-panel a{display:flex;align-items:center;gap:14px;padding:14px 12px;border-radius:var(--radius-sm);color:var(--text2);font-weight:700;transition:.2s}
.ktd-drawer-panel a:hover,.ktd-drawer-panel a.active{color:var(--accent);background:rgba(255,107,44,.06)}
.ktd-drawer-panel a i{font-size:18px;width:24px;text-align:center}

/* Buttons */
.ktd-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;text-decoration:none;border-radius:var(--radius);padding:14px 22px;font-family:var(--font-head);font-weight:800;font-size:15px;line-height:1.15;cursor:pointer;transition:.25s;position:relative;overflow:hidden;white-space:nowrap;min-height:50px}
.ktd-btn-primary{background:var(--accent);color:#fff!important;box-shadow:var(--shadow-accent)}
.ktd-btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 20px 50px rgba(255,107,44,.3)}
.ktd-btn-ghost{background:transparent;color:var(--text)!important;border:1px solid var(--border)}
.ktd-btn-ghost:hover{border-color:var(--accent);color:var(--accent)!important;background:rgba(255,107,44,.05)}
.ktd-btn-sm{padding:10px 16px;font-size:13px;min-height:40px;border-radius:var(--radius-sm)}

/* Kicker / Badge / Pill */
.ktd-kicker{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:var(--radius-pill);background:rgba(255,107,44,.1);border:1px solid var(--border-accent);color:var(--accent);font-weight:800;font-size:12px}
.ktd-pill{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius-pill);background:var(--surface2);color:var(--text2);font-weight:700;font-size:13px;text-decoration:none;border:1px solid var(--border);transition:.2s}
.ktd-pill:hover{border-color:var(--accent);color:var(--accent);background:rgba(255,107,44,.06)}
.ktd-badges{display:flex;gap:8px;flex-wrap:wrap}

/* Status */
.ktd-status{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius-pill);font-size:12px;font-weight:800}
.ktd-status::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}
.ktd-status.ok{background:rgba(16,185,129,.12);color:var(--green)}
.ktd-status.warn{background:rgba(255,215,0,.12);color:var(--gold)}
.ktd-status.danger{background:rgba(239,68,68,.12);color:var(--red)}

/* Hero */
.ktd-hero{position:relative;min-height:calc(100dvh - var(--header-h));display:flex;align-items:flex-end;padding:0 0 40px;overflow:hidden}
.ktd-hero-bg{position:absolute;inset:0;z-index:0}
.ktd-hero-bg img{width:100%;height:100%;object-fit:cover}
.ktd-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--bg) 0%,rgba(13,11,10,.85) 35%,rgba(13,11,10,.5) 100%)}
.ktd-hero-content{position:relative;z-index:2;width:100%}
.ktd-hero h1{margin-bottom:16px}
.ktd-hero .ktd-lead{margin-bottom:20px}
.ktd-hero .ktd-actions{margin-bottom:20px}
.ktd-hero .ktd-badges{margin-top:16px}
.ktd-hero .ktd-badges span{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-pill);background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text2);font-weight:700;font-size:12px;backdrop-filter:blur(12px)}
.ktd-hero .ktd-badges span i{color:var(--accent)}
.ktd-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Sections */
.ktd-section{padding:56px 0}
.ktd-section-head{margin-bottom:24px}
.ktd-section-head .ktd-kicker{margin-bottom:12px}
.ktd-section-head h2{margin-bottom:8px}
.ktd-section-head p{color:var(--text2);max-width:480px}
.ktd-section-head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px}
.ktd-section-head-row a{font-weight:800;color:var(--accent);font-size:14px;white-space:nowrap}

/* Grid */
.ktd-grid{display:grid;gap:14px}
.ktd-grid-2{grid-template-columns:repeat(2,1fr)}
.ktd-grid-3{grid-template-columns:1fr}

/* Cards */
.ktd-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:.25s;text-decoration:none;color:inherit}
.ktd-card:hover{border-color:var(--border-accent);box-shadow:0 0 0 1px rgba(255,107,44,.08),0 20px 50px rgba(0,0,0,.3)}
.ktd-card-img{position:relative;overflow:hidden}
.ktd-card-img img{width:100%;height:200px;object-fit:cover;transition:.35s}
.ktd-card:hover .ktd-card-img img{transform:scale(1.04)}
.ktd-card-body{padding:16px}
.ktd-card h3{font-family:var(--font-head);font-size:17px;font-weight:800;margin-bottom:6px;letter-spacing:-.01em}
.ktd-card p{color:var(--text2);font-size:14px;line-height:1.6;margin-bottom:8px}
.ktd-price{font-family:var(--font-head);font-weight:900;color:var(--accent);font-size:15px}

/* Feed / Portfolio */
.ktd-feed{display:grid;gap:16px}
.ktd-post{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.ktd-post-head{display:flex;align-items:center;gap:10px;padding:14px 16px}
.ktd-avatar{width:38px;height:38px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--gold));display:grid;place-items:center;color:#fff;font-weight:900;font-size:13px;flex:none}
.ktd-post-head strong{font-size:14px}
.ktd-post-head small{color:var(--text3);font-size:12px}
.ktd-post-images{display:grid;gap:2px}
.ktd-post-images img{width:100%;height:280px;object-fit:cover;cursor:pointer;transition:.2s}
.ktd-post-images img:active{opacity:.85}
.ktd-post-images.multi{grid-template-columns:1fr 1fr}
.ktd-post-images.multi img{height:160px}
.ktd-post-body{padding:14px 16px}
.ktd-post-body h3{font-family:var(--font-head);font-size:17px;font-weight:800;margin-bottom:6px}
.ktd-post-body p{color:var(--text2);font-size:14px;margin-bottom:10px}
.ktd-post-actions{display:flex;gap:8px;flex-wrap:wrap}

/* Process / Steps */
.ktd-process-list{display:grid;gap:0;position:relative;padding-left:28px}
.ktd-process-list::before{content:'';position:absolute;left:11px;top:24px;bottom:24px;width:2px;background:var(--border)}
.ktd-process-item{position:relative;padding:16px 0 16px 20px}
.ktd-process-num{position:absolute;left:-28px;top:16px;width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--font-head);font-weight:900;font-size:12px;display:grid;place-items:center;z-index:1}
.ktd-process-item h3{font-family:var(--font-head);font-size:16px;font-weight:800;margin-bottom:4px}
.ktd-process-item p{color:var(--text2);font-size:14px}

/* Page Hero */
.ktd-page-hero{padding:calc(var(--header-h) + 32px) 0 24px}
.ktd-page-hero h1{font-family:var(--font-head);font-size:clamp(28px,6vw,48px);font-weight:900;letter-spacing:-.03em;margin-bottom:8px}
.ktd-page-hero .ktd-lead{margin-bottom:16px}

/* Detail */
.ktd-detail{padding:calc(var(--header-h) + 20px) 0 40px}
.ktd-detail-img{margin-bottom:20px}
.ktd-detail-img img{width:100%;height:auto;max-height:50vh;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border)}
.ktd-detail-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.ktd-detail-content h1{font-family:var(--font-head);font-size:clamp(26px,5vw,44px);font-weight:900;letter-spacing:-.03em;margin-bottom:10px}
.ktd-rich{color:var(--text2);line-height:1.8;font-size:15px}
.ktd-rich h2,.ktd-rich h3{color:var(--text);font-family:var(--font-head);margin:20px 0 8px}
.ktd-rich img{border-radius:var(--radius);margin:16px 0}
.ktd-rich ul,.ktd-rich ol{padding-left:20px}
.ktd-rich li{margin-bottom:4px}
.ktd-rich a{color:var(--accent)}

/* Wizard (Booking / Warranty) */
.ktd-wizard{min-height:calc(100dvh - var(--header-h));display:flex;align-items:center;padding:calc(var(--header-h) + 16px) 0 calc(var(--bottom-h) + var(--safe-b) + 32px)}
.ktd-wizard-card{width:min(640px,100%);margin:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden}
.ktd-step-title{margin-bottom:16px}
.ktd-step-title h1{font-family:var(--font-head);font-size:clamp(24px,5vw,36px);font-weight:900;letter-spacing:-.03em;margin:0}
.ktd-step-title small{color:var(--text3);font-weight:600;font-size:13px}

/* Progress bar */
.ktd-progress{height:4px;background:var(--surface2);border-radius:99px;margin-bottom:20px;overflow:hidden}
.ktd-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--gold));border-radius:99px;transition:width .4s cubic-bezier(.22,.68,.18,1)}

/* Step indicators */
.ktd-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:20px}
.ktd-step{height:4px;border-radius:99px;background:var(--surface2);transition:.3s}
.ktd-step.active,.ktd-step.done{background:var(--accent)}

/* Panes */
.ktd-pane{display:none}
.ktd-pane.active{display:block;animation:ktdSlideIn .35s cubic-bezier(.22,.68,.18,1)}
.ktd-pane.slide-out-left{animation:ktdSlideOutLeft .3s ease forwards}
.ktd-pane.slide-in-right{animation:ktdSlideInRight .35s cubic-bezier(.22,.68,.18,1) forwards}
@keyframes ktdSlideIn{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes ktdSlideOutLeft{from{opacity:1;transform:none}to{opacity:0;transform:translateX(-24px)}}
@keyframes ktdSlideInRight{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
.ktd-pane h2{font-family:var(--font-head);font-weight:800;font-size:20px;letter-spacing:-.02em;margin-bottom:4px}
.ktd-pane-note{color:var(--text3);font-size:14px;margin-bottom:16px}

/* Forms */
.ktd-form-grid{display:grid;gap:14px}
.ktd-field label{font-weight:700;font-size:13px;color:var(--text2);margin-bottom:6px;display:block}
.ktd-field input,.ktd-field select,.ktd-field textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;color:var(--text);font-family:var(--font-body);font-size:15px;font-weight:600;outline:none;transition:.25s;-webkit-appearance:none}
.ktd-field input::placeholder,.ktd-field textarea::placeholder{color:var(--text3)}
.ktd-field input:focus,.ktd-field select:focus,.ktd-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.ktd-field .is-invalid{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(239,68,68,.15)!important}
.ktd-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23A69B96' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.ktd-field select option{background:var(--surface);color:var(--text)}

/* Wizard actions */
.ktd-wizard-actions{display:flex;justify-content:space-between;gap:10px;margin-top:20px}
.ktd-wizard-actions .ktd-btn{flex:1;border-radius:var(--radius)}

/* Summary */
.ktd-summary{display:grid;gap:8px}
.ktd-summary-row{display:flex;justify-content:space-between;gap:12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}
.ktd-summary-row span{color:var(--text3);font-weight:700;font-size:13px}
.ktd-summary-row b{text-align:right;color:var(--text);font-size:14px}

/* Success */
.ktd-success-state{text-align:center;padding:32px 0}
.ktd-success-icon{width:72px;height:72px;border-radius:50%;background:rgba(16,185,129,.12);display:grid;place-items:center;margin:0 auto 16px;font-size:32px;color:var(--green)}
.ktd-success-state h1{font-family:var(--font-head);font-size:clamp(24px,5vw,36px);font-weight:900;margin-bottom:8px}
.ktd-success-state .ktd-lead{margin:0 auto 20px}

/* Tabs */
.ktd-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--radius-sm);padding:4px;margin-bottom:16px}
.ktd-tabs button{flex:1;border:0;border-radius:10px;padding:10px 8px;background:transparent;font-family:var(--font-head);font-weight:700;color:var(--text3);font-size:13px;cursor:pointer;transition:.2s}
.ktd-tabs button.active{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}

/* Map */
.ktd-map{height:300px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.ktd-map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) brightness(.8)}

/* Chat Widget */
.ktd-chat{position:fixed;right:14px;bottom:calc(var(--bottom-h) + var(--safe-b) + 24px);z-index:1050}
.ktd-chat-btn{width:56px;height:56px;border:0;border-radius:18px;background:var(--accent);color:#fff;font-size:24px;box-shadow:var(--shadow-accent);cursor:pointer;transition:.25s;display:grid;place-items:center}
.ktd-chat-btn:active{transform:scale(.9)}
.ktd-chat-menu{position:absolute;right:0;bottom:68px;width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px;box-shadow:var(--shadow);opacity:0;transform:translateY(10px) scale(.96);pointer-events:none;transition:.25s}
.ktd-chat.open .ktd-chat-menu{opacity:1;transform:none;pointer-events:auto}
.ktd-chat-menu a{display:flex;gap:10px;align-items:center;text-decoration:none;color:var(--text2);font-weight:700;padding:11px 12px;border-radius:var(--radius-sm);font-size:14px;transition:.2s}
.ktd-chat-menu a:hover{background:rgba(255,107,44,.06);color:var(--accent)}

/* Bottom Nav */
.ktd-bottom-nav{position:fixed;left:10px;right:10px;bottom:calc(8px + var(--safe-b));z-index:1040;display:grid;grid-template-columns:repeat(5,1fr);background:var(--glass2);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:22px;padding:6px;box-shadow:0 8px 32px rgba(255,107,44,.08)}
.ktd-bottom-nav a{text-decoration:none;color:var(--text3);display:flex;flex-direction:column;align-items:center;gap:2px;font-size:10px;font-weight:800;padding:8px 4px;border-radius:16px;transition:.2s}
.ktd-bottom-nav a i{font-size:18px}
.ktd-bottom-nav a.active{color:var(--accent);background:rgba(255,107,44,.08)}
.ktd-bottom-nav a.main{transform:translateY(-14px);background:var(--accent);color:#fff;border-radius:18px;padding:10px 8px;box-shadow:var(--shadow-accent);min-width:0}
.ktd-bottom-nav a.main i{font-size:20px}
.ktd-bottom-nav a.main span{font-size:10px}
.ktd-bottom-nav a.main.active{background:var(--accent2)}

/* Footer */
.ktd-footer{background:var(--surface);border-top:1px solid var(--border);padding:40px 0 20px;margin-top:40px}
.ktd-footer h3,.ktd-footer h4{font-family:var(--font-head);color:var(--text);font-weight:800;margin-bottom:12px}
.ktd-footer p{color:var(--text2);font-size:14px;line-height:1.7}
.ktd-footer-grid{display:grid;gap:28px}
.ktd-footer ul{list-style:none;display:grid;gap:8px}
.ktd-footer li{font-size:14px;color:var(--text2)}
.ktd-footer li a{color:var(--text2)}
.ktd-footer li a:hover{color:var(--accent)}
.ktd-footer li i{width:20px;color:var(--accent);margin-right:6px}
.ktd-socials{display:flex;gap:8px;margin-top:12px}
.ktd-socials a{width:38px;height:38px;border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text2);transition:.2s}
.ktd-socials a:hover{border-color:var(--accent);color:var(--accent)}
.ktd-footer-bottom{border-top:1px solid var(--border);padding-top:14px;margin-top:20px;color:var(--text3);font-size:13px}

/* Alert */
.ktd-alert{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;font-size:14px;color:var(--text)}
.alert-danger.ktd-alert{border-color:rgba(239,68,68,.2);background:rgba(239,68,68,.06);color:var(--red)}
.alert-success.ktd-alert{border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.06);color:var(--green)}

/* Lightbox */
.ktd-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;z-index:3000;padding:16px}
.ktd-lightbox.open{display:flex}
.ktd-lightbox img{max-width:96vw;max-height:88vh;border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,.6)}
.ktd-lightbox button{position:absolute;top:14px;right:14px;border:0;background:rgba(255,255,255,.1);backdrop-filter:blur(12px);width:44px;height:44px;border-radius:var(--radius-sm);color:#fff;font-size:18px;cursor:pointer}

/* Ripple */
.ktd-ripple{position:absolute;width:16px;height:16px;border-radius:999px;background:rgba(255,255,255,.2);transform:scale(1);animation:ktdRipple .55s ease-out forwards;pointer-events:none}
@keyframes ktdRipple{to{transform:scale(20);opacity:0}}

/* Reveal */
.ktd-reveal{opacity:0;transform:translateY(20px);transition:.6s cubic-bezier(.22,.68,.18,1)}
.ktd-reveal.is-visible{opacity:1;transform:none}

/* Confetti canvas */
.ktd-confetti{position:fixed;inset:0;pointer-events:none;z-index:9999}

/* Loading state */
.is-loading{opacity:.6;pointer-events:none}

/* ===== RESPONSIVE ===== */
@media(max-width:767px){
.ktd-hero h1{font-size:clamp(32px,9vw,48px)}
.ktd-card-img img{height:180px}
.ktd-post-images img{height:220px}
.ktd-post-images.multi img{height:140px}
.ktd-detail{display:block}
.ktd-wizard-card{border-radius:var(--radius);padding:16px}
.ktd-footer-grid{grid-template-columns:1fr}
}

@media(min-width:768px){
.ktd-grid-3{grid-template-columns:repeat(2,1fr)}
.ktd-feed{grid-template-columns:repeat(2,1fr)}
.ktd-footer-grid{grid-template-columns:1fr 1fr}
}

@media(min-width:992px){
body.ktd-body{padding-bottom:0}
.ktd-bottom-nav{display:none}
.ktd-desktop-nav{display:flex}
.ktd-btn-header{display:inline-flex}
.ktd-call-mini{display:flex}
.ktd-menu-btn{display:none}
.ktd-brand-text strong{max-width:200px;font-size:18px}
.ktd-brand-text small{max-width:200px}
.ktd-grid-3{grid-template-columns:repeat(3,1fr)}
.ktd-grid-2{grid-template-columns:repeat(2,1fr)}
.ktd-hero{min-height:85vh;align-items:center;padding:60px 0}
.ktd-hero-content{max-width:600px}
.ktd-section{padding:80px 0}
.ktd-detail{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.ktd-detail-img{margin-bottom:0}
.ktd-detail-img img{max-height:70vh}
.ktd-feed{grid-template-columns:repeat(2,1fr)}
.ktd-footer-grid{grid-template-columns:1.3fr 1fr 1fr}
.ktd-chat{bottom:24px;right:24px}
.ktd-map{height:420px}
.ktd-card-img img{height:240px}
}

@media(min-width:1200px){
.ktd-grid-3{grid-template-columns:repeat(3,1fr)}
.ktd-hero h1{font-size:64px}
}

@media(prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:0s!important;transition-duration:0s!important}
.ktd-reveal{opacity:1;transform:none}
}

/* ========== KT DECAL FIXES 2026 ========== */
/* Hero — chữ thoáng hơn trên mobile, không sát mép */
.ktd-hero{padding:0 0 56px}
.ktd-hero .ktd-shell.ktd-hero-content{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right))}
.ktd-hero .ktd-lead{max-width:640px;line-height:1.65}
.ktd-hero h1{letter-spacing:-.5px}

/* Khung ảnh sản phẩm / dịch vụ / bài viết → vuông 1:1 */
.ktd-card-img{aspect-ratio:1/1;display:block}
.ktd-card-img img{width:100%!important;height:100%!important;aspect-ratio:1/1;object-fit:cover;display:block}
.ktd-post-images img{aspect-ratio:1/1;height:auto!important;object-fit:cover;width:100%}
.ktd-post-images.multi img{aspect-ratio:1/1;height:auto!important}
@media (min-width:768px){
  .ktd-card-img img,.ktd-card-img{aspect-ratio:1/1}
}

/* Avatar người đăng trong feed (hỗ trợ avatar ảnh thực) */
.ktd-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#ff8a4c);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px;overflow:hidden;flex-shrink:0}
.ktd-avatar.has-img{background:transparent;padding:0}
.ktd-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* Bong bóng chat 3 nút + avatar + rung rung */
@keyframes ktdWiggle{
  0%,92%,100%{transform:rotate(0) scale(1)}
  93%{transform:rotate(-10deg) scale(1.05)}
  95%{transform:rotate(10deg) scale(1.05)}
  97%{transform:rotate(-6deg) scale(1.05)}
  99%{transform:rotate(4deg) scale(1.05)}
}
@keyframes ktdPulseDot{0%{transform:scale(1);opacity:1}70%{transform:scale(2.2);opacity:0}100%{transform:scale(2.2);opacity:0}}
.ktd-chat-btn{position:relative;animation:ktdWiggle 3.2s ease-in-out infinite;overflow:visible}
.ktd-chat-btn:hover,.ktd-chat.open .ktd-chat-btn{animation:none}
.ktd-chat-btn.has-avatar{padding:0;background:#fff;border:2px solid var(--accent)}
.ktd-chat-btn.has-avatar img{width:100%;height:100%;object-fit:cover;border-radius:16px}
.ktd-chat-dot{position:absolute;top:6px;right:6px;width:12px;height:12px;background:#22c55e;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 0 rgba(34,197,94,.7)}
.ktd-chat-dot::after{content:'';position:absolute;inset:-2px;border-radius:50%;background:#22c55e;animation:ktdPulseDot 1.6s ease-out infinite;z-index:-1}
.ktd-chat-item{position:relative;padding-left:14px!important}
.ktd-chat-item i{width:24px;text-align:center;font-size:16px}
.ktd-chat-item.zalo:hover{background:rgba(0,104,255,.08);color:#0068ff}
.ktd-chat-item.zalo i{color:#0068ff}
.ktd-chat-item.phone:hover{background:rgba(34,197,94,.08);color:#16a34a}
.ktd-chat-item.phone i{color:#16a34a}
.ktd-chat-item.map:hover{background:rgba(234,67,53,.08);color:#ea4335}
.ktd-chat-item.map i{color:#ea4335}

/* ========== KT DECAL v2: FONT + MOBILE GRID ========== */
/* Override font: Be Vietnam Pro (body) + Manrope (heading) — hỗ trợ dấu tiếng Việt đầy đủ */
:root{
  --font-body:'Be Vietnam Pro', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  --font-head:'Manrope', 'Be Vietnam Pro', system-ui, -apple-system, sans-serif !important;
}
body.ktd-body, body{font-family:var(--font-body)}
h1,h2,h3,h4,h5,h6,.ktd-h1,.ktd-h2,.ktd-h3,.ktd-btn,.ktd-kicker,.ktd-brand-text strong,.ktd-desktop-nav a,.ktd-drawer-head strong,.ktd-card h3,.ktd-post-body h3,.ktd-section-head h2,.ktd-pill,.ktd-btn-header{font-family:var(--font-head)}

/* ========== MOBILE: GRID 2 CỘT cho dịch vụ / bài viết ========== */
@media (max-width:767px){
  .ktd-grid.ktd-grid-3{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important}
  .ktd-grid.ktd-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important}
  .ktd-grid.ktd-grid-3 > .ktd-card,
  .ktd-grid.ktd-grid-2 > .ktd-card{border-radius:16px}
  .ktd-grid.ktd-grid-3 .ktd-card-body,
  .ktd-grid.ktd-grid-2 .ktd-card-body{padding:10px 12px 12px}
  .ktd-grid.ktd-grid-3 .ktd-card-body h3,
  .ktd-grid.ktd-grid-2 .ktd-card-body h3{font-size:14px;line-height:1.35;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
  .ktd-grid.ktd-grid-3 .ktd-card-body p,
  .ktd-grid.ktd-grid-2 .ktd-card-body p{font-size:12px;line-height:1.45;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .ktd-grid.ktd-grid-3 .ktd-card-img,
  .ktd-grid.ktd-grid-2 .ktd-card-img{aspect-ratio:1/1;border-radius:14px}
  .ktd-grid.ktd-grid-3 .ktd-price,
  .ktd-grid.ktd-grid-2 .ktd-price{font-size:13px;font-weight:800;color:var(--accent)}
  /* Pill nhỏ gọn hơn trên mobile */
  .ktd-pill{font-size:12px;padding:6px 12px;min-height:32px}
  /* Section heading nhỏ gọn hơn */
  .ktd-section{padding:40px 0}
  .ktd-section-head h2{font-size:22px;line-height:1.2}
  /* Card feed (sản phẩm) GIỮ NGUYÊN 1 cột — .ktd-feed không bị ảnh hưởng */
}

/* Tablet 2-3 cột */
@media (min-width:768px) and (max-width:1023px){
  .ktd-grid.ktd-grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
}

/* Mobile bottom-nav font */
.ktd-bottom-nav a,.ktd-bottom-nav a span{font-family:var(--font-body);font-weight:600}

/* ===== KT v3: image fallback + dynamic area menu ===== */
.ktd-card-img.img-fallback{background:linear-gradient(135deg,rgba(255,107,44,.12),rgba(255,143,76,.06));display:flex;align-items:center;justify-content:center;position:relative}
.ktd-card-img.img-fallback::before{content:'\F40D';font-family:'bootstrap-icons';font-size:36px;color:var(--accent);opacity:.7}

/* Dropdown Khu vực trên desktop */
.ktd-nav-dropdown{position:relative}
.ktd-nav-dropdown > a::after{content:'\F282';font-family:'bootstrap-icons';font-size:11px;margin-left:4px;opacity:.7}
.ktd-nav-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:240px;background:var(--glass2);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:14px;padding:8px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.2s;z-index:99}
.ktd-nav-dropdown:hover .ktd-nav-dropdown-menu,.ktd-nav-dropdown:focus-within .ktd-nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.ktd-nav-dropdown-menu a{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;font-size:14px;color:var(--text2);text-decoration:none;font-family:var(--font-body);font-weight:600}
.ktd-nav-dropdown-menu a:hover{background:rgba(255,107,44,.08);color:var(--accent)}

/* Khu vực section trong drawer mobile */
.ktd-drawer-section{padding:8px 16px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-top:12px;border-top:1px solid var(--border);padding-top:16px}

/* === Upgrade 2026: drawer collapse cho menu khu vực === */
.ktd-drawer-collapse{border-top:1px solid rgba(255,255,255,.08);margin-top:8px;padding-top:8px}
.ktd-drawer-collapse-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;background:transparent;border:0;color:inherit;font-weight:600;font-size:15px;cursor:pointer;border-radius:10px}
.ktd-drawer-collapse-toggle:hover{background:rgba(0,0,0,.04)}
.ktd-drawer-collapse-toggle .ktd-chev{transition:transform .25s ease}
.ktd-drawer-collapse.is-open .ktd-chev{transform:rotate(180deg)}
.ktd-drawer-collapse-body{display:none;padding:4px 0 6px 14px;flex-wrap:wrap;gap:6px;flex-direction:row}
.ktd-drawer-collapse.is-open .ktd-drawer-collapse-body{display:flex}
.ktd-drawer-collapse-body a{display:inline-block;padding:6px 10px;font-size:13px;border-radius:999px;background:rgba(0,122,255,.08);color:var(--accent,#007aff);border:1px solid rgba(0,122,255,.18);text-decoration:none}
.ktd-drawer-collapse-body a:hover{background:rgba(0,122,255,.14)}

/* hashtag pill cho portfolio */
.ktd-hashtags .ktd-pill{transition:transform .15s ease,background .15s ease}
.ktd-hashtags .ktd-pill:hover{transform:translateY(-1px)}
