/* ═══════════════════════════════════════════════════════════
   TechSutra Components - Reusable UI
   Requires: design-system.css
   ═══════════════════════════════════════════════════════════ */

/* ── RESET ────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-1);
  overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;
  transition:background var(--ease-base),color var(--ease-base)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:var(--font-body);cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ── LAYOUT UTILITIES ─────────────────────────────────────── */
.w{max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-10)}
.hr{height:1px;background:linear-gradient(90deg,transparent,var(--b1),transparent);margin:0 var(--sp-10)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── SCROLL REVEAL ────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.4s}

/* ── ACCENT BAR ───────────────────────────────────────────── */
.abar{position:fixed;top:0;left:0;width:100%;height:var(--abar-h);
  background:linear-gradient(90deg,var(--rn),var(--gold),var(--vk));z-index:1001}

/* ── NAV ──────────────────────────────────────────────────── */
.site-nav{position:fixed;top:var(--abar-h);left:0;width:100%;z-index:1000;
  transition:background var(--ease-base),backdrop-filter var(--ease-base)}
.site-nav.scrolled{background:var(--bg-glass);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--b0)}
[data-theme="light"] .site-nav.scrolled{background:rgba(255,255,255,.96)}

.nav-inner{max-width:calc(var(--max-w) + 4rem);margin:0 auto;
  padding:0 var(--sp-10);height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-8)}

/* Logo mark */
.nav-logo{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.nav-mark{width:36px;height:36px;position:relative;flex-shrink:0}
.nav-mark img{width:100%;height:100%;object-fit:contain;opacity:0;
  position:absolute;inset:0;transition:opacity .4s}
.nav-mark img.loaded{opacity:1}
.nav-fb{position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;font-family:var(--font-display);font-weight:700;
  font-size:1rem;color:var(--gold);transition:opacity .4s}
.nav-mark.hi .nav-fb{opacity:0;pointer-events:none}
.nav-brand{font-family:var(--font-display);font-size:1.1rem;font-weight:600;letter-spacing:.01em}
/* Gold logo loses contrast on white bg — darken + shadow for definition */
[data-theme="light"] .nav-mark img.loaded{
  filter:brightness(.68) saturate(1.15) drop-shadow(0 1px 3px rgba(0,0,0,.18))
}

/* Links */
.nav-links{display:flex;align-items:center;gap:var(--sp-8)}
.nav-links a{font-size:var(--text-sm);font-weight:500;color:var(--text-2);
  transition:color var(--ease-base);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;
  height:1px;background:var(--gold);transition:width var(--ease-base)}
.nav-links a:hover{color:var(--text-1)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--text-1)}
.nav-links a.active::after{width:100%}

/* End actions */
.nav-end{display:flex;align-items:center;gap:.75rem;flex-shrink:0}

/* Mobile contact icon — shown at ≤768px in place of the hidden text button */
.nav-contact-icon{
  display:none;align-items:center;justify-content:center;
  min-width:44px;min-height:44px;flex-shrink:0;
  border-radius:var(--radius-md);border:1px solid var(--gold-g);
  background:var(--gold-d);color:var(--gold);cursor:pointer;
  transition:background var(--ease-base),color var(--ease-base),border-color var(--ease-base)
}
.nav-contact-icon:hover,.nav-contact-icon:focus-visible{
  background:var(--gold);color:var(--bg);border-color:var(--gold);
  outline:2px solid var(--gold);outline-offset:2px
}
@media(max-width:768px){.nav-contact-icon{display:flex}}

