/* ============================================
   VMS Portal - Main Stylesheet
   ============================================ */

/* ============================================
   Font Face Declarations
   ============================================ */

/* Prompt Thin Local (project-wide default) */
@font-face {
  font-family: 'Prompt Thin Local';
  src: url('../fonts/Prompt-Thin.woff2') format('woff2');
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

/* Anton Font (H1/Main Heading) */
@font-face {
  font-family: 'Anton';
  src: url('../fonts/Anton-Regular.woff2') format('woff2'),
       url('../fonts/Anton-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Belgrano Font (H2/Table Headings) */
@font-face {
  font-family: 'Belgrano';
  src: url('../fonts/Belgrano-Regular.woff2') format('woff2'),
       url('../fonts/Belgrano-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Inter Regular Font */
@font-face {
  font-family: 'Inter';
  src: url('../fonts/Inter-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Local Material Symbols fallback for any cached/legacy icon spans. */
@font-face {
  font-family: 'Material Symbols Outlined';
  src: url('../fonts/MaterialSymbolsOutlined-Variable.woff2') format('woff2'),
       url('../fonts/MaterialSymbolsOutlined-Variable.ttf') format('truetype');
  font-style: normal;
  font-weight: 100 700;
  font-display: block;
}

/* Prompt Font Family (p/field details) - Thin */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Thin.woff2') format('woff2'),
       url('../fonts/Prompt-Thin.woff') format('woff');
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-ThinItalic.woff2') format('woff2'),
       url('../fonts/Prompt-ThinItalic.woff') format('woff');
  font-weight: 100;
  font-style: italic;
  font-display: swap;
}

/* Prompt - ExtraLight */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-ExtraLight.woff2') format('woff2'),
       url('../fonts/Prompt-ExtraLight.woff') format('woff');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-ExtraLightItalic.woff2') format('woff2'),
       url('../fonts/Prompt-ExtraLightItalic.woff') format('woff');
  font-weight: 200;
  font-style: italic;
  font-display: swap;
}

/* Prompt - Light */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Light.woff2') format('woff2'),
       url('../fonts/Prompt-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-LightItalic.woff2') format('woff2'),
       url('../fonts/Prompt-LightItalic.woff') format('woff');
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

/* Prompt - Regular */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Regular.woff2') format('woff2'),
       url('../fonts/Prompt-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Italic.woff2') format('woff2'),
       url('../fonts/Prompt-Italic.woff') format('woff');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

/* Prompt - Medium */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Medium.woff2') format('woff2'),
       url('../fonts/Prompt-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-MediumItalic.woff2') format('woff2'),
       url('../fonts/Prompt-MediumItalic.woff') format('woff');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

/* Prompt - SemiBold */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-SemiBold.woff2') format('woff2'),
       url('../fonts/Prompt-SemiBold.woff') format('woff');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-SemiBoldItalic.woff2') format('woff2'),
       url('../fonts/Prompt-SemiBoldItalic.woff') format('woff');
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

/* Prompt - Bold */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Bold.woff2') format('woff2'),
       url('../fonts/Prompt-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-BoldItalic.woff2') format('woff2'),
       url('../fonts/Prompt-BoldItalic.woff') format('woff');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

/* Prompt - ExtraBold */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-ExtraBold.woff2') format('woff2'),
       url('../fonts/Prompt-ExtraBold.woff') format('woff');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-ExtraBoldItalic.woff2') format('woff2'),
       url('../fonts/Prompt-ExtraBoldItalic.woff') format('woff');
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}

/* Prompt - Black */
@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-Black.woff2') format('woff2'),
       url('../fonts/Prompt-Black.woff') format('woff');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prompt';
  src: url('../fonts/Prompt-BlackItalic.woff2') format('woff2'),
       url('../fonts/Prompt-BlackItalic.woff') format('woff');
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}


/* ============================================
   CSS Variables (Design Tokens)
   ============================================ */

:root {
  /* Color Tokens */
  --primary: #1414b8;            /* brand color */
  --muted: #6b7280;              /* helper text */
  --surface: #ffffff;            /* form fields */
  --field-border: #e6e7ee;       /* consistent border for inputs */
  --accent-invalid: #d97706;     /* amber/orange for validation (non-red) */
  --shadow-plate: 0 8px 20px rgba(8,9,31,0.06);
  
  /* Border Radius */
  --radius: 0.5rem;
  
  /* Animation Timings */
  --anim-fast: 180ms cubic-bezier(.2,.9,.2,1);
  --anim-medium: 320ms cubic-bezier(.2,.9,.2,1);
}


/* ============================================
   Base Styles
   ============================================ */

body {
  font-family: 'Inter', sans-serif;
}

/* Legacy Material Symbols utility, backed by local font files. */
.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 20px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  font-feature-settings: 'liga';
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
  font-optical-sizing: auto;
  speak: none;
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  vertical-align: middle;
}

/* Local SVG icon utility */
.local-icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  min-width: 1em;
  overflow: hidden;
  text-indent: -9999px;
  background-color: currentColor;
  vertical-align: middle;
  -webkit-mask: var(--icon-url) center / contain no-repeat;
  mask: var(--icon-url) center / contain no-repeat;
}

.local-icon-img {
  display: inline-block;
  width: 1em;
  height: 1em;
  min-width: 1em;
  object-fit: contain;
  vertical-align: middle;
}

.icon-account_circle { --icon-url: url('../icons/account_circle.svg'); }
.icon-add { --icon-url: url('../icons/add.svg'); }
.icon-add_box { --icon-url: url('../icons/add_box.svg'); }
.icon-add_circle { --icon-url: url('../icons/add_circle.svg'); }
.icon-arrow_back { --icon-url: url('../icons/arrow_back.svg'); }
.icon-badge { --icon-url: url('../icons/badge.svg'); }
.icon-check { --icon-url: url('../icons/check.svg'); }
.icon-check_circle { --icon-url: url('../icons/check_circle.svg'); }
.icon-close { --icon-url: url('../icons/close.svg'); }
.icon-delete { --icon-url: url('../icons/delete.svg'); }
.icon-description { --icon-url: url('../icons/description.svg'); }
.icon-download { --icon-url: url('../icons/download.svg'); }
.icon-edit { --icon-url: url('../icons/edit.svg'); }
.icon-edit_document { --icon-url: url('../icons/edit_document.svg'); }
.icon-error { --icon-url: url('../icons/error.svg'); }
.icon-expand_more { --icon-url: url('../icons/expand_more.svg'); }
.icon-fact_check { --icon-url: url('../icons/fact_check.svg'); }
.icon-gavel { --icon-url: url('../icons/gavel.svg'); }
.icon-home { --icon-url: url('../icons/home.svg'); }
.icon-how_to_reg { --icon-url: url('../icons/how_to_reg.svg'); }
.icon-info { --icon-url: url('../icons/info.svg'); }
.icon-lock_reset { --icon-url: url('../icons/lock_reset.svg'); }
.icon-login { --icon-url: url('../icons/login.svg'); }
.icon-logout { --icon-url: url('../icons/logout.svg'); }
.icon-mark_email_read { --icon-url: url('../icons/mark_email_read.svg'); }
.icon-menu { --icon-url: url('../icons/menu.svg'); }
.icon-pending_actions { --icon-url: url('../icons/pending_actions.svg'); }
.icon-person { --icon-url: url('../icons/person.svg'); }
.icon-person_add { --icon-url: url('../icons/person_add.svg'); }
.icon-person_off { --icon-url: url('../icons/person_off.svg'); }
.icon-print { --icon-url: url('../icons/print.svg'); }
.icon-save { --icon-url: url('../icons/save.svg'); }
.icon-search { --icon-url: url('../icons/search.svg'); }
.icon-task_alt { --icon-url: url('../icons/task_alt.svg'); }
.icon-track_changes { --icon-url: url('../icons/track_changes.svg'); }
.icon-verified { --icon-url: url('../icons/verified.svg'); }
.icon-verified_user { --icon-url: url('../icons/verified_user.svg'); }
.icon-visibility { --icon-url: url('../icons/visibility.svg'); }
.icon-warning { --icon-url: url('../icons/warning.svg'); }


/* ============================================
   Typography Classes
   ============================================ */

/* H1 - Main Heading (Anton) */
.heading-anton,
h1.heading-anton {
  font-family: sans-serif;
  font-weight: 800;
}

/* H2 - Table/Section Headings (Belgrano) */
.heading-belgrano,
h2.heading-belgrano {
  font-family: sans-serif;
  font-weight: 700;
}

/* Legacy class name for compatibility (using Anton based on your previous naming) */
.heading-montserrat {
  font-family: sans-serif;
  font-weight: 800;
}

/* Paragraphs and field details use Inter (default body font) */
p, .text-prompt {
  font-family: 'Inter', sans-serif;
}


/* ============================================
   Background & Layout
   ============================================ */

/* Optional decorative background image */
body.with-bg::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: url('../images/bd-shape.svg');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  opacity: 0.16;
  mix-blend-mode: normal;
  z-index: 0;
  transition: opacity var(--anim-medium);
}

