/* =====================================================
   Tech Designer Frontend
   Navy #04107C + Amber #F59E0B
   Desktop + Mobile, Modern, Premium
   ===================================================== */
:root{
  --td-primary:#04107C;
  --td-primary-2:#0a1ba8;
  --td-primary-3:#020a5a;
  --td-amber:#F59E0B;
  --td-amber-2:#fbbf24;
  --td-amber-soft:#fef3c7;
  --td-text:#0f172a;
  --td-text-2:#475569;
  --td-muted:#64748b;
  --td-bg:#ffffff;
  --td-soft:#f8fafc;
  --td-border:#e2e8f0;
  --td-success:#10b981;
  --td-danger:#ef4444;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter','Plus Jakarta Sans','Noto Sans Bengali',-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;
  font-size:15px;line-height:1.65;color:var(--td-text);
  background:var(--td-bg);overflow-x:hidden;
}
img{max-width:100%;height:auto}
a{color:var(--td-primary);text-decoration:none}
a:hover{color:var(--td-amber)}

/* ===== Typography ===== */
h1,h2,h3,h4,h5,h6{font-weight:700;color:var(--td-text);margin:0 0 .8rem;line-height:1.25}
h1{font-size:clamp(2rem,4.5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
.text-amber{color:var(--td-amber)!important}
.text-navy{color:var(--td-primary)!important}
.text-gradient{background:linear-gradient(90deg,var(--td-primary),var(--td-amber));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}

/* ===== Section ===== */
section{padding:90px 0;position:relative}
@media (max-width:768px){section{padding:60px 0}}
.section-title{text-align:center;margin-bottom:50px;max-width:720px;margin-left:auto;margin-right:auto}
.section-title .badge-tag{
  display:inline-block;background:var(--td-amber-soft);color:#92400e;
  padding:6px 16px;border-radius:30px;font-size:13px;font-weight:600;
  margin-bottom:12px;letter-spacing:.04em;text-transform:uppercase;
}
.section-title p{color:var(--td-muted);font-size:16px;margin-top:12px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 28px;border-radius:10px;font-weight:600;font-size:15px;
  border:0;cursor:pointer;transition:all .25s ease;text-decoration:none;
}
.btn-primary{background:var(--td-primary);color:#fff!important;border-color:var(--td-primary)}
.btn-primary:hover,.btn-primary:focus{background:var(--td-primary-2);color:#fff!important;transform:translateY(-2px);box-shadow:0 12px 28px rgba(4,16,124,.3)}
.btn-amber{background:linear-gradient(135deg,var(--td-amber) 0%,#fbbf24 100%);color:var(--td-primary)!important;border-color:var(--td-amber);font-weight:700}
.btn-amber:hover,.btn-amber:focus{background:linear-gradient(135deg,#fbbf24 0%,var(--td-amber) 100%);color:var(--td-primary)!important;transform:translateY(-2px);box-shadow:0 12px 28px rgba(245,158,11,.4)}
.btn-outline-light{border:2px solid rgba(255,255,255,.5);color:#fff!important;background:transparent}
.btn-outline-light:hover{background:#fff;color:var(--td-primary)!important;border-color:#fff}
.btn-outline,.btn.btn-outline{border:2px solid var(--td-primary)!important;color:var(--td-primary)!important;background:transparent!important}
.btn-outline:hover,.btn-outline:focus,.btn-outline:active,.btn.btn-outline:hover,.btn.btn-outline:focus{background:var(--td-primary)!important;color:#fff!important;border-color:var(--td-primary)!important;transform:translateY(-2px);box-shadow:0 12px 28px rgba(4,16,124,.25)}
.btn-lg{padding:16px 36px;font-size:16px}
.btn-sm{padding:8px 18px;font-size:13px}

/* ===== Header ===== */
.td-header{
  position:sticky;top:0;z-index:1030;background:#fff;
  border-bottom:1px solid var(--td-border);
  transition:.3s;
}
.td-header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.06)}
.td-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.td-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.td-logo .mark{
  width:42px;height:42px;border-radius:5px;
  background:linear-gradient(135deg,var(--td-primary) 0%,var(--td-primary-2) 100%);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:20px;
  box-shadow:0 6px 16px rgba(4,16,124,.25);
}
.td-logo .name{font-weight:800;font-size:20px;color:var(--td-primary);letter-spacing:-.01em}
.td-logo .name span{color:var(--td-amber)}
.td-menu{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.td-menu > li > a{
  color:var(--td-text);padding:10px 16px;font-weight:500;font-size:15px;
  border-radius:8px;transition:.2s;
}
.td-menu > li > a:hover,.td-menu > li > a.active{color:var(--td-primary);background:var(--td-soft)}
.td-actions{display:flex;align-items:center;gap:10px}
.td-cart-btn{position:relative;background:var(--td-primary);border:0;border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;color:#fff!important;font-size:19px;cursor:pointer;text-decoration:none;transition:.2s;box-shadow:0 6px 14px rgba(4,16,124,.25)}
.td-cart-btn:hover{background:var(--td-amber);color:var(--td-primary)!important;transform:translateY(-2px);box-shadow:0 8px 20px rgba(245,158,11,.4)}
.td-cart-btn .badge{position:absolute;top:-3px;right:-3px;background:var(--td-amber);color:var(--td-primary);font-size:11px;font-weight:700;border-radius:10px;padding:2px 6px;line-height:1}
.td-mobile-toggle{display:none;background:none;border:0;font-size:26px;color:var(--td-primary);cursor:pointer;position:relative;z-index:1050}

/* Mobile action strip: cart + login + hamburger together */
.td-mobile-actions{display:none;align-items:center;gap:6px}
.td-mobile-actions .td-mobile-icon{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;
  font-size:18px;text-decoration:none;font-weight:600;
  transition:transform .12s ease,box-shadow .15s;
}
.td-mobile-actions .td-mobile-icon:hover{transform:translateY(-1px);box-shadow:0 6px 14px -4px rgba(4,16,124,.35)}
.td-mobile-actions .td-mobile-icon.is-primary{
  background:#04107C;color:#fff;
}
.td-mobile-actions .td-mobile-icon.is-primary:hover{background:#0a1ba8;color:#fff}
.td-mobile-actions .td-mobile-icon.is-secondary{
  background:#F59E0B;color:#04107C;
}
.td-mobile-actions .td-mobile-icon.is-secondary:hover{background:#fbbf24;color:#04107C}
.td-mobile-actions .td-mobile-badge{
  position:absolute;top:-4px;right:-4px;
  background:#F59E0B;color:#04107C;font-size:10px;font-weight:800;
  min-width:18px;height:18px;border-radius:30px;padding:0 5px;
  display:flex;align-items:center;justify-content:center;line-height:1;
  border:2px solid #fff;
}
.td-mobile-actions .td-mobile-icon.is-secondary .td-mobile-badge{background:#04107C;color:#fff;border-color:#F59E0B}
.td-mobile-actions .td-mobile-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;font-size:24px;padding:0;
  color:#04107C;background:transparent;
}
.td-mobile-actions .td-mobile-toggle:hover{background:#eef2ff}
@media (max-width:991.98px){.td-mobile-actions{display:flex !important}}

/* ===== Mobile drawer (off-canvas, separate from desktop nav) ===== */
.td-drawer{display:none !important}
.td-drawer.show{
  display:flex !important;flex-direction:column;
  position:fixed !important;top:0;right:0;left:auto;bottom:0;
  width:310px;max-width:88vw;height:100vh;
  background:#fff;
  box-shadow:-20px 0 60px rgba(4,16,124,.18);
  z-index:99999;overflow-y:auto;
  margin:0;padding:0;
  animation:tdDrawerSlideIn .3s ease-out;
}
@keyframes tdDrawerSlideIn{
  from{transform:translateX(100%)}
  to{transform:translateX(0)}
}
.td-drawer-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 20px;background:linear-gradient(135deg,#04107C,#0a1ba8);
  position:sticky;top:0;z-index:2;
}
.td-drawer-head .td-logo .name{color:#fff;font-size:18px}
.td-drawer-head .td-logo .name span{color:#F59E0B}
.td-drawer-head .td-logo .mark{background:#fff;color:#04107C;width:34px;height:34px;font-size:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-weight:800}
.td-drawer-close{
  width:36px;height:36px;border-radius:50%;border:0;
  background:rgba(255,255,255,.14);color:#fff;font-size:16px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;
}
.td-drawer-close:hover{background:#F59E0B;color:#04107C;transform:rotate(90deg)}
.td-drawer-nav{flex:1;padding:14px 12px;display:flex;flex-direction:column;gap:2px}
.td-drawer-nav a, .td-drawer-nav summary{
  display:flex;align-items:center;gap:12px;
  padding:13px 14px;border-radius:10px;
  font-size:15px;font-weight:600;color:#0f172a;
  text-decoration:none;cursor:pointer;transition:background .15s;
  list-style:none;
}
.td-drawer-nav summary::-webkit-details-marker{display:none}
.td-drawer-nav a > i, .td-drawer-nav summary > i{
  font-size:18px;color:#04107C;width:22px;text-align:center;flex-shrink:0;
}
.td-drawer-nav a:hover, .td-drawer-nav summary:hover{background:#eef2ff}
.td-drawer-nav a.active{
  background:linear-gradient(90deg,rgba(245,158,11,.18),transparent);
  color:#04107C;
}
.td-drawer-nav a.active > i{color:#F59E0B}
.td-drawer-group .td-drawer-chev{margin-left:auto;transition:transform .25s}
.td-drawer-group[open] .td-drawer-chev{transform:rotate(180deg)}
.td-drawer-group > a{padding-left:46px;font-size:14px;font-weight:500;color:#475569}
.td-drawer-group > a > i{font-size:14px;width:18px}
.td-drawer-foot{
  border-top:1px solid #e5e7eb;padding:18px 20px;
  display:flex;flex-direction:column;gap:8px;
}
.td-drawer-cart{
  display:flex;align-items:center;gap:10px;padding:12px 14px;
  background:#eef2ff;color:#04107C;border-radius:10px;font-weight:600;
  text-decoration:none;font-size:14px;margin-bottom:6px;
}
.td-drawer-cart .badge{margin-left:auto;background:#F59E0B;color:#04107C;padding:2px 8px;border-radius:30px}



/* Dropdown */
.td-menu .dropdown-menu{padding:8px;border:0;box-shadow:0 14px 40px rgba(0,0,0,.08);border-radius:12px;min-width:220px}
.td-menu .dropdown-item{padding:9px 14px;border-radius:8px;font-size:14px;color:var(--td-text)}
.td-menu .dropdown-item:hover{background:var(--td-soft);color:var(--td-primary)}

/* ===== Hero ===== */
.td-hero{
  background:linear-gradient(135deg,var(--td-primary) 0%,var(--td-primary-3) 100%);
  color:#fff;padding:0;position:relative;overflow:hidden;
}
.td-hero::before{
  content:"";position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.18) 0%,transparent 70%);
  top:-200px;right:-100px;
}
.td-hero::after{
  content:"";position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.04) 0%,transparent 70%);
  bottom:-200px;left:-100px;
}
.td-hero h1{color:#fff;margin-bottom:18px}
.td-hero .subtitle{display:inline-block;background:rgba(245,158,11,.18);color:var(--td-amber);padding:6px 18px;border-radius:30px;font-size:13px;font-weight:600;margin-bottom:18px;border:1px solid rgba(245,158,11,.3)}
.td-hero .lead{font-size:18px;color:rgba(255,255,255,.85);max-width:560px;margin-bottom:30px}
.td-hero .actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px}
.td-hero .stats{display:flex;gap:30px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.15);padding-top:24px;margin-top:24px}
.td-hero .stat strong{font-size:32px;font-weight:800;color:var(--td-amber);display:block;line-height:1}
.td-hero .stat span{font-size:13px;color:rgba(255,255,255,.7)}
.td-hero-img{position:relative;z-index:2;text-align:center}
.td-hero-img img{max-width:100%;border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.3)}

/* ===== Card ===== */
.td-card{
  background:#fff;border:1px solid var(--td-border);border-radius:14px;
  overflow:hidden;transition:all .3s ease;height:100%;
  display:flex;flex-direction:column;
}
.td-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(4,16,124,.12);border-color:transparent}
.td-card-img{
  position:relative;overflow:hidden;background:var(--td-soft);aspect-ratio:16/10;
}
.td-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.td-card:hover .td-card-img img{transform:scale(1.05)}
.td-card-img .badge-overlay{
  position:absolute;top:12px;left:12px;background:var(--td-amber);color:var(--td-primary);
  font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px;letter-spacing:.04em;
  text-transform:uppercase;
}
.td-card-img .discount-badge{
  position:absolute;top:12px;right:12px;background:var(--td-danger);color:#fff;
  font-size:12px;font-weight:700;padding:4px 10px;border-radius:6px;
}
.td-card-body{padding:20px;flex:1;display:flex;flex-direction:column}
.td-card-cat{font-size:12px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:8px}
.td-card-body h5{font-size:17px;line-height:1.4;margin-bottom:8px;color:var(--td-text)}
.td-card-body h5 a{color:inherit}
.td-card-body h5 a:hover{color:var(--td-primary)}
.td-card-desc{color:var(--td-muted);font-size:14px;flex:1;margin-bottom:14px}
.td-card-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--td-border);flex-wrap:nowrap}
.td-price{display:flex;flex-direction:column;align-items:flex-start;gap:0;min-width:0;flex:1 1 auto;line-height:1.1}
.td-price .now{font-size:17px;font-weight:800;color:var(--td-primary);white-space:nowrap;line-height:1.2}
.td-price .was{font-size:12px;color:var(--td-muted);text-decoration:line-through;white-space:nowrap;line-height:1.2;margin-top:2px}
.td-card-foot .btn{flex-shrink:0;white-space:nowrap;padding:7px 14px;font-size:13px}
.td-card-actions{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
.td-card-actions .btn{padding:7px 11px}
.td-card-actions .td-card-details{
  border:1px solid var(--td-primary);color:var(--td-primary);background:transparent;
}
.td-card-actions .td-card-details:hover{
  background:var(--td-primary);color:#fff;transform:translateY(-1px);
}
.td-rating{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--td-muted)}
.td-rating i{color:var(--td-amber)}

/* ===== Categories grid ===== */
.cat-card{
  background:#fff;border:1px solid var(--td-border);border-radius:14px;
  padding:28px 22px;text-align:center;text-decoration:none;display:block;
  transition:all .3s;color:inherit;height:100%;
}
.cat-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(4,16,124,.1);border-color:var(--td-amber);color:inherit}
.cat-card .icon{
  width:64px;height:64px;border-radius:14px;
  background:linear-gradient(135deg,var(--td-primary),var(--td-primary-2));
  color:#fff;display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:28px;
}
.cat-card:hover .icon{background:linear-gradient(135deg,var(--td-amber),#fbbf24);color:var(--td-primary)}
.cat-card h6{font-size:16px;font-weight:600;margin-bottom:4px;color:var(--td-text)}
.cat-card span{font-size:13px;color:var(--td-muted)}

/* ===== Feature box ===== */
.feature-box{padding:28px 24px;background:#fff;border:1px solid var(--td-border);border-radius:14px;height:100%;transition:.3s}
.feature-box:hover{box-shadow:0 14px 36px rgba(4,16,124,.1);border-color:var(--td-amber)}
.feature-box .icon{width:56px;height:56px;border-radius:12px;background:var(--td-amber-soft);color:var(--td-amber);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px}
.feature-box h5{font-size:18px;margin-bottom:8px}
.feature-box p{color:var(--td-muted);margin:0;font-size:14px}

/* ===== Page Hero (banner) ===== */
.td-page-hero{
  background:linear-gradient(135deg,var(--td-primary) 0%,var(--td-primary-3) 100%);
  color:#fff;padding:80px 0 80px;text-align:center;position:relative;overflow:hidden;
}
.td-page-hero::before{
  content:"";position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.15) 0%,transparent 70%);
  top:-200px;right:-100px;
}
.td-page-hero h1{color:#fff;font-size:42px;margin-bottom:8px}
.td-page-hero .breadcrumbs{color:rgba(255,255,255,.7);font-size:14px}
.td-page-hero .breadcrumbs a{color:rgba(255,255,255,.85)}
.td-page-hero .breadcrumbs .sep{margin:0 6px}

/* ===== CTA ===== */
.td-cta{
  background:linear-gradient(135deg,var(--td-primary) 0%,var(--td-primary-3) 100%);
  color:#fff;padding:70px 0;border-radius:20px;text-align:center;position:relative;overflow:hidden;
}
.td-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 50%,rgba(245,158,11,.18) 0%,transparent 50%);
}
.td-cta h2{color:#fff;font-size:34px;position:relative;z-index:1}
.td-cta p{color:rgba(255,255,255,.85);font-size:17px;max-width:600px;margin:0 auto 24px;position:relative;z-index:1}
.td-cta .actions{position:relative;z-index:1;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== Footer ===== */
.td-footer{
  background:#020a5a;color:rgba(255,255,255,.75);
  padding:80px 0 0;font-size:14px;
}
.td-footer h6{color:#fff;font-size:16px;font-weight:700;margin-bottom:18px;text-transform:uppercase;letter-spacing:.04em}
.td-footer a{color:rgba(255,255,255,.75);display:block;margin-bottom:8px;font-size:14px}
.td-footer a:hover{color:var(--td-amber);transform:translateX(3px)}
/* Inline anchors inside paragraphs (contact lines: mailto/tel) shouldn't break to new line */
.td-footer p a{display:inline;margin:0;transform:none}
.td-footer p a:hover{transform:none}
.td-footer p{margin-bottom:8px;display:flex;align-items:center;flex-wrap:wrap}
.td-footer p i{flex-shrink:0}
.td-footer .footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.td-footer .footer-logo .mark{width:42px;height:42px;border-radius:5px;background:linear-gradient(135deg,var(--td-amber),#fbbf24);display:flex;align-items:center;justify-content:center;color:var(--td-primary);font-weight:800;font-size:20px}
.td-footer .footer-logo .name{color:#fff;font-weight:800;font-size:20px}
.td-footer .social{display:flex;gap:10px;margin-top:16px}
.td-footer .social a{width:38px;height:38px;background:rgba(255,255,255,.06);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;margin:0;transition:.2s}
.td-footer .social a:hover{background:var(--td-amber);color:var(--td-primary);transform:translateY(-3px)}
.td-footer .newsletter input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:5px;padding:10px 14px;width:100%;font-size:14px;outline:none}
.td-footer .newsletter input::placeholder{color:rgba(255,255,255,.4)}
.td-footer .newsletter button{margin-top:8px}
.td-footer-payments{
  border-top:1px solid rgba(255,255,255,.08);margin-top:50px;padding:24px 0;
}
.td-pay-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}
.td-pay-list img{height:36px;width:auto;background:#fff;border-radius:6px;padding:2px;box-shadow:0 2px 6px rgba(0,0,0,.1);transition:.2s}
.td-pay-list img:hover{transform:translateY(-2px)}
@media (max-width:991.98px){.td-pay-list{justify-content:flex-start}}

.td-footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:20px 0;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(255,255,255,.55);
}

/* ===== Scroll-to-top FAB ===== */
.td-scroll-top{
  position:fixed;right:24px;bottom:24px;width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--td-primary),var(--td-primary-2));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;
  border:0;cursor:pointer;box-shadow:0 10px 26px rgba(4,16,124,.3);
  opacity:0;visibility:hidden;transform:translateY(10px);transition:all .25s;z-index:1020;
}
.td-scroll-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.td-scroll-top:hover{background:linear-gradient(135deg,var(--td-amber),#fbbf24);color:var(--td-primary);transform:translateY(-2px) scale(1.05)}

/* ===== Forms ===== */
.form-control,.form-select{border:1px solid var(--td-border);border-radius:10px;padding:12px 16px;font-size:15px;transition:.2s}
.form-control:focus,.form-select:focus{border-color:var(--td-primary);box-shadow:0 0 0 3px rgba(4,16,124,.08)}
.form-label{font-weight:500;margin-bottom:6px;color:var(--td-text);font-size:14px}

/* ===== Auth pages (centered card with nav+footer) ===== */
.td-auth-wrap{
  background:linear-gradient(135deg,#eef2ff 0%,#fef3c7 100%);
  padding:60px 16px;min-height:calc(100vh - 80px);
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
}
.td-auth-wrap::before{
  content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(4,16,124,.08) 0%,transparent 70%);top:-200px;left:-200px;pointer-events:none;
}
.td-auth-wrap::after{
  content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.12) 0%,transparent 70%);bottom:-200px;right:-200px;pointer-events:none;
}
.td-auth-card{
  background:#fff;border-radius:18px;
  box-shadow:0 24px 60px rgba(4,16,124,.12),0 4px 12px rgba(0,0,0,.04);
  padding:42px 38px;width:100%;max-width:480px;position:relative;z-index:2;
}
.td-auth-card.wide{max-width:560px}
.td-auth-card .auth-icon{
  width:64px;height:64px;border-radius:16px;
  background:linear-gradient(135deg,var(--td-primary),var(--td-primary-2));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;
  margin:0 auto 18px;box-shadow:0 10px 26px rgba(4,16,124,.25);
}
.td-auth-card h3{font-size:26px;margin-bottom:6px;text-align:center;color:var(--td-primary)}
.td-auth-card .sub{color:var(--td-muted);margin-bottom:28px;text-align:center}
.td-auth-card .form-control,.td-auth-card .form-select{padding:13px 16px;font-size:15px}
.td-auth-card .input-group .form-control{border-left:0}
.td-auth-card .input-group-text{background:#fff;border-right:0;color:var(--td-muted)}
.td-auth-card .form-control:focus + .input-group-text,
.td-auth-card .input-group:focus-within .input-group-text{border-color:var(--td-primary)}
.td-auth-card .auth-divider{display:flex;align-items:center;text-align:center;color:var(--td-muted);margin:20px 0;font-size:13px}
.td-auth-card .auth-divider::before,.td-auth-card .auth-divider::after{content:"";flex:1;height:1px;background:var(--td-border)}
.td-auth-card .auth-divider span{padding:0 14px}
.td-auth-card .auth-foot{text-align:center;color:var(--td-muted);margin-top:20px;font-size:14px}
.td-auth-card .auth-foot a{color:var(--td-primary);font-weight:600}
.td-auth-payments{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin-top:18px;padding-top:18px;border-top:1px dashed var(--td-border)}
.td-auth-payments img{height:28px;border-radius:4px}
.td-password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--td-muted);cursor:pointer;padding:4px;font-size:18px;z-index:3}
.td-password-toggle:hover{color:var(--td-primary)}
.td-password-wrap{position:relative}
.td-password-wrap .form-control{padding-right:42px}

/* intl-tel-input fixes */
.iti{width:100%}
.iti__country-list{font-size:14px}
.iti--separate-dial-code .iti__selected-flag{background:#fff;border:1px solid var(--td-border);border-right:0;border-radius:10px 0 0 10px}
.iti--separate-dial-code .form-control{border-radius:0 10px 10px 0!important}
.iti__search-input{padding:8px 12px!important;font-size:14px!important}

@media (max-width:575.98px){
  .td-auth-card{padding:30px 22px;border-radius:14px}
  .td-auth-wrap{padding:30px 12px}
}

/* ===== Detail page ===== */
.product-gallery .main{aspect-ratio:16/10;border-radius:14px;overflow:hidden;background:var(--td-soft)}
.product-gallery .main img{width:100%;height:100%;object-fit:cover}
.product-gallery .thumbs{display:flex;gap:10px;margin-top:12px;overflow-x:auto}
.product-gallery .thumbs img{width:80px;height:80px;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid transparent}
.product-gallery .thumbs img.active{border-color:var(--td-primary)}

.detail-tabs{border-bottom:1px solid var(--td-border);margin-bottom:30px;display:flex;gap:6px;overflow-x:auto}
.detail-tabs button{
  border:0;background:transparent;padding:14px 22px;font-weight:500;color:var(--td-muted);
  border-bottom:3px solid transparent;cursor:pointer;font-size:15px;white-space:nowrap;
}
.detail-tabs button.active{color:var(--td-primary);border-color:var(--td-amber)}

/* ===== Code block ===== */
.code-block{background:#0f172a;color:#e2e8f0;padding:18px;border-radius:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;overflow-x:auto;line-height:1.6}

/* ===== Blog ===== */
.blog-content{font-size:17px;line-height:1.85;color:var(--td-text)}
.blog-content h2,.blog-content h3{margin-top:36px;margin-bottom:12px}
.blog-content p{margin-bottom:18px}
.blog-content img{border-radius:10px;margin:18px 0}
.blog-content blockquote{border-left:4px solid var(--td-amber);padding-left:18px;margin:24px 0;color:var(--td-muted);font-style:italic}

/* ===== Sidebar ===== */
.td-sidebar-widget{background:#fff;border:1px solid var(--td-border);border-radius:12px;padding:24px;margin-bottom:24px}
.td-sidebar-widget h6{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--td-primary);padding-bottom:10px;border-bottom:1px solid var(--td-border)}
.td-sidebar-widget ul{list-style:none;padding:0;margin:0}
.td-sidebar-widget ul li{padding:6px 0;border-bottom:1px solid var(--td-border)}
.td-sidebar-widget ul li:last-child{border-bottom:0}
.td-sidebar-widget ul li a{color:var(--td-text-2);font-size:14px;display:flex;justify-content:space-between}

/* ===== Customer dashboard ===== */
.cust-side{
  background:#fff;border:1px solid var(--td-border);border-radius:16px;padding:24px;position:sticky;top:90px;
  box-shadow:0 4px 16px rgba(15,23,42,.04);
}
.cust-side .avatar{
  width:90px;height:90px;border-radius:50%;object-fit:cover;margin:0 auto 12px;display:block;
  border:3px solid var(--td-amber-soft);box-shadow:0 8px 20px rgba(4,16,124,.12);
}
.cust-side .nav{flex-direction:column;gap:4px}
.cust-side .nav a{
  padding:11px 14px;border-radius:10px;color:var(--td-text-2);font-weight:500;font-size:14px;
  display:flex;align-items:center;gap:12px;transition:.2s;
}
.cust-side .nav a:hover{background:var(--td-soft);color:var(--td-primary);transform:translateX(2px)}
.cust-side .nav a.active{
  background:linear-gradient(90deg,var(--td-primary),var(--td-primary-2));color:#fff;
  box-shadow:0 6px 14px rgba(4,16,124,.25);
}
.cust-side .nav a i{width:20px;font-size:18px}
.cust-side-toggle{display:none}

/* Customer sidebar — collapsed on mobile, full on desktop */
@media (max-width:991.98px){
  .cust-side{position:static;padding:0;overflow:hidden}
  .cust-side-profile{display:none}
  .cust-side-toggle{
    display:flex;align-items:center;gap:12px;width:100%;
    padding:14px 18px;background:none;border:0;cursor:pointer;
  }
  .cust-side-toggle img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--td-amber-soft)}
  .cust-side-toggle .cst-name{
    flex:1;text-align:left;font-weight:700;color:var(--td-text);font-size:15px;line-height:1.2;
    display:flex;flex-direction:column;
  }
  .cust-side-toggle .cst-name small{font-weight:500;color:var(--td-muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
  .cust-side-toggle i{font-size:16px;color:var(--td-muted);transition:transform .25s}
  .cust-side.open .cust-side-toggle i{transform:rotate(180deg)}
  .cust-side-nav{display:none!important;padding:4px 14px 14px;border-top:1px solid var(--td-border)}
  .cust-side.open .cust-side-nav{display:flex!important}
}

/* Welcome hero */
.cust-hero{
  background:linear-gradient(135deg,var(--td-primary) 0%,var(--td-primary-3) 100%);
  border-radius:18px;padding:30px 36px;color:#fff;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  position:relative;overflow:hidden;
  box-shadow:0 10px 30px rgba(4,16,124,.15);
}
.cust-hero::before{
  content:"";position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.22) 0%,transparent 70%);
  top:-120px;right:-80px;pointer-events:none;
}
.cust-hero::after{
  content:"";position:absolute;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%);
  bottom:-120px;left:30%;pointer-events:none;
}
.cust-hero-text{flex:1;min-width:0;position:relative;z-index:2}
.cust-hero-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(245,158,11,.18);color:var(--td-amber);
  padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;
  border:1px solid rgba(245,158,11,.3);margin-bottom:10px;
}
.cust-hero h2{color:#fff;font-size:28px;margin:0 0 6px;font-weight:800;letter-spacing:-.02em}
.cust-hero h2 span{color:var(--td-amber)}
.cust-hero p{color:rgba(255,255,255,.85);margin:0 0 18px;font-size:15px}
.cust-hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.cust-hero-img{position:relative;z-index:2;flex-shrink:0}
.cust-hero-img img{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.25);box-shadow:0 10px 24px rgba(0,0,0,.2)}
@media (max-width:575.98px){
  .cust-hero{padding:24px;flex-direction:column;text-align:center}
  .cust-hero-actions{justify-content:center}
}

/* Stat cards (customer) */
.cust-stat{
  background:#fff;border-radius:14px;padding:18px 20px;
  display:flex;align-items:center;gap:14px;height:100%;
  border:1px solid var(--td-border);transition:all .25s;
  position:relative;overflow:hidden;
}
.cust-stat::before{
  content:"";position:absolute;top:0;left:0;width:4px;height:100%;
  background:var(--td-primary);transition:width .3s;
}
.cust-stat:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(4,16,124,.1);border-color:transparent}
.cust-stat:hover::before{width:6px}
.cust-stat .ico{
  width:50px;height:50px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;
}
.cust-stat .meta{min-width:0;flex:1}
.cust-stat .meta span{font-size:12px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;display:block;margin-bottom:2px}
.cust-stat .meta strong{font-size:22px;font-weight:800;color:var(--td-text);display:block;line-height:1.1;letter-spacing:-.01em}
.cust-stat.primary::before{background:var(--td-primary)}.cust-stat.primary .ico{background:rgba(4,16,124,.1);color:var(--td-primary)}
.cust-stat.success::before{background:var(--td-success)}.cust-stat.success .ico{background:rgba(16,185,129,.12);color:var(--td-success)}
.cust-stat.info::before{background:#3b82f6}.cust-stat.info .ico{background:rgba(59,130,246,.12);color:#3b82f6}
.cust-stat.warning::before{background:var(--td-amber)}.cust-stat.warning .ico{background:var(--td-amber-soft);color:#b45309}
.cust-stat.danger::before{background:var(--td-danger)}.cust-stat.danger .ico{background:rgba(239,68,68,.12);color:var(--td-danger)}

/* Quick actions */
.cust-quick{margin-top:8px}
.cust-action{
  background:#fff;border:1px solid var(--td-border);border-radius:14px;
  padding:22px 16px;text-align:center;display:block;text-decoration:none;color:var(--td-text);
  transition:all .25s;height:100%;
}
.cust-action i{
  font-size:30px;color:var(--td-primary);display:block;margin-bottom:8px;
  transition:transform .3s;
}
.cust-action span{font-size:13px;font-weight:600;color:var(--td-text-2)}
.cust-action:hover{transform:translateY(-4px);border-color:var(--td-amber);box-shadow:0 14px 30px rgba(4,16,124,.1);color:var(--td-text)}
.cust-action:hover i{color:var(--td-amber);transform:scale(1.15) rotate(-5deg)}

/* Active access list */
.cust-access-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  border:1px solid var(--td-border);border-radius:12px;margin-bottom:10px;
  transition:.2s;
}
.cust-access-item:hover{border-color:var(--td-amber);background:rgba(245,158,11,.04)}
.cust-access-item:last-child{margin-bottom:0}
.cust-access-item .ico{
  width:42px;height:42px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;
}
.cust-access-item .ico-product{background:rgba(4,16,124,.1);color:var(--td-primary)}
.cust-access-item .ico-ebook{background:rgba(245,158,11,.14);color:#b45309}
.cust-access-item .ico-course{background:rgba(16,185,129,.12);color:var(--td-success)}
.cust-access-item .ico-api{background:rgba(59,130,246,.12);color:#3b82f6}

/* ===== Customer sub-page header ===== */
.cust-pagehead{
  position:relative;overflow:hidden;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  background:linear-gradient(135deg,#04107C 0%,#16207a 55%,#020a4f 100%);
  border-radius:18px;padding:24px 26px;margin-bottom:24px;
  box-shadow:0 12px 30px rgba(4,16,124,.22);
}
.cust-pagehead::before{
  content:"";position:absolute;top:-70px;right:-40px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.22),transparent 68%);pointer-events:none;
}
.cust-pagehead::after{
  content:"";position:absolute;bottom:-90px;left:28%;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(147,167,255,.16),transparent 70%);pointer-events:none;
}
.cust-pagehead .ph-ico{
  width:58px;height:58px;border-radius:16px;flex-shrink:0;position:relative;z-index:2;
  background:linear-gradient(135deg,#F59E0B,#fbbf24);color:#04107C;
  display:flex;align-items:center;justify-content:center;font-size:26px;
  box-shadow:0 10px 22px rgba(245,158,11,.4);
}
.cust-pagehead .ph-text{flex:1;min-width:0;position:relative;z-index:2}
.cust-pagehead .ph-text h2{margin:0;font-size:22px;font-weight:800;color:#fff;letter-spacing:-.02em}
.cust-pagehead .ph-text p{margin:4px 0 0;font-size:13px;color:rgba(255,255,255,.72)}
.cust-pagehead .ph-action{flex-shrink:0;display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:2}
@media (max-width:600px){
  .cust-pagehead{padding:20px;gap:14px}
  .cust-pagehead .ph-text h2{font-size:19px}
}

/* ===== Empty state ===== */
.cust-empty{
  text-align:center;padding:56px 24px;background:#fff;border-radius:16px;
  box-shadow:0 6px 22px rgba(4,16,124,.06);
}
.cust-empty .ico{
  width:78px;height:78px;border-radius:50%;background:var(--td-soft);color:var(--td-primary);
  display:inline-flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:16px;
}
.cust-empty h5{font-weight:700;color:var(--td-text);margin:0 0 6px;font-size:18px}
.cust-empty p{color:var(--td-muted);font-size:14px;margin:0 0 18px}

/* ===== Customer data card / panel ===== */
.cust-panel{
  background:#fff;border-radius:16px;box-shadow:0 6px 22px rgba(4,16,124,.06);
  overflow:hidden;
}
.cust-panel-head{
  padding:16px 22px;border-bottom:1px solid var(--td-border);
  display:flex;align-items:center;gap:8px;font-weight:700;color:var(--td-text);font-size:15px;
}
.cust-panel-head i{color:var(--td-amber)}

/* Order rows table polish */
.cust-table{width:100%;border-collapse:collapse}
.cust-table th{
  font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--td-muted);
  font-weight:700;padding:13px 18px;background:var(--td-soft);text-align:left;
}
.cust-table td{padding:14px 18px;border-bottom:1px solid var(--td-border);font-size:14px;vertical-align:middle}
.cust-table tbody tr:last-child td{border-bottom:0}
.cust-table tbody tr{transition:background .15s}
.cust-table tbody tr:hover{background:var(--td-soft)}

/* License / key block */
.cust-keybox{
  background:var(--td-soft);border:1px dashed #c7cce0;border-radius:10px;padding:12px 14px;
}
.cust-keybox code{font-size:14px;color:var(--td-primary);font-weight:700;word-break:break-all}

/* ===== Support ticket thread ===== */
.tkt-meta{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:13px;color:var(--td-muted);padding:14px 18px;border-bottom:1px solid var(--td-border)}
.tkt-meta b{color:var(--td-text);font-weight:600}
.tkt-thread{padding:18px}
.tkt-msg{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}
.tkt-msg:last-child{margin-bottom:0}
.tkt-msg .av{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:#fff;
  background:linear-gradient(135deg,#04107C,#1e2a9e);
}
.tkt-msg.staff .av{background:linear-gradient(135deg,#F59E0B,#d97706);color:#04107C}
.tkt-msg .bubble{
  flex:1;min-width:0;background:#f4f6fc;border-radius:5px;padding:12px 16px;
}
.tkt-msg.staff .bubble{background:#fff7e8;border:1px solid #fde7c2}
.tkt-msg .bubble .who{font-size:12px;font-weight:700;color:var(--td-text);margin-bottom:3px}
.tkt-msg .bubble .who small{font-weight:500;color:var(--td-muted);margin-left:6px}
.tkt-msg .bubble .body{font-size:14px;color:var(--td-text-2);white-space:pre-wrap;line-height:1.6}
.tkt-msg .bubble .staff-tag{display:inline-block;background:#F59E0B;color:#04107C;font-size:9px;font-weight:800;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;margin-left:4px}

/* On mobile, each table row becomes a stacked card */
@media (max-width:600px){
  .cust-table thead{display:none}
  .cust-table,.cust-table tbody,.cust-table tr,.cust-table td{display:block}
  /* the .table-responsive wrapper must not scroll once rows are cards */
  .cust-panel .table-responsive{overflow-x:visible}
  .cust-table tr{
    margin:12px;border:1px solid var(--td-border);
    background:#fff;overflow:hidden;
  }
  .cust-table tbody tr:hover{background:#fff}
  .cust-table td{
    display:flex;justify-content:space-between;align-items:center;gap:14px;
    padding:10px 14px;border:0;border-bottom:1px solid var(--td-soft);text-align:right;
  }
  .cust-table td:last-child{border-bottom:0;justify-content:flex-end}
  .cust-table td::before{
    content:attr(data-label);font-weight:700;color:var(--td-muted);
    font-size:11px;text-transform:uppercase;letter-spacing:.04em;text-align:left;flex-shrink:0;
  }
  .cust-table td:last-child::before{display:none}
  .cust-table td:last-child .btn{width:100%}
}

/* ===== Mobile menu (premium off-canvas drawer) ===== */
.td-menu-head{display:none}
.td-menu-close{display:none}

@media (max-width:991.98px){
  .td-mobile-toggle{display:block}

  body{overflow-x:hidden}

  /* Drawer header — logo + close button */
  .td-menu-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 20px;border-bottom:1px solid var(--td-border);
    background:linear-gradient(135deg,var(--td-primary),var(--td-primary-2));
    position:sticky;top:0;z-index:2;
  }
  .td-menu-head .td-logo .name{color:#fff}
  .td-menu-head .td-logo .name span{color:var(--td-amber)}
  .td-menu-close{
    display:flex;align-items:center;justify-content:center;width:38px;height:38px;
    border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;
    font-size:18px;cursor:pointer;transition:.2s;
  }
  .td-menu-close:hover{background:var(--td-amber);color:var(--td-primary);transform:rotate(90deg)}

  /* Menu items — bigger, with icons + chevron */
  .td-menu > li{padding:0 14px}
  .td-menu > li:first-of-type:not(.td-menu-head){padding-top:14px}
  .td-menu > li > a{
    padding:14px 16px;border-radius:10px;display:flex;align-items:center;gap:14px;
    font-size:15px;font-weight:600;color:var(--td-text);position:relative;
    transition:all .2s;
  }
  .td-menu > li > a > i{
    font-size:20px;color:var(--td-primary);width:24px;text-align:center;flex-shrink:0;
  }
  .td-menu > li > a::after{
    content:"\F285";font-family:"bootstrap-icons";margin-left:auto;
    color:var(--td-muted);font-size:14px;transition:.2s;
  }
  .td-menu > li > a:hover{background:var(--td-soft)}
  .td-menu > li > a:hover::after{color:var(--td-amber);transform:translateX(2px)}
  .td-menu > li > a.active{
    background:linear-gradient(90deg,var(--td-amber-soft),transparent);
    color:var(--td-primary);
  }
  .td-menu > li > a.active > i{color:var(--td-amber)}
  .td-menu > li > a.active::after{color:var(--td-amber)}

  /* Products — open as flat submenu, not a popup dropdown */
  .td-menu .dropdown-toggle::after{display:none}
  .td-menu .dropdown-menu{
    position:static!important;display:block!important;float:none!important;
    transform:none!important;border:0;box-shadow:none;padding:6px 0 6px 38px;
    background:transparent;width:auto;min-width:0;margin:0;
  }
  .td-menu .dropdown-menu .dropdown-item{
    padding:10px 12px;border-radius:8px;font-size:14px;color:var(--td-text-2);
    display:flex;align-items:center;gap:10px;
  }
  .td-menu .dropdown-menu .dropdown-item i{color:var(--td-primary);font-size:16px;width:20px;text-align:center}
  .td-menu .dropdown-menu .dropdown-item:hover{background:var(--td-soft);color:var(--td-primary)}

  /* Bottom action area — separated, prominent */
  .td-menu .td-actions{
    flex-direction:column;align-items:stretch;gap:10px;
    padding:18px 20px 24px;margin-top:14px;
    border-top:1px solid var(--td-border);background:var(--td-soft);
    position:sticky;bottom:0;
  }
  .td-menu .td-cart-btn{
    width:auto;height:46px;border-radius:10px;justify-content:flex-start;padding:0 16px;
    font-size:15px;font-weight:600;
  }
  .td-menu .td-cart-btn .td-cart-label{display:inline}
  .td-menu .td-cart-btn .badge{position:static;margin-left:auto}
  .td-menu .td-user-dd{width:100%}
  .td-menu .td-user-dd .btn{width:100%;justify-content:flex-start;padding:12px 16px;font-size:15px}
  .td-menu .td-user-dd .td-user-name{flex:1;text-align:left}
  .td-menu .td-user-dd .dropdown-menu{padding-left:0;background:#fff;border:1px solid var(--td-border);box-shadow:0 4px 12px rgba(0,0,0,.06);border-radius:10px;margin-top:6px}
  .td-menu .td-user-dd .dropdown-menu .dropdown-item{padding:10px 14px;font-weight:500}
  .td-menu .td-actions .btn{width:100%;height:46px;font-size:15px;justify-content:center}

  .td-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(2px);z-index:9998;display:none}
  .td-overlay.show{display:block}

  .td-hero{padding:60px 0 70px;text-align:center}
  .td-hero .stats{justify-content:center}
}
@media (max-width:575.98px){
  .td-hero{padding:50px 0 60px}
  .td-hero h1{font-size:30px}
  .td-page-hero{padding:60px 0}
  .td-page-hero h1{font-size:28px}
  .td-cta{padding:50px 24px;border-radius:14px}
  .td-cta h2{font-size:24px}
}

/* ============================================================
   GLOBAL BORDER-RADIUS — all cards, buttons, inputs → 5px
   ============================================================ */
.btn,
.btn-amber,.btn-primary,.btn-outline,.btn-outline-light,
.form-control,.form-select,.input-group-text,.input-group,
.card,.td-card,.feature-box,.cat-card,
.cust-hero,.cust-stat,.cust-action,.cust-access-item,.cust-side,
.cust-pagehead,.cust-pagehead .ph-ico,.cust-panel,.cust-empty,
.cust-keybox,.cust-table tr,.cust-stat .ico,
.td-modnav-link,.td-back-btn,
.td-section-card,.td-summary-card,.td-order-thumb,.td-order-status,.td-pay-card-inner,
.td-shop-search,.td-shop-search input,.td-shop-search button,.td-shop-chip,.td-chip-count,
.td-blog-card,.td-blog-card-img,.td-blog-cat-pill,
.td-sidebar-widget,.td-auth-card,.alert,
.badge,.discount-badge,.badge-overlay,
.dropdown-menu,.list-group-item:first-child,.list-group-item:last-child,
.td-cart-btn,.td-pay-list img,.td-auth-payments img,
.product-gallery .main,.product-gallery .thumbs img,
.code-block{border-radius:5px!important}
/* Specific overrides for fully-round elements (avatars, social circles, scroll-top) */
.cust-side .avatar,.cust-hero-img img,.cust-empty .ico,
.td-footer .social a,
.td-scroll-top{border-radius:50%!important}

/* ===== Utils ===== */
.bg-soft{background:var(--td-soft)}
.bg-navy{background:var(--td-primary);color:#fff}
.shadow-soft{box-shadow:0 6px 24px rgba(4,16,124,.06)}
.rounded-xl{border-radius:14px}


/* ============================================================
   PREMIUM HOMEPAGE POLISH (overrides existing where needed)
   ============================================================ */

/* --- Hero — animated decorative blobs + cleaner stats --- */
.td-hero{padding:120px 0 140px}
.td-hero::before{
  background:radial-gradient(circle,rgba(245,158,11,.22) 0%,transparent 70%);
  width:680px;height:680px;animation:tdFloat 12s ease-in-out infinite;
}
.td-hero::after{
  background:radial-gradient(circle,rgba(255,255,255,.07) 0%,transparent 70%);
  width:560px;height:560px;animation:tdFloat 16s ease-in-out infinite reverse;
}
@keyframes tdFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.08)}}

.td-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;letter-spacing:-.02em;line-height:1.1}
.td-hero h1 .highlight{
  background:linear-gradient(120deg,var(--td-amber),#fde68a);
  -webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;
}
.td-hero .subtitle{
  background:rgba(245,158,11,.18);color:var(--td-amber);padding:8px 18px;border-radius:30px;
  font-size:13px;font-weight:600;border:1px solid rgba(245,158,11,.3);display:inline-flex;align-items:center;gap:6px;
}
.td-hero .subtitle::before{content:"✦";font-size:14px}
.td-hero .lead{font-size:18px;color:rgba(255,255,255,.85);max-width:560px;margin-bottom:32px;line-height:1.6}

.td-hero .stats{
  display:flex;gap:0;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.15);
  padding-top:28px;margin-top:32px;
}
.td-hero .stats .stat{
  flex:1;min-width:130px;padding:0 20px;border-right:1px solid rgba(255,255,255,.12);
  background:transparent;box-shadow:none;border-radius:0;
}
.td-hero .stats .stat:first-child{padding-left:0}
.td-hero .stats .stat:last-child{border-right:0}
.td-hero .stat strong{font-size:34px;font-weight:800;color:#fff;display:block;line-height:1;letter-spacing:-.02em}
.td-hero .stat strong .plus{color:var(--td-amber)}
.td-hero .stat span{font-size:12px;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.08em;margin-top:6px;display:block}

.td-hero-img{position:relative;z-index:2}
.td-hero-img::before{
  content:"";position:absolute;inset:-20px;border-radius:24px;
  background:linear-gradient(135deg,rgba(245,158,11,.4),rgba(255,255,255,.1));
  filter:blur(40px);z-index:-1;opacity:.6;
}
.td-hero-img img{
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.1);
  transform:perspective(900px) rotateY(-3deg) rotateX(2deg);
  transition:transform .6s ease;
}
.td-hero-img:hover img{transform:perspective(900px) rotateY(0) rotateX(0)}

/* --- Section title — premium typography --- */
section{padding:100px 0}
@media (max-width:768px){section{padding:70px 0}}
.section-title{margin-bottom:60px}
.section-title h2{
  font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin-bottom:14px;
}
.section-title h2 .text-amber{
  background:linear-gradient(120deg,var(--td-amber),#fbbf24);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-title p{font-size:17px;color:var(--td-muted);line-height:1.7;max-width:640px;margin:14px auto 0}
.section-title .badge-tag{
  background:linear-gradient(135deg,var(--td-amber-soft),#fef3c7);
  color:#92400e;border:1px solid rgba(245,158,11,.25);
  display:inline-flex;align-items:center;gap:6px;padding:6px 16px;
  border-radius:30px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
}
.section-title .badge-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--td-amber);animation:tdPulse 2s infinite}
@keyframes tdPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* --- Category cards — premium hover --- */
.cat-card{padding:32px 22px;border:1px solid var(--td-border);transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.cat-card::before{
  content:"";position:absolute;inset:0;border-radius:14px;padding:2px;
  background:linear-gradient(135deg,var(--td-amber),var(--td-primary));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s;
}
.cat-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(4,16,124,.14);border-color:transparent}
.cat-card:hover::before{opacity:1}
.cat-card .icon{
  width:64px;height:64px;border-radius:16px;font-size:28px;
  background:linear-gradient(135deg,var(--td-primary),var(--td-primary-2));
  transition:all .4s;
}
.cat-card:hover .icon{
  background:linear-gradient(135deg,var(--td-amber),#fbbf24);color:var(--td-primary);
  transform:rotate(-6deg) scale(1.05);box-shadow:0 12px 28px rgba(245,158,11,.35);
}
.cat-card h6{font-size:16px;font-weight:700;margin-bottom:6px;color:var(--td-text);letter-spacing:-.01em}
.cat-card span{font-size:12px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* --- Product/Course/Ebook cards — softer shadow + smoother lift --- */
.td-card{box-shadow:0 1px 3px rgba(15,23,42,.04);border-color:rgba(226,232,240,.6)}
.td-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(4,16,124,.16)}
.td-card-img::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.18));
  opacity:0;transition:opacity .3s;
}
.td-card:hover .td-card-img::after{opacity:1}
.td-card-body h5 a:hover{color:var(--td-amber)}

/* --- Feature box — corner accent + animated icon --- */
.feature-box{padding:32px 26px;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.feature-box::before{
  content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.12),transparent 70%);
  transition:all .5s;
}
.feature-box:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(4,16,124,.12);border-color:var(--td-amber)}
.feature-box:hover::before{transform:scale(1.6)}
.feature-box .icon{
  background:linear-gradient(135deg,var(--td-amber-soft),#fde68a);
  width:60px;height:60px;border-radius:14px;font-size:26px;
  transition:all .4s;
}
.feature-box:hover .icon{
  background:linear-gradient(135deg,var(--td-amber),#fbbf24);color:var(--td-primary);
  transform:rotate(8deg) scale(1.05);
}
.feature-box h5{font-size:18px;font-weight:700;letter-spacing:-.01em}

/* --- Testimonial cards (uses feature-box class) --- */
.feature-box .bi-star-fill{color:var(--td-amber)}

/* --- CTA — gradient + decorative --- */
.td-cta{
  padding:80px 30px;border-radius:24px;
  background:linear-gradient(135deg,var(--td-primary) 0%,var(--td-primary-3) 60%,var(--td-primary-2) 100%);
}
.td-cta::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(245,158,11,.2),transparent 50%),
             radial-gradient(circle at 20% 80%,rgba(255,255,255,.08),transparent 50%);
  pointer-events:none;
}
.td-cta h2{font-size:clamp(1.8rem,3.4vw,2.6rem);letter-spacing:-.02em;font-weight:800}
.td-cta p{font-size:18px}
.td-cta .actions .btn{padding:14px 32px;font-size:16px}

/* --- Subtle gradient divider option for sections --- */
.bg-soft{background:linear-gradient(180deg,var(--td-soft) 0%,#f3f4f6 100%)}

/* --- Mobile tweaks for hero --- */
@media (max-width:991.98px){
  .td-hero{padding:80px 0 90px;text-align:center}
  .td-hero h1{font-size:36px}
  .td-hero .stats{justify-content:center;border-top:1px solid rgba(255,255,255,.15);padding-top:24px}
  .td-hero .stats .stat{flex:0 0 auto;border-right:0;padding:0 14px}
  .td-hero .stats .stat strong{font-size:26px}
}

/* Premium confirm dialog (frontend) */
.td-confirm-popup{
  background:#fff!important;border-radius:20px!important;overflow:hidden;
  box-shadow:0 30px 80px rgba(4,16,124,.35), 0 0 0 1px rgba(255,255,255,.5)!important;
  font-family:inherit!important;
}
.td-confirm-popup .swal2-html-container{margin:0!important;padding:0!important;overflow:visible!important}
.td-confirm{padding:36px 32px 24px;text-align:center;background:#fff;position:relative}
.td-confirm::before{
  content:"";position:absolute;top:0;left:0;right:0;height:140px;
  background:radial-gradient(circle at 50% 0%, rgba(245,158,11,.08) 0%, transparent 70%);
  pointer-events:none;
}
.td-confirm-icon{
  width:74px;height:74px;border-radius:50%;margin:0 auto 18px;
  display:flex;align-items:center;justify-content:center;
  font-size:34px;position:relative;z-index:1;
  box-shadow:0 12px 24px rgba(0,0,0,.08);
}
.td-confirm-icon::after{
  content:"";position:absolute;inset:-8px;border-radius:50%;
  border:2px solid currentColor;opacity:.18;
  animation:tdConfirmPulse 2s ease-in-out infinite;
}
@keyframes tdConfirmPulse{
  0%,100%{transform:scale(1);opacity:.18}
  50%{transform:scale(1.12);opacity:0}
}
.td-confirm-icon.danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}
.td-confirm-icon.warn{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}
.td-confirm-icon.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}
.td-confirm-title{
  font-size:22px;font-weight:700;color:#04107C;margin:0 0 8px;
  letter-spacing:-.3px;position:relative;z-index:1;
}
.td-confirm-sub{
  font-size:14px;color:#6b7280;margin:0 8px;line-height:1.6;
  position:relative;z-index:1;
}
.td-confirm-actions{
  background:#f9fafb;border-top:1px solid #e5e7eb;
  padding:18px 24px!important;margin:0!important;
  display:flex!important;gap:10px;justify-content:flex-end;
}
.td-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border:0;border-radius:10px;padding:11px 22px;font-size:14px;font-weight:600;
  cursor:pointer;transition:all .18s ease;font-family:inherit;min-width:110px;
}
.td-btn-danger{background:#dc2626;color:#fff;box-shadow:0 4px 12px rgba(220,38,38,.3)}
.td-btn-danger:hover{background:#b91c1c;transform:translateY(-1px);box-shadow:0 8px 20px rgba(220,38,38,.4)}
.td-btn-primary{background:#04107C;color:#fff;box-shadow:0 4px 12px rgba(4,16,124,.3)}
.td-btn-primary:hover{background:#0a1ba8;transform:translateY(-1px);box-shadow:0 8px 20px rgba(4,16,124,.4)}
.td-btn-ghost{background:#fff;color:#374151;border:1px solid #d1d5db}
.td-btn-ghost:hover{background:#f3f4f6;border-color:#9ca3af}
.td-confirm-show{animation:tdConfirmIn .35s cubic-bezier(.34,1.56,.64,1) both}
.td-confirm-hide{animation:tdConfirmOut .2s ease both}
@keyframes tdConfirmIn{0%{transform:scale(.85);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes tdConfirmOut{0%{transform:scale(1);opacity:1}100%{transform:scale(.95);opacity:0}}

/* Hero carousel polish */
.td-hero .carousel{position:relative}
.td-hero .carousel-item{padding:20px 0 40px}
.td-hero h1{font-size:38px !important;line-height:1.15}
.td-hero .lead{font-size:16px;margin-bottom:20px}
.td-hero .subtitle{margin-bottom:14px;padding:5px 14px;font-size:12px}
.td-hero .actions{margin-bottom:20px}
.td-hero .stats{padding-top:18px;margin-top:18px;gap:24px}
.td-hero .stat strong{font-size:26px}
.td-hero-img img{max-height:340px;object-fit:cover}
@media (max-width:991.98px){
  .td-hero .carousel-item{padding:18px 0 40px}
  .td-hero h1{font-size:26px !important;line-height:1.2}
  .td-hero .lead{font-size:14.5px;margin-bottom:16px}
  .td-hero .actions .btn{padding:9px 18px;font-size:13.5px}
  .td-hero .stats{gap:16px;padding-top:14px;margin-top:14px}
  .td-hero .stat strong{font-size:22px}
}
.td-hero .carousel-indicators{position:absolute;bottom:18px;margin:0;justify-content:center;left:0;right:0;z-index:3}
.td-hero .carousel-indicators button{
  width:28px!important;height:4px!important;border-radius:3px;
  background:rgba(255,255,255,.35)!important;border:0!important;margin:0 4px;opacity:1;transition:.25s;
}
.td-hero .carousel-indicators button.active{background:#F59E0B!important;width:42px!important}
.td-hero .carousel-control-prev,.td-hero .carousel-control-next{
  width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12)!important;
  top:50%;transform:translateY(-50%);bottom:auto;opacity:1;
  border:1px solid rgba(255,255,255,.2);transition:.2s;
}
.td-hero .carousel-control-prev{left:18px}
.td-hero .carousel-control-next{right:18px}
.td-hero .carousel-control-prev:hover,.td-hero .carousel-control-next:hover{
  background:#F59E0B!important;border-color:#F59E0B;
}
.td-hero .carousel-control-prev-icon,.td-hero .carousel-control-next-icon{width:18px;height:18px}
@media (max-width:768px){
  .td-hero .carousel-control-prev,.td-hero .carousel-control-next{display:none}
}

/* Cart items — responsive flex layout (mobile-friendly) */
.cart-items{display:flex;flex-direction:column;gap:12px}
.cart-item{
  background:#fff;border:1px solid var(--td-border);border-radius:14px;padding:16px;
  display:grid;
  grid-template-columns:72px 1fr 110px 100px 110px 40px;
  grid-template-areas:"thumb main price qty subtotal remove";
  align-items:center;gap:14px;transition:.2s;
}
.cart-item:hover{box-shadow:0 8px 24px rgba(4,16,124,.08);border-color:#cbd5e1}
.cart-item-thumb{
  grid-area:thumb;width:72px;height:72px;border-radius:10px;overflow:hidden;
  background:var(--td-soft);display:flex;align-items:center;justify-content:center;
  color:var(--td-muted);font-size:26px;
}
.cart-item-thumb img{width:100%;height:100%;object-fit:cover}
.cart-item-main{grid-area:main;min-width:0}
.cart-item-name{margin:0 0 4px;font-size:15px;font-weight:600;color:var(--td-text);line-height:1.3}
.cart-item-type{font-size:12px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.cart-item-price-mobile{font-size:14px;font-weight:700;color:var(--td-primary);margin-top:6px}
.cart-item-price{grid-area:price;font-size:14px;color:var(--td-muted);text-align:center;white-space:nowrap}
.cart-item-qty{grid-area:qty}
.cart-item-qty input{width:80px;text-align:center;margin:0 auto;display:block}
.cart-item-subtotal{grid-area:subtotal;font-size:16px;font-weight:700;color:var(--td-primary);text-align:right;white-space:nowrap}
.cart-item-remove{grid-area:remove;margin:0}
.btn-icon-x{
  width:36px;height:36px;border-radius:8px;border:0;background:transparent;color:#94a3b8;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s;
}
.btn-icon-x:hover{background:#fef2f2;color:#dc2626}
.btn-icon-x i{font-size:16px}

@media (max-width:767.98px){
  .cart-item{
    grid-template-columns:64px 1fr auto;
    grid-template-rows:auto auto;
    grid-template-areas:
      "thumb main   remove"
      "qty   qty    subtotal";
    padding:14px;gap:12px;align-items:center;
  }
  .cart-item-thumb{width:64px;height:64px}
  .cart-item-price{display:none}
  .cart-item-qty{
    margin:6px 0 0;padding-top:12px;border-top:1px dashed var(--td-border);
  }
  .cart-item-qty input{margin:0;width:96px;text-align:center;display:block}
  .cart-item-subtotal{
    margin:6px 0 0;padding-top:12px;border-top:1px dashed var(--td-border);
    font-size:16px;text-align:right;
  }
}

/* Premium SweetAlert toast — brand-styled */
.td-toast-popup{
  background:#fff!important;border-radius:14px!important;
  padding:0!important;font-family:inherit!important;overflow:hidden!important;
  box-shadow:0 18px 50px rgba(4,16,124,.22), 0 0 0 1px rgba(255,255,255,.6)!important;
  margin-top:14px!important;
}
.td-toast-popup .swal2-html-container{margin:0!important;padding:0!important;text-align:left!important}
.td-toast{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px 14px 14px;position:relative;
  background:#fff;
}
.td-toast::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:0 4px 4px 0;
}
.td-toast-success::before{background:linear-gradient(180deg,#10b981 0%,#059669 100%)}
.td-toast-error::before{background:linear-gradient(180deg,#ef4444 0%,#dc2626 100%)}
.td-toast-icon{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.td-toast-success .td-toast-icon{
  background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669;
  box-shadow:0 4px 12px rgba(16,185,129,.18);
}
.td-toast-error .td-toast-icon{
  background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;
  box-shadow:0 4px 12px rgba(220,38,38,.18);
}
.td-toast-body{flex:1;min-width:0;line-height:1.35}
.td-toast-title{
  font-size:13px;font-weight:700;letter-spacing:.02em;margin-bottom:2px;
}
.td-toast-success .td-toast-title{color:#059669}
.td-toast-error .td-toast-title{color:#dc2626}
.td-toast-msg{font-size:13.5px;color:#1f2937;font-weight:500;line-height:1.45}
.td-toast-popup .swal2-timer-progress-bar-container{
  position:absolute;left:0;right:0;bottom:0;height:3px;background:transparent;
}
.td-toast-popup .swal2-timer-progress-bar{
  background:linear-gradient(90deg,#04107C 0%,#F59E0B 100%)!important;height:3px!important;
}
/* Smooth slide-in from right */
.td-toast-show{animation:tdToastIn .35s cubic-bezier(.34,1.56,.64,1) both}
.td-toast-hide{animation:tdToastOut .25s ease both}
@keyframes tdToastIn{0%{transform:translateX(110%);opacity:0}100%{transform:translateX(0);opacity:1}}
@keyframes tdToastOut{0%{transform:translateX(0);opacity:1}100%{transform:translateX(110%);opacity:0}}

/* Swiper — Software Products slider on homepage */
.td-card-swiper{padding:10px 4px 60px;position:relative;overflow:hidden}
.td-card-swiper .swiper-button-prev,.td-card-swiper .swiper-button-next{
  z-index:5;
}
/* Allow card hover lift to show without clipping vertically */
.td-card-swiper .swiper-wrapper{padding-top:6px;padding-bottom:6px}
.td-card-swiper .swiper-wrapper{align-items:stretch}
.td-card-swiper .swiper-slide{height:auto;display:flex}
.td-card-swiper .swiper-slide > *{width:100%}
.td-card-swiper .td-swiper-arrow{
  width:44px;height:44px;border-radius:50%;
  background:#fff;border:1px solid var(--td-border);color:var(--td-primary);
  box-shadow:0 6px 20px rgba(4,16,124,.12);
  display:flex;align-items:center;justify-content:center;
  margin-top:0;top:42%;transform:translateY(-50%);
  transition:.2s;
}
.td-card-swiper .td-swiper-arrow:hover{
  background:var(--td-amber);border-color:var(--td-amber);color:var(--td-primary);
  transform:translateY(-50%) scale(1.08);box-shadow:0 10px 26px rgba(245,158,11,.35);
}
.td-card-swiper .td-swiper-arrow.swiper-button-prev{left:8px}
.td-card-swiper .td-swiper-arrow.swiper-button-next{right:8px}
.td-card-swiper .td-swiper-arrow::after{font-size:16px;font-weight:700}
.td-card-swiper .td-swiper-arrow.swiper-button-disabled{opacity:0;pointer-events:none}
.td-card-swiper .swiper-pagination{bottom:10px!important;position:absolute}
.td-card-swiper .swiper-pagination-bullet{
  width:8px;height:8px;background:#cbd5e1;opacity:1;transition:.2s;border-radius:5px;
}
.td-card-swiper .swiper-pagination-bullet-active{
  background:linear-gradient(90deg,var(--td-primary),var(--td-amber));width:28px;border-radius:5px;
}
@media (max-width:991.98px){
  .td-card-swiper .td-swiper-arrow{display:none}
}

/* Footer contact rows — icon stays left, text aligns beside (not below) */
.td-foot-item{display:flex;align-items:flex-start;gap:10px;line-height:1.5}
.td-foot-item > i{flex-shrink:0;margin-top:4px;font-size:15px;min-width:18px;text-align:center}
.td-foot-item > span,.td-foot-item > a{flex:1;min-width:0;word-break:break-word}

/* ============================================================
   Cart + Checkout — premium two-column layout
   ============================================================ */
.td-checkout-hero{
  background:linear-gradient(135deg,#04107C 0%,#020a5a 100%);
  color:#fff;padding:60px 0 50px;position:relative;overflow:hidden;
}
.td-checkout-hero::before{
  content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.16) 0%,transparent 70%);
  top:-180px;right:-120px;pointer-events:none;
}
.td-checkout-hero::after{
  content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);
  bottom:-160px;left:-80px;pointer-events:none;
}
.td-checkout-hero .td-eyebrow{
  display:inline-block;background:rgba(245,158,11,.18);color:#F59E0B;
  padding:5px 14px;border-radius:30px;font-size:11px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;
  border:1px solid rgba(245,158,11,.3);position:relative;z-index:2;
}
.td-checkout-hero .td-page-title{color:#fff;margin:0 0 8px;font-size:34px;font-weight:800;letter-spacing:-.3px;position:relative;z-index:2}
.td-checkout-hero .td-page-sub{color:rgba(255,255,255,.75);font-size:15px;margin-bottom:28px;max-width:560px;position:relative;z-index:2}
.td-steps{
  display:flex;justify-content:center;gap:0;list-style:none;margin:0;padding:0;
  position:relative;z-index:2;flex-wrap:wrap;
}
.td-steps li{
  display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.5);
  font-size:13px;font-weight:600;position:relative;padding:0 22px;
}
.td-steps li::after{
  content:"";position:absolute;right:-1px;top:50%;transform:translateY(-50%);
  width:30px;height:1px;background:rgba(255,255,255,.25);
}
.td-steps li:last-child::after{display:none}
.td-steps li .num{
  width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;transition:.2s;
}
.td-steps li.active{color:#F59E0B}
.td-steps li.active .num{background:#F59E0B;border-color:#F59E0B;color:#04107C;box-shadow:0 0 0 4px rgba(245,158,11,.18)}
.td-steps li.done{color:rgba(255,255,255,.85)}
.td-steps li.done .num{background:rgba(16,185,129,.95);border-color:rgba(16,185,129,.95);color:#fff}
@media (max-width:575.98px){
  .td-checkout-hero{padding:42px 0 36px}
  .td-checkout-hero .td-page-title{font-size:26px}
  .td-steps li{padding:0 12px;font-size:12px}
  .td-steps li::after{width:14px}
  .td-steps li .num{width:28px;height:28px;font-size:12px}
  .td-steps li .label{display:none}
  .td-steps li.active .label{display:inline}
}

.td-section-card,.td-summary-card{
  background:#fff;border:1px solid var(--td-border);border-radius:16px;
  box-shadow:0 4px 14px rgba(4,16,124,.04);overflow:hidden;
}
.td-section-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 22px;border-bottom:1px solid var(--td-border);background:#fafbfc;
}
.td-section-head h5{font-size:15px;font-weight:700;color:#04107C;letter-spacing:-.1px}
.td-section-head .td-count{
  background:#04107C;color:#fff;font-size:11px;font-weight:700;padding:2px 9px;
  border-radius:20px;margin-left:6px;
}
.td-section-body{padding:22px}

.td-summary-card .td-summary-head{
  padding:16px 22px;border-bottom:1px solid var(--td-border);
  background:linear-gradient(135deg,#04107C 0%,#0a1ba8 100%);color:#fff;
}
.td-summary-card .td-summary-head h5{color:#fff}
.td-summary-card .td-summary-head h5 .text-amber{color:#fbbf24!important}
.td-summary-body{padding:20px 22px}
.td-summary-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;font-size:14px;color:var(--td-text-2);
}
.td-summary-row strong{color:var(--td-text);font-weight:700}
.td-summary-discount span:first-child code{
  background:#fef3c7;color:#92400e;padding:1px 7px;border-radius:4px;font-size:12px;font-weight:600;
}
.td-summary-divider{height:1px;background:var(--td-border);margin:10px 0}
.td-summary-total{font-size:18px;color:var(--td-text)!important;padding:12px 0 4px}
.td-summary-total strong{font-size:26px;font-weight:800;color:#04107C;letter-spacing:-.5px}
.td-savings-banner{
  background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#065f46;
  padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;
  display:flex;align-items:center;gap:8px;margin:8px 0 4px;
  border:1px solid rgba(16,185,129,.2);
}
.td-savings-banner i{font-size:16px}

.td-coupon-form{
  position:relative;display:flex;align-items:center;gap:0;
  background:#f9fafb;border:1px solid var(--td-border);border-radius:10px;
  padding:4px;margin:10px 0;transition:.2s;
}
.td-coupon-form:focus-within{border-color:#04107C;background:#fff;box-shadow:0 0 0 4px rgba(4,16,124,.08)}
.td-coupon-form .input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9ca3af}
.td-coupon-form input{
  flex:1;border:0;background:transparent;padding:9px 12px 9px 36px;font-size:14px;outline:none;color:var(--td-text);
}
.td-coupon-form input::placeholder{color:#9ca3af}
.td-coupon-form button{
  background:#04107C;color:#fff;border:0;padding:9px 18px;border-radius:8px;
  font-weight:600;font-size:13px;cursor:pointer;transition:.2s;
}
.td-coupon-form button:hover{background:#F59E0B;color:#04107C}

.td-trust-row{
  display:flex;justify-content:space-around;padding:14px 18px;
  background:#fafbfc;border-top:1px solid var(--td-border);font-size:12px;
}
.td-trust-row > div{display:flex;align-items:center;gap:6px;color:var(--td-muted);font-weight:600}
.td-trust-row i{font-size:15px}
.text-primary-td{color:#04107C}

.td-pay-strip{
  margin-top:14px;padding:18px 18px 16px;background:#fff;border:1px solid var(--td-border);
  border-radius:14px;text-align:center;
}
.td-pay-strip small{display:block;color:var(--td-muted);font-size:11px;letter-spacing:.12em;margin-bottom:12px;font-weight:700;text-transform:uppercase}
.td-pay-imgs{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}
.td-pay-imgs img{
  height:56px;width:90px;object-fit:contain;
  background:#fff;border:1px solid #e5e7eb;border-radius:10px;
  padding:8px 14px;transition:all .2s ease;box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.td-pay-imgs img:hover{
  transform:translateY(-2px);border-color:#F59E0B;
  box-shadow:0 8px 18px rgba(4,16,124,.12);
}
@media (max-width:575.98px){
  .td-pay-imgs{gap:8px}
  .td-pay-imgs img{height:48px;width:76px;padding:6px 10px}
}

.td-empty-state{
  max-width:480px;margin:60px auto;text-align:center;padding:48px 32px;
  background:#fff;border-radius:18px;border:1px solid var(--td-border);
}
.td-empty-icon{
  width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#eef2ff,#dbeafe);
  display:flex;align-items:center;justify-content:center;color:#04107C;font-size:42px;
  margin:0 auto 22px;
}
.td-empty-state h2{font-size:22px;margin-bottom:10px;color:#04107C}
.td-empty-state p{color:var(--td-muted);margin-bottom:20px}

.td-guest-notice{
  background:linear-gradient(135deg,#fef3c7,#fde68a);color:#78350f;
  padding:14px 18px;border-radius:12px;display:flex;align-items:flex-start;gap:14px;
  margin-bottom:24px;border:1px solid rgba(245,158,11,.3);
}
.td-guest-notice i{font-size:24px;color:#d97706;flex-shrink:0;margin-top:2px}
.td-guest-notice a{color:#92400e;font-weight:700;text-decoration:underline}

.td-pay-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.td-pay-card{margin:0;cursor:pointer;position:relative}
.td-pay-card input{position:absolute;opacity:0;pointer-events:none}
.td-pay-card-inner{
  border:2px solid var(--td-border);border-radius:14px;padding:18px 14px;text-align:center;
  background:#fff;transition:all .2s ease;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
}
.td-pay-card-inner > img{height:30px;width:auto;max-width:80px;object-fit:contain;margin-bottom:6px}
.td-pay-card-inner .td-pay-icon{
  width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#04107C,#0a1ba8);
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:6px;
}
.td-pay-card-inner .td-pay-cards{
  display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:6px;flex-wrap:wrap;
}
.td-pay-card-inner .td-pay-cards img{
  height:26px;width:auto;object-fit:contain;border-radius:4px;
  box-shadow:0 1px 3px rgba(0,0,0,.08);
}
/* Logo-only payment card — bigger logo, no text */
.td-pay-card-logo-only{min-height:96px;padding:16px}
.td-pay-card-logo-only > img{height:56px!important;max-width:140px!important;margin-bottom:0!important}
.td-pay-card-logo-only .td-pay-cards{margin-bottom:0;gap:6px}
.td-pay-card-logo-only .td-pay-cards img{height:29px}
.td-pay-card-inner h6{font-size:14px;font-weight:700;margin:0;color:var(--td-text)}
.td-pay-card-inner small{font-size:11px;color:var(--td-muted)}
.td-pay-card:hover .td-pay-card-inner{border-color:#04107C;transform:translateY(-2px);box-shadow:0 8px 20px rgba(4,16,124,.08)}
.td-pay-card input:checked + .td-pay-card-inner{
  border-color:#F59E0B;background:linear-gradient(135deg,#fffbeb,#fef3c7);
  box-shadow:0 0 0 4px rgba(245,158,11,.18);
}
.td-pay-card input:checked + .td-pay-card-inner h6{color:#04107C}
@media (max-width:575.98px){
  .td-pay-methods{grid-template-columns:1fr;gap:10px}
  .td-pay-card-inner{flex-direction:row;text-align:left;gap:14px;padding:14px 16px}
  .td-pay-card-inner > img,.td-pay-card-inner .td-pay-icon,.td-pay-card-inner .td-pay-cards{margin-bottom:0;flex-shrink:0}
  .td-pay-card-inner h6{margin-bottom:2px}
  .td-pay-card-logo-only{min-height:78px}
  .td-pay-card-logo-only > img{height:46px!important}
  .td-pay-card-logo-only .td-pay-cards img{height:34px}
}
.td-pay-secure{
  margin-top:16px;padding:10px 14px;background:#ecfdf5;color:#065f46;
  border-radius:10px;font-size:12px;border:1px solid rgba(16,185,129,.2);
}

.td-order-items{list-style:none;margin:0;padding:0;max-height:300px;overflow-y:auto}
.td-order-items li{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed var(--td-border)}
.td-order-items li:last-child{border-bottom:0}
.td-order-thumb{
  position:relative;width:50px;height:50px;border-radius:8px;
  background:var(--td-soft);overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:var(--td-muted);
}
.td-order-thumb img{width:100%;height:100%;object-fit:cover}
.td-order-qty{
  position:absolute;top:-6px;right:-6px;background:#04107C;color:#fff;
  font-size:10px;font-weight:700;width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;border:2px solid #fff;
}
.td-order-info{flex:1;min-width:0}
.td-order-info h6{font-size:13px;font-weight:600;margin:0 0 2px;color:var(--td-text);line-height:1.3}
.td-order-info small{font-size:11px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.td-order-price{font-size:14px;color:#04107C;white-space:nowrap}

/* Mobile sticky bottom Place Order bar */
.td-mobile-checkout-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:1040;
  background:#fff;border-top:1px solid var(--td-border);
  padding:12px 16px;display:flex;align-items:center;gap:12px;
  box-shadow:0 -8px 24px rgba(4,16,124,.10);
  animation:tdBarUp .3s ease both;
}
@keyframes tdBarUp{0%{transform:translateY(100%)}100%{transform:translateY(0)}}
.td-mobile-price{display:flex;flex-direction:column;line-height:1.1;flex-shrink:0;min-width:0}
.td-mobile-price small{font-size:11px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.td-mobile-price strong{font-size:18px;color:#04107C;font-weight:800;white-space:nowrap}
.td-mobile-checkout-bar .btn{padding:11px 16px;font-size:14px;white-space:nowrap}
/* Push page content above the bar on mobile */
@media (max-width:991.98px){
  body:has(.td-mobile-checkout-bar){padding-bottom:80px}
}

/* Order status banner — paid / pending */
.td-order-status{
  background:#fff;border-radius:18px;padding:24px 28px;
  display:flex;align-items:flex-start;gap:20px;
  box-shadow:0 8px 30px rgba(4,16,124,.08);
  border:1px solid var(--td-border);position:relative;overflow:hidden;
}
.td-order-status::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
}
.td-order-status-paid::before{background:linear-gradient(180deg,#10b981,#059669)}
.td-order-status-pending::before{background:linear-gradient(180deg,#F59E0B,#d97706)}
.td-order-status-icon{
  width:64px;height:64px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:30px;
}
.td-order-status-paid .td-order-status-icon{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}
.td-order-status-pending .td-order-status-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}
.td-order-status-body{flex:1;min-width:0}
.td-order-status-body h2{font-size:22px;font-weight:700;color:#04107C;margin:0 0 6px;letter-spacing:-.2px}
.td-order-num{color:var(--td-muted);font-size:14px;margin:0 0 8px}
.td-order-num code{background:#eef2ff;color:#04107C;padding:2px 9px;border-radius:6px;font-size:13px;font-weight:700;letter-spacing:.5px}
.td-order-note{
  margin:8px 0 0;padding:10px 14px;background:#fffbeb;color:#78350f;
  border-radius:10px;font-size:13.5px;border:1px solid rgba(245,158,11,.25);line-height:1.55;
}
@media (max-width:575.98px){
  .td-order-status{flex-direction:column;gap:14px;padding:20px}
  .td-order-status-icon{width:52px;height:52px;font-size:24px}
}

/* ============================================================
   Product Detail Page — premium layout
   ============================================================ */
.td-product-hero{
  background:linear-gradient(135deg,#04107C 0%,#020a5a 100%);
  color:#fff;padding:18px 0;position:relative;overflow:hidden;
}
.td-product-hero::before{
  content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.12) 0%,transparent 70%);
  top:-160px;right:-100px;pointer-events:none;
}
.td-product-hero .td-breadcrumb{
  display:flex;align-items:center;gap:8px;font-size:13px;
  color:rgba(255,255,255,.65);position:relative;z-index:2;flex-wrap:wrap;
}
.td-product-hero .td-breadcrumb a{color:rgba(255,255,255,.85);text-decoration:none;transition:.2s}
.td-product-hero .td-breadcrumb a:hover{color:#F59E0B}
.td-product-hero .td-breadcrumb .sep{opacity:.4}
.td-product-hero .td-breadcrumb .current{color:#F59E0B;font-weight:600}

/* Gallery */
.td-product-gallery{background:#fff;border:1px solid var(--td-border);border-radius:18px;overflow:hidden;box-shadow:0 4px 14px rgba(4,16,124,.04)}
.td-product-gallery .main{position:relative;background:var(--td-soft);aspect-ratio:16/10;overflow:hidden}
.td-product-gallery .main img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.td-product-gallery .main:hover img{transform:scale(1.03)}
.td-corner-badge{
  position:absolute;top:16px;left:16px;background:#F59E0B;color:#04107C;
  font-size:11px;font-weight:800;padding:6px 12px;border-radius:8px;letter-spacing:.06em;
  text-transform:uppercase;box-shadow:0 4px 14px rgba(245,158,11,.3);
}
.td-corner-badge.bestseller{background:linear-gradient(135deg,#F59E0B,#fbbf24)}
.td-corner-discount{
  position:absolute;top:16px;right:16px;background:#dc2626;color:#fff;
  font-size:13px;font-weight:800;padding:6px 12px;border-radius:8px;
  box-shadow:0 4px 14px rgba(220,38,38,.3);
}
.td-product-gallery .thumbs{
  display:flex;gap:8px;padding:14px;overflow-x:auto;background:#fafbfc;border-top:1px solid var(--td-border);
}
.td-product-gallery .thumb{
  width:74px;height:60px;border:2px solid transparent;border-radius:8px;overflow:hidden;
  background:none;padding:0;cursor:pointer;flex-shrink:0;transition:.2s;
}
.td-product-gallery .thumb img{width:100%;height:100%;object-fit:cover}
.td-product-gallery .thumb:hover{transform:translateY(-2px)}
.td-product-gallery .thumb.active{border-color:#F59E0B;box-shadow:0 4px 12px rgba(245,158,11,.25)}

/* Tabs */
.td-product-tabs{
  display:flex;gap:0;border-bottom:2px solid var(--td-border);overflow-x:auto;
  scrollbar-width:none;
}
.td-product-tabs::-webkit-scrollbar{display:none}
.td-product-tabs .tab-btn{
  background:none;border:0;padding:12px 18px;font-size:14px;font-weight:600;
  color:var(--td-muted);cursor:pointer;position:relative;white-space:nowrap;transition:.2s;
}
.td-product-tabs .tab-btn:hover{color:#04107C}
.td-product-tabs .tab-btn.active{color:#04107C}
.td-product-tabs .tab-btn.active::after{
  content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:#F59E0B;border-radius:3px 3px 0 0;
}
.td-product-tab-content{padding:24px 4px;min-height:200px}
.td-product-tab-content .tab-panel{display:none;animation:tabFade .25s ease}
.td-product-tab-content .tab-panel.active{display:block}
@keyframes tabFade{0%{opacity:0;transform:translateY(6px)}100%{opacity:1;transform:translateY(0)}}

/* Feature list */
.td-feature-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}
.td-feature-list li{
  display:flex;align-items:flex-start;gap:10px;padding:10px 14px;
  background:#f8fafc;border-radius:10px;border:1px solid var(--td-border);
}
.td-feature-list li i{
  width:26px;height:26px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;
}
.td-feature-list li span{font-size:14px;color:var(--td-text);line-height:1.45}

/* Demo card */
.td-demo-card{
  background:linear-gradient(135deg,#fff,#f9fafb);border:1px solid var(--td-border);border-radius:14px;
  padding:24px;display:flex;align-items:flex-start;gap:18px;
}
.td-demo-icon{
  width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#F59E0B,#fbbf24);color:#04107C;
  display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;
  box-shadow:0 6px 16px rgba(245,158,11,.3);
}
.td-demo-body h5{font-size:18px;color:#04107C;margin:0 0 4px;font-weight:700}
.td-demo-body p{color:var(--td-muted);margin:0 0 10px;font-size:14px}
.td-demo-creds{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.td-demo-creds > div{
  background:#fff;border:1px dashed var(--td-border);border-radius:10px;padding:8px 14px;
  display:flex;flex-direction:column;line-height:1.2;
}
.td-demo-creds small{font-size:10px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.td-demo-creds code{background:none;padding:0;color:#04107C;font-weight:700;font-size:14px}

/* Requirements panel */
.td-reqs{background:#f8fafc;border-left:4px solid #F59E0B;padding:14px 18px;border-radius:8px;line-height:1.7;color:var(--td-text-2);font-size:14px;white-space:pre-line}

/* Right buy panel */
.td-buy-panel{
  background:#fff;border:1px solid var(--td-border);border-radius:18px;
  padding:24px 26px;box-shadow:0 8px 30px rgba(4,16,124,.06);
}
.td-buy-head{padding-bottom:18px;border-bottom:1px solid var(--td-border);margin-bottom:18px}
.td-buy-cat{
  font-size:11px;color:var(--td-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700;
  display:inline-block;margin-bottom:8px;
}
.td-buy-title{font-size:22px;font-weight:800;color:#04107C;margin:0 0 8px;letter-spacing:-.3px;line-height:1.25}
.td-buy-sub{font-size:14px;color:var(--td-muted);line-height:1.55;margin:0}
.td-buy-price{display:flex;align-items:baseline;gap:14px;margin-bottom:6px;flex-wrap:wrap}
.td-buy-price-now{font-size:34px;font-weight:800;color:#04107C;letter-spacing:-.5px;line-height:1}
.td-buy-price-was{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.td-buy-price-was .was{text-decoration:line-through;color:var(--td-muted);font-size:16px}
.td-buy-price-was .save{
  background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;
  padding:3px 10px;border-radius:6px;font-size:12px;font-weight:700;
}
.td-buy-savings{
  background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#065f46;
  padding:10px 14px;border-radius:10px;font-size:13.5px;
  display:flex;align-items:center;gap:8px;margin:12px 0 18px;
  border:1px solid rgba(16,185,129,.2);
}
.td-buy-savings i{font-size:16px}
.td-buy-actions{margin:0}
.td-buy-actions .btn{font-weight:700}
.td-buy-trust{list-style:none;padding:18px 0 0;margin:18px 0 0;border-top:1px solid var(--td-border)}
.td-buy-trust li{
  display:flex;align-items:center;gap:12px;padding:8px 0;font-size:13.5px;color:var(--td-text-2);
}
.td-buy-trust li i{
  width:30px;height:30px;border-radius:8px;background:#fef3c7;color:#d97706;
  display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;
}
.td-buy-pay{margin-top:18px;padding-top:18px;border-top:1px solid var(--td-border);text-align:center}
.td-buy-pay small{display:block;color:var(--td-muted);font-size:10px;letter-spacing:.12em;font-weight:700;text-transform:uppercase;margin-bottom:10px}
.td-buy-pay .td-pay-imgs{gap:8px}
.td-buy-pay .td-pay-imgs img{height:50px;width:78px;padding:7px 11px}

/* Buy Now + Add to Cart — side-by-side on desktop, stacked on mobile */
.td-buy-actions-row{
  display:flex !important;flex-wrap:wrap;gap:10px;margin-top:4px;
  align-items:stretch;
}
.td-buy-actions-row > *{
  flex:1 1 0 !important;min-width:0 !important;width:0 !important;margin:0 !important;
  display:flex !important;
}
.td-buy-actions-row .btn{
  font-weight:700;padding:13px 14px !important;
  width:100% !important;height:52px !important;
  display:inline-flex !important;align-items:center;justify-content:center;
  font-size:16px;line-height:1;white-space:nowrap;
  box-sizing:border-box;
}
@media (max-width:575.98px){
  .td-buy-actions-row > *{flex:1 1 100% !important;width:100% !important}
}

@media (max-width:991.98px){
  .td-buy-panel{position:static!important}
}
@media (max-width:575.98px){
  .td-buy-title{font-size:20px}
  .td-buy-price-now{font-size:28px}
  .td-buy-panel{padding:20px}
}

/* ============================================================
   Shop page — unified catalog
   ============================================================ */
.td-shop-hero{
  background:linear-gradient(135deg,#04107C 0%,#020a5a 100%);
  color:#fff;padding:60px 0 70px;position:relative;overflow:hidden;text-align:center;
}
.td-shop-hero::before{
  content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.18) 0%,transparent 70%);
  top:-200px;right:-120px;pointer-events:none;
}
.td-shop-hero::after{
  content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%);
  bottom:-160px;left:-80px;pointer-events:none;
}
.td-shop-hero .td-eyebrow{
  display:inline-block;background:rgba(245,158,11,.18);color:#F59E0B;
  padding:5px 14px;border-radius:30px;font-size:11px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;
  border:1px solid rgba(245,158,11,.3);position:relative;z-index:2;
}
.td-shop-hero h1{color:#fff;font-size:38px;font-weight:800;margin:0 0 8px;letter-spacing:-.4px;position:relative;z-index:2}
.td-shop-hero p{color:rgba(255,255,255,.8);font-size:15px;margin:0 auto 28px;max-width:560px;position:relative;z-index:2}
.td-shop-search{
  position:relative;z-index:2;display:flex;align-items:center;gap:0;max-width:640px;margin:0 auto;
  background:#fff;border-radius:5px;padding:6px;box-shadow:0 20px 50px rgba(0,0,0,.25);
}
.td-shop-search .input-icon{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:18px}
.td-shop-search input{
  flex:1;border:0;background:transparent;padding:14px 14px 14px 48px;font-size:15px;outline:none;color:var(--td-text);
}
.td-shop-search button{
  background:linear-gradient(135deg,#F59E0B,#fbbf24);color:#04107C;border:0;
  padding:12px 28px;border-radius:5px;font-weight:700;font-size:14px;cursor:pointer;transition:.2s;
}
.td-shop-search button:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(245,158,11,.4)}
@media (max-width:575.98px){
  .td-shop-hero{padding:42px 0 50px}
  .td-shop-hero h1{font-size:28px}
  .td-shop-search input{padding:11px 10px 11px 44px;font-size:14px}
  .td-shop-search button{padding:10px 18px;font-size:13px}
}

/* Chips */
.td-shop-chips{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
  padding:18px;background:#fff;border-radius:5px;border:1px solid var(--td-border);
  box-shadow:0 4px 14px rgba(4,16,124,.04);margin-bottom:26px;
}
.td-shop-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 18px;border:1px solid var(--td-border);border-radius:5px;
  font-size:14px;font-weight:600;color:var(--td-text-2);background:#fff;
  transition:all .2s ease;text-decoration:none;
}
.td-shop-chip:hover{border-color:#04107C;color:#04107C;transform:translateY(-2px)}
.td-shop-chip.active{
  background:linear-gradient(135deg,#04107C,#0a1ba8);color:#fff!important;
  border-color:#04107C;box-shadow:0 8px 20px rgba(4,16,124,.25);
}
.td-shop-chip i{font-size:15px}
.td-shop-chip .td-chip-count{
  background:rgba(0,0,0,.08);color:inherit;font-size:11px;font-weight:700;
  padding:1px 8px;border-radius:20px;
}
.td-shop-chip.active .td-chip-count{background:rgba(245,158,11,.25);color:#fbbf24}

/* Sub-chips (category filter under type) */
.td-shop-subchips{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:-18px 0 26px;
  padding:14px 18px;background:#f8fafc;border-radius:5px;border:1px solid var(--td-border);
}
.td-shop-subchip{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border:1px solid var(--td-border);border-radius:5px;
  font-size:13px;font-weight:600;color:var(--td-text-2);background:#fff;
  transition:all .15s ease;text-decoration:none;
}
.td-shop-subchip:hover{border-color:#F59E0B;color:#92400e;background:#fef3c7}
.td-shop-subchip.active{
  background:#F59E0B;color:#04107C !important;border-color:#F59E0B;
  box-shadow:0 4px 10px rgba(245,158,11,.3);
}
.td-shop-subchip i{font-size:13px}

/* Toolbar */
.td-shop-toolbar{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:18px;flex-wrap:wrap;gap:12px;
}
.td-shop-count{font-size:14px;color:var(--td-text-2)}
.td-shop-count strong{color:#04107C;font-weight:700}
.td-shop-count em{color:#04107C;font-style:normal;font-weight:600}
.td-shop-sort{display:flex;align-items:center;gap:10px}
.td-shop-sort label{font-size:13px;color:var(--td-muted);font-weight:600;margin:0}
.td-shop-sort select{
  border:1px solid var(--td-border);border-radius:8px;padding:8px 32px 8px 12px;
  font-size:13px;background:#fff;cursor:pointer;color:var(--td-text);font-weight:500;
}
.td-shop-sort select:focus{outline:none;border-color:#04107C;box-shadow:0 0 0 3px rgba(4,16,124,.1)}

/* Type badge colors on the card */
.td-type-badge{font-size:10px!important;letter-spacing:.06em;padding:4px 9px!important}
.td-type-software{background:#04107C!important;color:#fff!important}
.td-type-api{background:#7c3aed!important;color:#fff!important}
.td-type-ebook{background:#dc2626!important;color:#fff!important}
.td-type-course{background:#059669!important;color:#fff!important}
.td-type-service{background:#0891b2!important;color:#fff!important}

/* Portrait cover (ebooks) keeps proper 3:4 aspect inside the gallery */
.td-product-gallery .main.td-cover-portrait{aspect-ratio:3/4;max-height:560px;background:#0f172a}
.td-product-gallery .main.td-cover-portrait img{object-fit:contain;padding:30px}


/* ============================================================
   GLOBAL 5PX RADIUS — buttons + cards + form controls
   (loaded last so it overrides all earlier radius declarations)
   ============================================================ */
.btn,
.btn-lg,
.btn-sm,
.card,
.td-card,
.td-section-card,
.td-summary-card,
.td-section-card .card-header,
.td-blog-card,
.td-blog-hero,
.td-service-card,
.td-value-card,
.td-team-card,
.td-process-step,
.td-info-card,
.td-channel-card,
.cart-item,
.feature-box,
.cat-card,
.td-stat,
.cust-stat,
.cust-hero,
.td-buy-panel,
.td-product-gallery,
.td-empty-state,
.td-pay-card-inner,
.alert,
.form-control,
.form-control-lg,
.form-control-sm,
.form-select,
.form-select-lg,
.form-select-sm,
.input-group-text,
.dropdown-menu,
.dropdown-item,
.modal-content,
.shadow-soft,
.rounded-xl,
.td-buy-actions-row .btn,
.td-pay-imgs img,
.td-section-head,
.cust-list-icon,
.cust-list-item,
.td-shop-search,
.td-coupon-form,
.td-coupon-form button,
.td-blog-card-img,
.td-tag-pill,
.td-shop-chip,
.td-savings-banner,
.td-trust-row,
.td-pay-strip,
.td-mobile-checkout-bar .btn,
.td-side-widget,
.td-legal-nav,
.td-legal-link,
.td-legal-help,
.td-author-card,
.td-comment-form,
.td-final-cta,
.td-stats-band .td-stat-tile,
.td-process,
.td-product-gallery .main,
.td-product-gallery .thumb,
.td-corner-badge,
.td-corner-discount,
.td-blog-featured,
.td-blog-featured-img,
.td-blog-featured-body,
.td-channel-icon,
.td-service-icon,
.td-value-icon,
.td-process-icon,
.td-comment-form,
.td-pay-secure,
.td-guest-notice,
.td-savings-banner,
.td-empty-icon{
  border-radius:5px !important;
}

/* Don't break the things that NEED to be circular */
.rounded-circle,
.cust-avatar img,
.td-avatar,
.td-blog-author img,
.td-author-card img,
.td-comment img,
.td-team-photo,
.td-pay-toggle,
.td-cart-btn,
.td-toggler,
.td-icon-btn,
.td-mobile-toggle,
.td-search input,
.iti__flag,
.td-share-row a,
.td-share-btn,
.td-social,
.td-loader-spinner,
.td-loader-spinner *,
.td-confirm-icon,
.td-toast-icon,
.td-side-rank,
.td-empty-icon,
.td-channel-arrow,
.td-team-social a,
.cust-avatar-status,
.iti--separate-dial-code .iti__selected-dial-code{
  border-radius:50% !important;
}

/* Pills (small badges, status chips, breadcrumb chips) — keep pill shape */
.badge.rounded-pill,
.td-eyebrow,
.td-mini-tag,
.td-mini-tag-light,
.td-tag-pill,
.meta-status,
.td-corner-badge,
.td-corner-discount,
.td-stat,
.td-buy-cat,
.swiper-pagination-bullet,
.swiper-pagination-bullet-active,
.td-loader-bars span,
.td-pay-imgs img:not([class*="logo-only"]){
  border-radius:30px !important;
}

/* Force inputs in cart/checkout that should remain slim pills */
.td-coupon-form{
  border-radius:30px !important;
}

/* Section cards keep 5px for the outer + inner */
.td-section-card .card-header{border-radius:5px 5px 0 0 !important}
.td-summary-card .td-summary-head{border-radius:5px 5px 0 0 !important}
.td-summary-card .td-trust-row{border-radius:0 0 5px 5px !important}

/* ============================================================
   Radius override fix — keep inner image-wrappers flush
   (parent has overflow:hidden + 5px; children must be 0)
   ============================================================ */
.td-blog-featured > *,
.td-blog-featured .td-blog-featured-img,
.td-blog-featured .td-blog-featured-body,
.td-blog-card .td-blog-card-img,
.td-card .td-card-img,
.td-product-gallery .main,
.td-product-gallery .thumbs,
.td-info-card .td-info-card-head,
.td-info-card .td-info-card-body,
.td-section-card .td-section-body,
.td-summary-card .td-summary-body,
.cust-hero .cust-hero-banner,
.cust-hero .cust-hero-body,
.td-pay-card .td-pay-card-inner,
.td-channel-card .td-channel-icon,
.cart-item .cart-item-thumb,
.td-order-thumb,
.td-author-card img,
.td-comment img,
.cust-list-item .cust-list-icon{
  border-radius:0 !important;
}

/* These specific elements need to STAY circular even after the fix */
.td-pay-card .td-pay-card-inner .td-pay-icon{border-radius:8px !important}
.td-channel-card .td-channel-icon{border-radius:12px !important}
.cart-item .cart-item-thumb{border-radius:8px !important}
.td-order-thumb{border-radius:8px !important}
.cust-list-item .cust-list-icon{border-radius:8px !important}
.td-product-gallery .main{border-radius:5px 5px 0 0 !important}
.td-product-gallery .thumbs{border-radius:0 0 5px 5px !important}
.td-product-gallery .thumb img{border-radius:5px !important}
.td-author-card img,
.td-comment img{border-radius:50% !important}

/* Featured blog post inner halves — flush to parent corners */
.td-blog-featured-img{border-radius:5px 0 0 5px !important}
.td-blog-featured-body{border-radius:0 5px 5px 0 !important}
@media (max-width:767.98px){
  .td-blog-featured-img{border-radius:5px 5px 0 0 !important}
  .td-blog-featured-body{border-radius:0 0 5px 5px !important}
}

/* Card images — top-rounded only (since they sit at the top of the card) */
.td-card .td-card-img,
.td-blog-card .td-blog-card-img{border-radius:5px 5px 0 0 !important}

/* Section-card head — top-rounded, body flush bottom */
.td-section-card .card-header,
.td-section-head{border-radius:5px 5px 0 0 !important}
.td-summary-card .td-summary-head{border-radius:5px 5px 0 0 !important}
.td-summary-card .td-trust-row{border-radius:0 0 5px 5px !important}

/* Pill-shaped buttons inside pill-shaped input wrappers */
.td-coupon-form button{
  border-radius:30px !important;
}

/* ===== Rich-text content (admin-authored HTML) ===== */
.td-rich{color:#374151;font-size:15.5px;line-height:1.75}
.td-rich p{margin:0 0 14px}
.td-rich p:last-child{margin-bottom:0}
.td-rich h2{
  font-size:22px;font-weight:800;color:#04107C;letter-spacing:-.3px;
  margin:30px 0 12px;padding-left:14px;position:relative;line-height:1.3;
}
.td-rich h2::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:4px;border-radius:3px;
  background:linear-gradient(180deg,#04107C 0%,#F59E0B 100%);
}
.td-rich h3{font-size:18px;font-weight:800;color:#04107C;margin:24px 0 10px;letter-spacing:-.2px}
.td-rich h4{font-size:16px;font-weight:700;color:#04107C;margin:20px 0 8px}
.td-rich ul, .td-rich ol{margin:0 0 16px;padding-left:0;list-style:none}
.td-rich ul li, .td-rich ol li{
  position:relative;padding:4px 0 4px 28px;color:#374151;font-size:15px;line-height:1.65;
}
.td-rich ul li::before{
  content:"\F26E";font-family:"bootstrap-icons";
  position:absolute;left:0;top:6px;width:18px;height:18px;border-radius:50%;
  background:#fef3c7;color:#d97706;font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.td-rich ol{counter-reset:td-ol}
.td-rich ol li{counter-increment:td-ol}
.td-rich ol li::before{
  content:counter(td-ol);position:absolute;left:0;top:5px;width:20px;height:20px;border-radius:50%;
  background:#04107C;color:#fff;font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.td-rich strong, .td-rich b{color:#04107C;font-weight:700}
.td-rich em, .td-rich i{font-style:italic;color:#64748b}
.td-rich a{color:#04107C;font-weight:600;text-decoration:underline;text-decoration-color:rgba(245,158,11,.55);text-underline-offset:3px}
.td-rich a:hover{color:#F59E0B}
.td-rich code{background:#eef2ff;color:#04107C;padding:2px 7px;border-radius:5px;font-size:13px;font-weight:600}
.td-rich pre{background:#0f172a;color:#e2e8f0;padding:14px 16px;border-radius:8px;overflow-x:auto;font-size:13px;line-height:1.6;margin:12px 0 18px}
.td-rich pre code{background:transparent;color:inherit;padding:0;font-size:inherit}
.td-rich blockquote{
  margin:14px 0;padding:12px 16px;border-left:4px solid #F59E0B;background:#fffbeb;color:#92400e;
  border-radius:0 8px 8px 0;font-style:italic;
}
.td-rich table{width:100%;border-collapse:collapse;margin:14px 0;font-size:14px}
.td-rich th, .td-rich td{padding:10px 12px;border:1px solid #e5e7eb;text-align:left}
.td-rich th{background:linear-gradient(135deg,#04107C 0%,#1e2a8a 100%);color:#fff;font-weight:700}
.td-rich tr:nth-child(even) td{background:#f8fafc}
.td-rich img{max-width:100%;height:auto;border-radius:8px;margin:10px 0}
.td-rich hr{border:0;border-top:1px solid #e5e7eb;margin:24px 0}

/* ===== Brand Pagination ===== */
.td-pagination{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  margin:48px 0 8px;
}
.td-pages{
  list-style:none;padding:0;margin:0;
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;border:1px solid #e5e7eb;border-radius:14px;
  padding:6px;box-shadow:0 6px 20px -10px rgba(4,16,124,.18);
}
.td-page{display:inline-flex}
.td-page > a,
.td-page > span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;
  font-weight:600;font-size:14px;color:#04107C;
  background:transparent;border-radius:9px;
  text-decoration:none;border:0;cursor:pointer;
  transition:all .18s ease;
  letter-spacing:.2px;
}
.td-page > a:hover{
  background:#eef2ff;color:#04107C;transform:translateY(-1px);
}
.td-page.is-active > span{
  background:linear-gradient(135deg,#04107C 0%,#1e2a8a 100%);
  color:#fff;box-shadow:0 6px 16px -6px rgba(4,16,124,.55);
}
.td-page.is-disabled > span{
  color:#cbd5e1;cursor:not-allowed;background:transparent;
}
.td-page.td-page-dots > span{
  color:#94a3b8;min-width:24px;padding:0 4px;
  letter-spacing:2px;
}
.td-page i{font-size:15px;line-height:1}

/* Amber accent on prev/next arrows on hover */
.td-page:first-child > a:hover,
.td-page:last-child > a:hover{
  background:#fef3c7;color:#92400e;
}

.td-pagination-info{
  font-size:13px;color:#64748b;letter-spacing:.2px;
}
.td-pagination-info strong{color:#04107C;font-weight:700}

@media (max-width:575.98px){
  .td-pages{padding:4px;gap:3px}
  .td-page > a,
  .td-page > span{min-width:38px;height:38px;padding:0 10px;font-size:13px}
  .td-pagination-info{font-size:12px;text-align:center}
}