/* Hamburger */
/* C-03: min 44×44px tap target */
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;cursor:pointer;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.hamburger span{display:block;width:22px;height:2px;background:var(--text-1);
  border-radius:2px;transition:all var(--ease-base)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
@keyframes navSlideIn{from{transform:translateY(-110%)}to{transform:translateY(0)}}
@media(max-width:768px){
  /* Reduce nav-inner padding and gap; hide CTA (hamburger provides navigation) */
  .nav-inner{padding:0 var(--sp-6);gap:var(--sp-4)}
  .nav-end .btn{display:none}
  /* C-02 / defensive: display:none ensures links are hidden even if position:fixed
     misbehaves in some mobile browsers; animation restores the slide-in on open */
  .nav-links{display:none;position:fixed;top:calc(var(--nav-h) + var(--abar-h));left:0;width:100%;
    background:rgba(6,9,26,.97);backdrop-filter:blur(20px);
    border-bottom:1px solid var(--b0);flex-direction:column;align-items:flex-start;
    padding:1.25rem var(--sp-8);gap:0;transform:translateY(0);
    max-height:calc(100vh - var(--nav-h) - var(--abar-h));overflow-y:auto}
  [data-theme="light"] .nav-links{background:rgba(255,255,255,.98);
    border-bottom-color:rgba(12,17,32,.16)}
  .nav-links.open{display:flex;animation:navSlideIn 400ms ease}
  .nav-links a{display:block;padding:.8rem 0;font-size:.95rem;
    border-bottom:1px solid var(--b0);width:100%}
  .hamburger{display:flex}
}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.56rem 1.2rem;border-radius:var(--radius-md);font-size:var(--text-sm);
  font-weight:600;transition:all var(--ease-base);cursor:pointer;border:1px solid transparent}

.btn-gold{background:var(--gold-d);color:var(--gold-l);border-color:var(--gold-g)}
.btn-gold:hover{background:var(--gold);color:var(--bg);box-shadow:var(--shadow-gold)}

.btn-rn{background:var(--rn-d);color:var(--rn-l);border-color:var(--rn-b)}
.btn-rn:hover{background:var(--rn);color:#fff;box-shadow:var(--shadow-rn)}

.btn-vk{background:var(--vk-d);color:var(--vk-l);border-color:var(--vk-b)}
.btn-vk:hover{background:var(--vk);color:var(--bg);box-shadow:var(--shadow-vk)}

.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--b1)}
.btn-ghost:hover{background:var(--b0);color:var(--text-1)}

.btn-sm{padding:.38rem .85rem;font-size:var(--text-xs)}
.btn-lg{padding:.75rem 1.75rem;font-size:var(--text-md)}

/* ── TAGS / BADGES ────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;gap:.4rem;padding:.24rem .8rem;
  border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;border:1px solid}
.tag-gold{background:var(--gold-d);color:var(--gold);border-color:var(--gold-g)}
.tag-rn{background:var(--rn-d);color:var(--rn);border-color:var(--rn-b)}
.tag-vk{background:var(--vk-d);color:var(--vk);border-color:var(--vk-b)}

/* Tag dot for "live" indicators */
.tag-dot{width:6px;height:6px;border-radius:50%;background:currentColor;
  animation:tag-pulse 2s ease-in-out infinite}
@keyframes tag-pulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.6);opacity:1}}

/* ── CARDS ────────────────────────────────────────────────── */
.card{background:var(--bg-c);border:1px solid var(--b1);border-radius:var(--radius-xl)}
.card-hover{transition:transform var(--ease-base),border-color var(--ease-base),box-shadow var(--ease-base)}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}

/* ── TABS ─────────────────────────────────────────────────── */
.tabs{display:flex;flex-direction:column}
.tabs__list{display:flex;gap:0;border-bottom:1px solid var(--b1);overflow-x:auto;
  scrollbar-width:none}
.tabs__list::-webkit-scrollbar{display:none}
.tabs__tab{flex-shrink:0;padding:.75rem 1.5rem;font-size:var(--text-sm);font-weight:600;
  color:var(--text-3);cursor:pointer;border:none;background:none;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color var(--ease-base),border-color var(--ease-base)}
.tabs__tab:hover{color:var(--text-2)}
.tabs__tab--active{color:var(--text-1)}
.tabs__tab--rn.tabs__tab--active{border-color:var(--rn);color:var(--rn-l)}
.tabs__tab--vk.tabs__tab--active{border-color:var(--vk);color:var(--vk-l)}
.tabs__tab--gold.tabs__tab--active{border-color:var(--gold);color:var(--gold-l)}
.tabs__panel{padding:var(--sp-8) 0}
.tabs__panel[hidden]{display:none}