/* Layout safe area so content sits above optional background */
.layout-container,
.layout-content-container {
  position: relative;
  z-index: 1;
}

/* Make sure colored sections keep their original Tailwind appearance but add subtle animations */
header,
footer {
  transition: background-color var(--anim-fast), box-shadow var(--anim-fast);
}


/* ============================================
   Animations
   ============================================ */

/* Form wrapper micro-entrance and gentle shadow */
.layout-content-container {
  animation: contentFadeUp 420ms var(--anim-fast);
  will-change: transform, opacity;
}

@keyframes contentFadeUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes invalidPulse {
  0% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
  100% { transform: translateY(0); }
}

@keyframes invalidShake {
  0% { transform: translateX(0); }
  25% { transform: translateX(-6px); }
  50% { transform: translateX(6px); }
  75% { transform: translateX(-4px); }
  100% { transform: translateX(0); }
}

.animate-invalid-shake {
  animation: invalidShake 600ms ease;
  box-shadow: 0 8px 20px rgba(217,124,14,0.06) !important;
}


/* ============================================
   Form Elements Styling
   ============================================ */

input[type="text"],
input[type="date"],
input[type="datetime-local"],
input[type="search"],
input[type="tel"],
input[type="email"],
textarea,
select {
  border: 1px solid var(--field-border) !important;
  background: var(--surface) !important;
  border-radius: 0.5rem !important;
  transition: box-shadow var(--anim-fast), border-color var(--anim-fast), transform var(--anim-fast);
  box-shadow: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* Larger hit area and consistent height */
input[type="text"],
input[type="date"],
input[type="datetime-local"],
input[type="search"],
input[type="tel"],
input[type="email"],
select {
  height: 44px;
  padding-left: 1rem;
  padding-right: 1rem;
}

textarea {
  padding: 0.9rem;
  min-height: 108px;
  resize: vertical;
}

/* Focus - friendly ring that matches brand */
input:focus,
textarea:focus,
select:focus {
  border-color: rgba(20,20,184,0.95) !important;
  box-shadow: 0 6px 18px rgba(20,20,184,0.06), 0 0 0 4px rgba(20,20,184,0.08);
  transform: translateY(-1px);
}

/* Invalid inputs - amber highlight (not red) */
input:invalid:not(:focus),
textarea:invalid:not(:focus),
select:invalid:not(:focus) {
  border-color: var(--accent-invalid) !important;
  box-shadow: 0 6px 18px rgba(217,124,14,0.06);
  animation: invalidPulse 600ms ease;
}


/* ============================================
   Radio & Checkbox Styling
   ============================================ */

/* Radio card visual improvements */
.radio-card {
  transition: transform var(--anim-fast), background-color var(--anim-fast), box-shadow var(--anim-fast);
}

.radio-card:hover {
  transform: translateX(4px);
}

.radio-card input[type="radio"] {
  accent-color: var(--primary);
}

/* When radio is checked */
.radio-card input[type="radio"]:checked + span {
  color: var(--primary);
  font-weight: 700;
}

.radio-card input[type="radio"]:checked {
  transform: translateX(0);
}


/* ============================================
   Button Styling
   ============================================ */

/* Button micro-animations */
.action-button {
  transition: transform var(--anim-fast), box-shadow var(--anim-fast), opacity var(--anim-fast);
}

.action-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(20,20,184,0.14);
}

.action-button:active {
  transform: translateY(-1px);
}

/* Header icon buttons */
header button,
header .size-8 {
  transition: transform var(--anim-fast), box-shadow var(--anim-fast), background-color var(--anim-fast);
}

header button:hover {
  transform: translateY(-2px);
}


/* ============================================
   Utility Classes
   ============================================ */

/* Small helper text style */
.help-text {
  color: var(--muted);
  font-size: 0.85rem;
}

/* Footer and validation notice styling */
.validation-note {
  transition: transform var(--anim-fast), background var(--anim-fast);
}

.validation-note:hover {
  transform: translateY(-3px);
}

/* Subtle section emphasis on focus-within for accessibility */
.layout-content-container fieldset:focus-within {
  border-color: rgba(20,20,184,0.9);
  box-shadow: 0 10px 30px rgba(20,20,184,0.04);
}


/* ============================================
   Responsive Design
   ============================================ */

/* Responsive tweak: ensure custom radius + shadows look good on small screens */
@media (max-width: 640px) {
  .layout-content-container {
    border-radius: 10px;
    margin: 0.6rem;
  }
  
  header {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}


/* ============================================
   Footer Styling
   ============================================ */

footer {
  font-size: 0.8125rem;
}