/* ── MODALS ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(6,9,26,.9);
  backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;
  justify-content:center;padding:var(--sp-8);
  opacity:0;pointer-events:none;transition:opacity var(--ease-base)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg-c);border:1px solid var(--b1);border-radius:var(--radius-xl);
  padding:0;max-width:640px;width:100%;max-height:85vh;overflow-y:auto;
  box-shadow:0 24px 60px rgba(0,0,0,.7);
  transform:translateY(-14px) scale(.98);transition:transform .3s;
  scrollbar-width:thin;scrollbar-color:var(--b1) transparent}
.modal-overlay.open .modal{transform:none}
.modal__header{display:flex;justify-content:space-between;align-items:center;
  padding:var(--sp-8) var(--sp-10) var(--sp-5);border-bottom:1px solid var(--b1)}
.modal__title{font-family:var(--font-display);font-size:1.5rem;font-weight:600}
/* C-06: 44×44px tap target */
.modal__close{width:44px;height:44px;background:var(--bg-s);border:1px solid var(--b1);
  border-radius:var(--radius-md);color:var(--text-2);display:flex;align-items:center;
  justify-content:center;cursor:pointer;transition:all var(--ease-base)}
.modal__close:hover{background:var(--b1);color:var(--text-1)}
.modal__body{padding:var(--sp-6) var(--sp-10) var(--sp-10)}
.modal__body h4{font-size:var(--text-base);font-weight:600;color:var(--text-1);margin:1.2rem 0 .4rem}
.modal__body p,.modal__body ul{font-size:var(--text-base);color:var(--text-2);line-height:1.7;margin-bottom:.55rem}
.modal__body ul{padding-left:1.2rem}.modal__body li{margin-bottom:.3rem;color:var(--text-2)}
.modal__body a{color:var(--gold)}

/* ── CONTACT LINE (shared footer contact text) ────────────── */
.contact-line{font-size:var(--text-sm);color:var(--text-2);margin-bottom:.3rem;overflow-wrap:break-word}

/* ── MODAL ACTION BUTTON (gold text link style) ───────────── */
.modal-action-btn{font-size:var(--text-sm);color:var(--gold);font-weight:500;
  cursor:pointer;background:none;border:none;font-family:var(--font-body)}

/* ── THEME TOGGLE ─────────────────────────────────────────── */
/* X-08: min 44×44px tap target */
.theme-btn{min-width:44px;min-height:44px;background:var(--gold-d);border:1px solid var(--gold-g);
  border-radius:var(--radius-md);color:var(--gold);font-size:1rem;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all var(--ease-base);flex-shrink:0}
.theme-btn:hover{background:var(--gold);color:var(--bg)}

/* ── LANGUAGE SWITCH ──────────────────────────────────────── */
.lang-switch{display:inline-flex;align-items:center;background:var(--gold-d);
  border:1px solid var(--gold-g);border-radius:var(--radius-md);overflow:hidden;
  flex-shrink:0;height:44px}
.lang-switch button{background:transparent;border:0;color:var(--gold);
  font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;
  padding:0 .65rem;height:100%;cursor:pointer;font-family:inherit;
  transition:background var(--ease-base),color var(--ease-base);min-width:44px}
.lang-switch button + button{border-left:1px solid var(--gold-g)}
.lang-switch button:hover{background:rgba(212,175,55,.18)}
.lang-switch button.lang-switch--active{background:var(--gold);color:var(--bg)}
.lang-switch button.lang-switch--active:hover{background:var(--gold)}
.lang-switch .lang-switch-hi{font-family:var(--font-hindi),inherit}

/* ── FOOTER ───────────────────────────────────────────────── */
.site-footer{background:var(--bg-s);border-top:1px solid var(--b0);padding:var(--sp-12) var(--sp-10) var(--sp-8)}
.footer-grid{max-width:var(--max-w);margin:0 auto;
  display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:var(--sp-12);margin-bottom:var(--sp-10)}
.footer-brand{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin-bottom:.38rem}
.footer-tagline{font-size:var(--text-base);color:var(--text-3);max-width:240px;line-height:1.6;margin-bottom:var(--sp-4)}
.footer-email{font-size:var(--text-sm);color:var(--gold);display:inline-flex;align-items:center;
  gap:.3rem;transition:opacity var(--ease-base)}
.footer-email:hover{opacity:.72}
.footer-col-title{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:var(--sp-4)}
.footer-links{display:flex;flex-direction:column;gap:.55rem}
/* C-10: min ~44px effective tap height via vertical padding */
.footer-links a,.footer-links button{font-size:var(--text-sm);color:var(--text-2);transition:color var(--ease-base);
  text-align:left;background:none;border:none;padding:.55rem 0;cursor:pointer;font-family:var(--font-body)}
.footer-links a:hover,.footer-links button:hover{color:var(--text-1)}
.footer-links .dim{color:var(--text-3);cursor:default}
.footer-bottom{max-width:var(--max-w);margin:0 auto;padding-top:var(--sp-8);
  border-top:1px solid var(--b0);display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:.75rem}
.footer-copy{font-size:var(--text-xs);color:var(--text-3);margin:0}

/* ── LOADER ───────────────────────────────────────────────── */
.loader{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);z-index:9999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.5rem;transition:opacity .5s}
.loader.gone{opacity:0;pointer-events:none}
.loader-ring{width:48px;height:48px;border-radius:50%;
  border:3px solid var(--bg-c);border-top-color:var(--gold);
  animation:loader-spin .9s linear infinite}
.loader-name{font-family:var(--font-display);font-size:var(--text-base);color:var(--gold);
  letter-spacing:.14em;text-transform:uppercase;animation:loader-pulse 1.6s ease-in-out infinite}
@keyframes loader-spin{to{transform:rotate(360deg)}}
@keyframes loader-pulse{0%,100%{opacity:.35}50%{opacity:1}}

/* ── RESPONSIVE FOOTER ────────────────────────────────────── */
@media(max-width:768px){
  .site-footer{padding:var(--sp-10) var(--sp-6) var(--sp-6)}
  .footer-grid{grid-template-columns:1fr;gap:var(--sp-8);margin-bottom:var(--sp-8)}
  .footer-bottom{flex-direction:column;text-align:center}
  .w{padding:0 var(--sp-6)}
}
@media(max-width:480px){
  html{font-size:15px}
  .w{padding:0 var(--sp-5)}
  /* C-04: btn-sm tap height and font-size floor at 480px */
  .btn-sm{padding:.55rem 1rem;font-size:.8125rem}
}

/* ── SKIP LINK (WCAG-AA) ──────────────────────────────────── */
.skip-link{
  position:absolute;
  top:-40px;
  left:0;
  background:var(--gold);
  color:#0b0d12;
  padding:.6rem 1rem;
  border-radius:0 0 6px 0;
  font-weight:700;
  z-index:9999;
  text-decoration:none;
  transition:top .15s ease;
}
.skip-link:focus{ top:0; outline:2px solid var(--text-1); outline-offset:2px; }

/* ── C-05: Tab bar scroll affordance (right-fade gradient) ─── */
.tabs__list-wrap{position:relative}
.tabs__list-wrap::after{
  content:'';
  position:absolute;right:0;top:0;bottom:0;width:40px;
  background:linear-gradient(to right,transparent,var(--bg));
  pointer-events:none
}

/* ── C-07: Sticky modal header — modal has no top padding so top:0 has no gap ── */
.modal__header{
  position:sticky;
  top:0;
  background:var(--bg-c);
  z-index:1
}
/* Contact modal: direct children (no .modal__body wrapper) get side + vertical spacing */
.modal > .modal-contact-block{margin:var(--sp-6) var(--sp-10) var(--sp-4)}
.modal > .modal-vk-inquiry-note{
  padding:0 var(--sp-10) var(--sp-5);
  font-size:var(--text-sm);color:var(--text-2);line-height:1.6
}
.modal > .modal-contact-links{padding:0 var(--sp-10) var(--sp-8)}

/* ── C-09: Narrow modal gutters on small phones ────────────── */
@media(max-width:480px){
  .modal__header{padding:var(--sp-6) var(--sp-5) var(--sp-4)}
  .modal__body{padding:var(--sp-5) var(--sp-5) var(--sp-8)}
  .modal > .modal-contact-block{margin:var(--sp-5) var(--sp-5) var(--sp-4)}
  .modal > .modal-vk-inquiry-note{padding:0 var(--sp-5) var(--sp-4)}
  .modal > .modal-contact-links{padding:0 var(--sp-5) var(--sp-6)}
}

/* ── C-01: Narrower gutter at 360px ──────────────────────── */
@media(max-width:360px){
  .w{padding:0 var(--sp-4)}
  .site-footer{padding-left:var(--sp-4);padding-right:var(--sp-4)}
}

/* ── C-08: Reduce footer vertical padding below 480px ─────── */
@media(max-width:480px){
  .site-footer{padding-top:var(--sp-8)}
}

/* ── C-11: Further reduce nav inner padding on small phones ── */
@media(max-width:480px){
  .nav-inner{padding:0 var(--sp-4)}
}

/* ── X-02 / C-14 / MO-03: Global reduced-motion guard ─────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important
  }
}
