/* ============================================================
   IRALENOV — css/style.css
   Prebuilt Tailwind v4.1.5 output — Swiss Brutalist / Dark
   K_FAMILY=0 | K_FONT=4 | K_HUE=7 | K_BG=2 | K_SAT=0
   ============================================================ */

/* 1. @theme — design tokens */
@theme {
  --color-bg-primary:    #0C0C0A;
  --color-bg-secondary:  #181815;
  --color-ink-primary:   #F0EDE8;
  --color-accent:        #9CA097;
  --color-ink-muted:     #6B6B66;
  --color-border-hard:   #F0EDE8;
  --color-border-soft:   #2E2E2B;
  --font-display: 'Archivo Black', 'Arial Black', sans-serif;
  --font-body:    'Archivo', 'Arial', sans-serif;
  --shadow-brutal-sm:  4px 4px 0 #9CA097;
  --shadow-brutal-md:  6px 6px 0 #9CA097;
  --shadow-brutal-lg:  8px 8px 0 #F0EDE8;
  --shadow-brutal-acc: 4px 4px 0 #F0EDE8;
  --radius-none: 0px;
  --spacing-section: 6rem;
}

/* 2. Base reset / @layer base */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  background-color: #0C0C0A;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  background-color: #0C0C0A;
  color: #F0EDE8;
  font-family: 'Archivo', 'Arial', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Archivo Black', 'Arial Black', sans-serif;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #F0EDE8;
}

a { color: inherit; text-decoration: none; transition: color 0.15s ease; }
a:hover { color: #9CA097; }

img { display: block; max-width: 100%; height: auto; }

address { font-style: normal; }

/* Marquee base */
.marquee-track {
  display: flex;
  gap: 3rem;
  animation: marquee-scroll 28s linear infinite;
  white-space: nowrap;
}
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Accordion hidden state */
.accordion-body { overflow: hidden; transition: max-height 0.3s ease, padding 0.3s ease; }

/* ============================================================
   3. LAYOUT UTILITIES
   ============================================================ */
.flex                { display: flex; }
.inline-flex         { display: inline-flex; }
.grid                { display: grid; }
.block               { display: block; }
.inline-block        { display: inline-block; }
.hidden              { display: none; }
.flex-col            { flex-direction: column; }
.flex-row            { flex-direction: row; }
.flex-wrap           { flex-wrap: wrap; }
.flex-1              { flex: 1 1 0%; }
.flex-none           { flex: none; }
.flex-shrink-0       { flex-shrink: 0; }
.items-start         { align-items: flex-start; }
.items-center        { align-items: center; }
.items-end           { align-items: flex-end; }
.items-stretch       { align-items: stretch; }
.justify-start       { justify-content: flex-start; }
.justify-center      { justify-content: center; }
.justify-end         { justify-content: flex-end; }
.justify-between     { justify-content: space-between; }
.justify-around      { justify-content: space-around; }
.self-start          { align-self: flex-start; }
.self-center         { align-self: center; }
.self-end            { align-self: flex-end; }
.self-stretch        { align-self: stretch; }
.grid-cols-1         { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2         { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3         { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4         { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.col-span-1          { grid-column: span 1 / span 1; }
.col-span-2          { grid-column: span 2 / span 2; }
.col-span-3          { grid-column: span 3 / span 3; }
.col-span-4          { grid-column: span 4 / span 4; }
.col-span-full       { grid-column: 1 / -1; }
.row-span-1          { grid-row: span 1 / span 1; }
.row-span-2          { grid-row: span 2 / span 2; }
.gap-0               { gap: 0; }
.gap-1               { gap: 0.25rem; }
.gap-2               { gap: 0.5rem; }
.gap-3               { gap: 0.75rem; }
.gap-4               { gap: 1rem; }
.gap-5               { gap: 1.25rem; }
.gap-6               { gap: 1.5rem; }
.gap-8               { gap: 2rem; }
.gap-10              { gap: 2.5rem; }
.gap-12              { gap: 3rem; }
.gap-16              { gap: 4rem; }
.gap-x-4             { column-gap: 1rem; }
.gap-x-6             { column-gap: 1.5rem; }
.gap-x-8             { column-gap: 2rem; }
.gap-y-4             { row-gap: 1rem; }
.gap-y-6             { row-gap: 1.5rem; }
.gap-y-8             { row-gap: 2rem; }
.gap-y-12            { row-gap: 3rem; }
.overflow-hidden     { overflow: hidden; }
.overflow-x-hidden   { overflow-x: hidden; }
.overflow-auto       { overflow: auto; }
.relative            { position: relative; }
.absolute            { position: absolute; }
.fixed               { position: fixed; }
.sticky              { position: sticky; }
.inset-0             { inset: 0; }
.inset-x-0           { left: 0; right: 0; }
.top-0               { top: 0; }
.top-4               { top: 1rem; }
.right-0             { right: 0; }
.right-4             { right: 1rem; }
.bottom-0            { bottom: 0; }
.bottom-4            { bottom: 1rem; }
.left-0              { left: 0; }
.left-4              { left: 1rem; }
.left-1\/2           { left: 50%; }
.z-0                 { z-index: 0; }
.z-10                { z-index: 10; }
.z-20                { z-index: 20; }
.z-30                { z-index: 30; }
.z-40                { z-index: 40; }
.z-50                { z-index: 50; }

/* ============================================================
   4. SIZING
   ============================================================ */
.w-full              { width: 100%; }
.w-auto              { width: auto; }
.w-fit               { width: fit-content; }
.w-screen            { width: 100vw; }
.w-4                 { width: 1rem; }
.w-6                 { width: 1.5rem; }
.w-8                 { width: 2rem; }
.w-10                { width: 2.5rem; }
.w-12                { width: 3rem; }
.w-16                { width: 4rem; }
.w-20                { width: 5rem; }
.w-24                { width: 6rem; }
.w-32                { width: 8rem; }
.w-48                { width: 12rem; }
.w-64                { width: 16rem; }
.h-full              { height: 100%; }
.h-auto              { height: auto; }
.h-screen            { height: 100vh; }
.h-4                 { height: 1rem; }
.h-6                 { height: 1.5rem; }
.h-8                 { height: 2rem; }
.h-10                { height: 2.5rem; }
.h-12                { height: 3rem; }
.h-14                { height: 3.5rem; }
.h-16                { height: 4rem; }
.h-20                { height: 5rem; }
.h-24                { height: 6rem; }
.h-32                { height: 8rem; }
.h-48                { height: 12rem; }
.h-64                { height: 16rem; }
.h-80                { height: 20rem; }
.h-96                { height: 24rem; }
.min-h-screen        { min-height: 100vh; }
.min-h-\[400px\]     { min-height: 400px; }
.min-h-\[500px\]     { min-height: 500px; }
.min-h-\[600px\]     { min-height: 600px; }
.min-h-\[300px\]     { min-height: 300px; }
.min-h-\[200px\]     { min-height: 200px; }
.max-w-xs            { max-width: 20rem; }
.max-w-sm            { max-width: 24rem; }
.max-w-md            { max-width: 28rem; }
.max-w-lg            { max-width: 32rem; }
.max-w-xl            { max-width: 36rem; }
.max-w-2xl           { max-width: 42rem; }
.max-w-3xl           { max-width: 48rem; }
.max-w-4xl           { max-width: 56rem; }
.max-w-5xl           { max-width: 64rem; }
.max-w-6xl           { max-width: 72rem; }
.max-w-7xl           { max-width: 80rem; }
.max-w-none          { max-width: none; }
.max-w-\[1220px\]    { max-width: 1220px; }
.min-w-0             { min-width: 0; }
.min-w-\[200px\]     { min-width: 200px; }
.aspect-square       { aspect-ratio: 1 / 1; }
.aspect-video        { aspect-ratio: 16 / 9; }
.aspect-\[16\/9\]    { aspect-ratio: 16 / 9; }
.aspect-\[21\/9\]    { aspect-ratio: 21 / 9; }
.aspect-\[4\/3\]     { aspect-ratio: 4 / 3; }
.aspect-\[3\/4\]     { aspect-ratio: 3 / 4; }
.object-cover        { object-fit: cover; }
.object-contain      { object-fit: contain; }
.object-center       { object-position: center; }
.object-top          { object-position: top; }

/* ============================================================
   5. SPACING
   ============================================================ */
.p-0      { padding: 0; }
.p-1      { padding: 0.25rem; }
.p-2      { padding: 0.5rem; }
.p-3      { padding: 0.75rem; }
.p-4      { padding: 1rem; }
.p-5      { padding: 1.25rem; }
.p-6      { padding: 1.5rem; }
.p-8      { padding: 2rem; }
.p-10     { padding: 2.5rem; }
.p-12     { padding: 3rem; }
.p-16     { padding: 4rem; }
.px-0     { padding-left: 0; padding-right: 0; }
.px-2     { padding-left: 0.5rem; padding-right: 0.5rem; }
.px-3     { padding-left: 0.75rem; padding-right: 0.75rem; }
.px-4     { padding-left: 1rem; padding-right: 1rem; }
.px-5     { padding-left: 1.25rem; padding-right: 1.25rem; }
.px-6     { padding-left: 1.5rem; padding-right: 1.5rem; }
.px-8     { padding-left: 2rem; padding-right: 2rem; }
.px-10    { padding-left: 2.5rem; padding-right: 2.5rem; }
.px-12    { padding-left: 3rem; padding-right: 3rem; }
.py-0     { padding-top: 0; padding-bottom: 0; }
.py-1     { padding-top: 0.25rem; padding-bottom: 0.25rem; }
.py-1\.5  { padding-top: 0.375rem; padding-bottom: 0.375rem; }
.py-2     { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.py-2\.5  { padding-top: 0.625rem; padding-bottom: 0.625rem; }
.py-3     { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.py-4     { padding-top: 1rem; padding-bottom: 1rem; }
.py-5     { padding-top: 1.25rem; padding-bottom: 1.25rem; }
.py-6     { padding-top: 1.5rem; padding-bottom: 1.5rem; }
.py-8     { padding-top: 2rem; padding-bottom: 2rem; }
.py-10    { padding-top: 2.5rem; padding-bottom: 2.5rem; }
.py-12    { padding-top: 3rem; padding-bottom: 3rem; }
.py-16    { padding-top: 4rem; padding-bottom: 4rem; }
.py-20    { padding-top: 5rem; padding-bottom: 5rem; }
.py-24    { padding-top: 6rem; padding-bottom: 6rem; }
.pt-0     { padding-top: 0; }
.pt-2     { padding-top: 0.5rem; }
.pt-3     { padding-top: 0.75rem; }
.pt-4     { padding-top: 1rem; }
.pt-6     { padding-top: 1.5rem; }
.pt-8     { padding-top: 2rem; }
.pt-10    { padding-top: 2.5rem; }
.pt-12    { padding-top: 3rem; }
.pb-0     { padding-bottom: 0; }
.pb-2     { padding-bottom: 0.5rem; }
.pb-3     { padding-bottom: 0.75rem; }
.pb-4     { padding-bottom: 1rem; }
.pb-6     { padding-bottom: 1.5rem; }
.pb-8     { padding-bottom: 2rem; }
.pb-12    { padding-bottom: 3rem; }
.pl-0     { padding-left: 0; }
.pl-4     { padding-left: 1rem; }
.pl-6     { padding-left: 1.5rem; }
.pr-4     { padding-right: 1rem; }
.m-0      { margin: 0; }
.m-auto   { margin: auto; }
.mx-auto  { margin-left: auto; margin-right: auto; }
.mx-2     { margin-left: 0.5rem; margin-right: 0.5rem; }
.mx-4     { margin-left: 1rem; margin-right: 1rem; }
.my-2     { margin-top: 0.5rem; margin-bottom: 0.5rem; }
.my-4     { margin-top: 1rem; margin-bottom: 1rem; }
.my-8     { margin-top: 2rem; margin-bottom: 2rem; }
.mt-0     { margin-top: 0; }
.mt-1     { margin-top: 0.25rem; }
.mt-2     { margin-top: 0.5rem; }
.mt-3     { margin-top: 0.75rem; }
.mt-4     { margin-top: 1rem; }
.mt-6     { margin-top: 1.5rem; }
.mt-8     { margin-top: 2rem; }
.mt-10    { margin-top: 2.5rem; }
.mt-12    { margin-top: 3rem; }
.mt-16    { margin-top: 4rem; }
.mt-20    { margin-top: 5rem; }
.mt-24    { margin-top: 6rem; }
.mb-0     { margin-bottom: 0; }
.mb-1     { margin-bottom: 0.25rem; }
.mb-2     { margin-bottom: 0.5rem; }
.mb-3     { margin-bottom: 0.75rem; }
.mb-4     { margin-bottom: 1rem; }
.mb-5     { margin-bottom: 1.25rem; }
.mb-6     { margin-bottom: 1.5rem; }
.mb-8     { margin-bottom: 2rem; }
.mb-10    { margin-bottom: 2.5rem; }
.mb-12    { margin-bottom: 3rem; }
.mb-16    { margin-bottom: 4rem; }
.ml-0     { margin-left: 0; }
.ml-2     { margin-left: 0.5rem; }
.ml-4     { margin-left: 1rem; }
.ml-auto  { margin-left: auto; }
.mr-2     { margin-right: 0.5rem; }
.mr-4     { margin-right: 1rem; }
.mr-auto  { margin-right: auto; }

/* ============================================================
   6. TYPOGRAPHY
   ============================================================ */
.font-display        { font-family: 'Archivo Black', 'Arial Black', sans-serif; }
.font-body           { font-family: 'Archivo', 'Arial', sans-serif; }
.font-mono           { font-family: 'Courier New', Courier, monospace; }
.font-normal         { font-weight: 400; }
.font-medium         { font-weight: 500; }
.font-semibold       { font-weight: 600; }
.font-bold           { font-weight: 700; }
.font-black          { font-weight: 900; }
.italic              { font-style: italic; }
.not-italic          { font-style: normal; }
.text-xs             { font-size: 0.75rem; line-height: 1rem; }
.text-sm             { font-size: 0.875rem; line-height: 1.25rem; }
.text-base           { font-size: 1rem; line-height: 1.5rem; }
.text-lg             { font-size: 1.125rem; line-height: 1.75rem; }
.text-xl             { font-size: 1.25rem; line-height: 1.75rem; }
.text-2xl            { font-size: 1.5rem; line-height: 2rem; }
.text-3xl            { font-size: 1.875rem; line-height: 2.25rem; }
.text-4xl            { font-size: 2.25rem; line-height: 2.5rem; }
.text-5xl            { font-size: 3rem; line-height: 1.1; }
.text-6xl            { font-size: 3.75rem; line-height: 1.05; }
.text-7xl            { font-size: 4.5rem; line-height: 1; }
.text-8xl            { font-size: 6rem; line-height: 1; }
.text-9xl            { font-size: 8rem; line-height: 1; }
.text-\[10px\]       { font-size: 10px; }
.text-\[11px\]       { font-size: 11px; }
.text-\[13px\]       { font-size: 13px; }
.text-\[15px\]       { font-size: 15px; }
.text-\[40px\]       { font-size: 40px; }
.text-\[52px\]       { font-size: 52px; }
.text-\[64px\]       { font-size: 64px; }
.text-\[72px\]       { font-size: 72px; }
.text-\[80px\]       { font-size: 80px; line-height: 0.95; }
.text-\[96px\]       { font-size: 96px; line-height: 0.9; }
.text-\[120px\]      { font-size: 120px; line-height: 0.9; }
.leading-none        { line-height: 1; }
.leading-tight       { line-height: 1.25; }
.leading-snug        { line-height: 1.375; }
.leading-normal      { line-height: 1.5; }
.leading-relaxed     { line-height: 1.625; }
.leading-loose       { line-height: 2; }
.leading-\[1\.05\]   { line-height: 1.05; }
.leading-\[1\.1\]    { line-height: 1.1; }
.leading-\[1\.15\]   { line-height: 1.15; }
.tracking-tighter    { letter-spacing: -0.05em; }
.tracking-tight      { letter-spacing: -0.025em; }
.tracking-normal     { letter-spacing: 0em; }
.tracking-wide       { letter-spacing: 0.025em; }
.tracking-wider      { letter-spacing: 0.05em; }
.tracking-widest     { letter-spacing: 0.1em; }
.tracking-\[0\.15em\]{ letter-spacing: 0.15em; }
.tracking-\[0\.2em\] { letter-spacing: 0.2em; }
.tracking-\[-0\.03em\] { letter-spacing: -0.03em; }
.tracking-\[-0\.04em\] { letter-spacing: -0.04em; }
.tracking-\[-0\.05em\] { letter-spacing: -0.05em; }
.text-left           { text-align: left; }
.text-center         { text-align: center; }
.text-right          { text-align: right; }
.uppercase           { text-transform: uppercase; }
.lowercase           { text-transform: lowercase; }
.normal-case         { text-transform: none; }
.underline           { text-decoration: underline; }
.no-underline        { text-decoration: none; }
.line-through        { text-decoration: line-through; }
.truncate            { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.whitespace-nowrap   { white-space: nowrap; }
.whitespace-pre      { white-space: pre; }
.break-words         { overflow-wrap: break-word; }
.list-none           { list-style-type: none; }
.decoration-1        { text-decoration-thickness: 1px; }
.underline-offset-4  { text-underline-offset: 4px; }

/* ============================================================
   7. COLORS
   ============================================================ */
.text-\[\#F0EDE8\]   { color: #F0EDE8; }
.text-\[\#9CA097\]   { color: #9CA097; }
.text-\[\#6B6B66\]   { color: #6B6B66; }
.text-\[\#0C0C0A\]   { color: #0C0C0A; }
.text-\[\#181815\]   { color: #181815; }
.text-\[\#D8E2DC\]   { color: #D8E2DC; }
.text-\[\#C8C8C2\]   { color: #C8C8C2; }
.text-\[\#ffffff\]   { color: #ffffff; }
.text-white          { color: #ffffff; }
.text-black          { color: #0C0C0A; }
.bg-\[\#0C0C0A\]     { background-color: #0C0C0A; }
.bg-\[\#181815\]     { background-color: #181815; }
.bg-\[\#F0EDE8\]     { background-color: #F0EDE8; }
.bg-\[\#9CA097\]     { background-color: #9CA097; }
.bg-\[\#6B6B66\]     { background-color: #6B6B66; }
.bg-\[\#2E2E2B\]     { background-color: #2E2E2B; }
.bg-\[\#242420\]     { background-color: #242420; }
.bg-\[\#1C1C19\]     { background-color: #1C1C19; }
.bg-transparent      { background-color: transparent; }
.bg-black\/10        { background-color: rgba(0,0,0,0.10); }
.bg-black\/20        { background-color: rgba(0,0,0,0.20); }
.bg-black\/40        { background-color: rgba(0,0,0,0.40); }
.bg-black\/60        { background-color: rgba(0,0,0,0.60); }
.bg-white\/5         { background-color: rgba(255,255,255,0.05); }
.bg-white\/10        { background-color: rgba(255,255,255,0.10); }
.fill-\[\#F0EDE8\]   { fill: #F0EDE8; }
.fill-\[\#9CA097\]   { fill: #9CA097; }
.stroke-\[\#F0EDE8\] { stroke: #F0EDE8; }
.stroke-\[\#9CA097\] { stroke: #9CA097; }

/* ============================================================
   8. BORDERS
   ============================================================ */
.border              { border-width: 1px; border-style: solid; }
.border-2            { border-width: 2px; border-style: solid; }
.border-4            { border-width: 4px; border-style: solid; }
.border-0            { border-width: 0; }
.border-t            { border-top-width: 1px; border-top-style: solid; }
.border-b            { border-bottom-width: 1px; border-bottom-style: solid; }
.border-l            { border-left-width: 1px; border-left-style: solid; }
.border-r            { border-right-width: 1px; border-right-style: solid; }
.border-t-2          { border-top-width: 2px; border-top-style: solid; }
.border-b-2          { border-bottom-width: 2px; border-bottom-style: solid; }
.border-l-4          { border-left-width: 4px; border-left-style: solid; }
.border-\[\#F0EDE8\] { border-color: #F0EDE8; }
.border-\[\#9CA097\] { border-color: #9CA097; }
.border-\[\#6B6B66\] { border-color: #6B6B66; }
.border-\[\#2E2E2B\] { border-color: #2E2E2B; }
.border-\[\#181815\] { border-color: #181815; }
.border-white        { border-color: #ffffff; }
.border-\[\#F0EDE8\]\/10 { border-color: rgba(240,237,232,0.10); }
.border-\[\#F0EDE8\]\/20 { border-color: rgba(240,237,232,0.20); }
.border-\[\#F0EDE8\]\/30 { border-color: rgba(240,237,232,0.30); }
.border-\[\#6B6B66\]\/30 { border-color: rgba(107,107,102,0.30); }
.border-\[\#6B6B66\]\/20 { border-color: rgba(107,107,102,0.20); }
.divide-y > * + *    { border-top-width: 1px; border-top-style: solid; }
.divide-\[\#2E2E2B\] > * + * { border-top-color: #2E2E2B; }
.rounded-none        { border-radius: 0; }
.rounded             { border-radius: 0.25rem; }
.rounded-sm          { border-radius: 0.125rem; }
.rounded-full        { border-radius: 9999px; }

/* ============================================================
   9. EFFECTS — Swiss Brutalist offset shadows
   ============================================================ */
.shadow-none         { box-shadow: none; }
.shadow-sm           { box-shadow: 0 1px 2px rgba(0,0,0,0.3); }
.shadow-brutal       { box-shadow: 4px 4px 0 #9CA097; }
.shadow-brutal-lg    { box-shadow: 6px 6px 0 #9CA097; }
.shadow-brutal-xl    { box-shadow: 8px 8px 0 #F0EDE8; }
.shadow-brutal-acc   { box-shadow: 4px 4px 0 #F0EDE8; }
.shadow-brutal-sm    { box-shadow: 3px 3px 0 #9CA097; }
.shadow-\[4px_4px_0_\#9CA097\]  { box-shadow: 4px 4px 0 #9CA097; }
.shadow-\[6px_6px_0_\#9CA097\]  { box-shadow: 6px 6px 0 #9CA097; }
.shadow-\[8px_8px_0_\#F0EDE8\]  { box-shadow: 8px 8px 0 #F0EDE8; }
.shadow-\[4px_4px_0_\#F0EDE8\]  { box-shadow: 4px 4px 0 #F0EDE8; }
.shadow-\[3px_3px_0_\#9CA097\]  { box-shadow: 3px 3px 0 #9CA097; }
.opacity-0           { opacity: 0; }
.opacity-20          { opacity: 0.2; }
.opacity-40          { opacity: 0.4; }
.opacity-50          { opacity: 0.5; }
.opacity-60          { opacity: 0.6; }
.opacity-70          { opacity: 0.7; }
.opacity-80          { opacity: 0.8; }
.opacity-90          { opacity: 0.9; }
.opacity-100         { opacity: 1; }
.blur-sm             { filter: blur(4px); }
.blur                { filter: blur(8px); }
.backdrop-blur-xl    { -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px); }
.backdrop-blur-sm    { -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }

/* ============================================================
   10. TRANSFORMS
   ============================================================ */
.rotate-90           { transform: rotate(90deg); }
.rotate-\[-90deg\]   { transform: rotate(-90deg); }
.rotate-\[3deg\]     { transform: rotate(3deg); }
.rotate-\[-3deg\]    { transform: rotate(-3deg); }
.scale-95            { transform: scale(0.95); }
.scale-100           { transform: scale(1); }
.scale-105           { transform: scale(1.05); }
.-translate-x-1\/2  { transform: translateX(-50%); }
.-translate-y-1\/2  { transform: translateY(-50%); }
.translate-x-0       { transform: translateX(0); }

/* ============================================================
   11. TRANSITIONS
   ============================================================ */
.transition          { transition-property: color, background-color, border-color, opacity, box-shadow, transform; transition-duration: 150ms; transition-timing-function: cubic-bezier(0.4,0,0.2,1); }
.transition-all      { transition: all 0.2s ease; }
.transition-colors   { transition-property: color, background-color, border-color; transition-duration: 150ms; transition-timing-function: cubic-bezier(0.4,0,0.2,1); }
.transition-opacity  { transition-property: opacity; transition-duration: 150ms; }
.transition-transform{ transition-property: transform; transition-duration: 200ms; }
.duration-150        { transition-duration: 150ms; }
.duration-200        { transition-duration: 200ms; }
.duration-300        { transition-duration: 300ms; }
.ease-in-out         { transition-timing-function: cubic-bezier(0.4,0,0.2,1); }

/* ============================================================
   12. INTERACTION STATES
   ============================================================ */
.cursor-pointer      { cursor: pointer; }
.select-none         { user-select: none; }
.pointer-events-none { pointer-events: none; }
.appearance-none     { appearance: none; }
.resize-none         { resize: none; }
.outline-none        { outline: none; }
.outline-0           { outline: 0; }
.focus\:outline-none:focus { outline: none; }
.focus\:border-\[\#9CA097\]:focus { border-color: #9CA097; }
.focus\:border-\[\#F0EDE8\]:focus { border-color: #F0EDE8; }
.hover\:text-\[\#9CA097\]:hover  { color: #9CA097; }
.hover\:text-\[\#F0EDE8\]:hover  { color: #F0EDE8; }
.hover\:bg-\[\#9CA097\]:hover    { background-color: #9CA097; }
.hover\:bg-\[\#F0EDE8\]:hover    { background-color: #F0EDE8; }
.hover\:text-\[\#0C0C0A\]:hover  { color: #0C0C0A; }
.hover\:opacity-90:hover         { opacity: 0.9; }
.hover\:opacity-80:hover         { opacity: 0.8; }
.hover\:shadow-brutal-lg:hover   { box-shadow: 6px 6px 0 #9CA097; }
.hover\:shadow-brutal-xl:hover   { box-shadow: 8px 8px 0 #F0EDE8; }
.hover\:translate-x-1:hover      { transform: translateX(0.25rem); }
.hover\:border-\[\#9CA097\]:hover{ border-color: #9CA097; }
.hover\:border-\[\#F0EDE8\]:hover{ border-color: #F0EDE8; }
.group:hover .group-hover\:text-\[\#9CA097\] { color: #9CA097; }
.group:hover .group-hover\:opacity-100 { opacity: 1; }
.group:hover .group-hover\:scale-105 { transform: scale(1.05); }

/* ============================================================
   13. MISC UTILITIES
   ============================================================ */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border-width: 0;
}
.container           { width: 100%; margin-left: auto; margin-right: auto; padding-left: 1rem; padding-right: 1rem; }
.mx-auto             { margin-left: auto; margin-right: auto; }
.space-y-1 > * + *   { margin-top: 0.25rem; }
.space-y-2 > * + *   { margin-top: 0.5rem; }
.space-y-3 > * + *   { margin-top: 0.75rem; }
.space-y-4 > * + *   { margin-top: 1rem; }
.space-y-6 > * + *   { margin-top: 1.5rem; }
.space-y-8 > * + *   { margin-top: 2rem; }
.space-y-10 > * + *  { margin-top: 2.5rem; }
.space-y-12 > * + *  { margin-top: 3rem; }
.space-x-2 > * + *   { margin-left: 0.5rem; }
.space-x-4 > * + *   { margin-left: 1rem; }
.space-x-6 > * + *   { margin-left: 1.5rem; }
.w-\[calc\(100\%-1\.5rem\)\] { width: calc(100% - 1.5rem); }
.bg-cover            { background-size: cover; }
.bg-center           { background-position: center; }
.bg-no-repeat        { background-repeat: no-repeat; }
.pointer-events-auto { pointer-events: auto; }

/* ============================================================
   14. RESPONSIVE BREAKPOINTS
   ============================================================ */
@media (min-width: 640px) {
  .sm\:block           { display: block; }
  .sm\:flex            { display: flex; }
  .sm\:hidden          { display: none; }
  .sm\:grid-cols-2     { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sm\:text-5xl        { font-size: 3rem; line-height: 1.1; }
  .sm\:text-6xl        { font-size: 3.75rem; line-height: 1.05; }
  .sm\:px-6            { padding-left: 1.5rem; padding-right: 1.5rem; }
  .sm\:col-span-2      { grid-column: span 2 / span 2; }
}

@media (min-width: 768px) {
  .md\:block           { display: block; }
  .md\:flex            { display: flex; }
  .md\:hidden          { display: none; }
  .md\:inline-block    { display: inline-block; }
  .md\:grid-cols-2     { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3     { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:grid-cols-4     { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .md\:col-span-1      { grid-column: span 1 / span 1; }
  .md\:col-span-2      { grid-column: span 2 / span 2; }
  .md\:col-span-3      { grid-column: span 3 / span 3; }
  .md\:row-span-2      { grid-row: span 2 / span 2; }
  .md\:flex-row        { flex-direction: row; }
  .md\:flex-col        { flex-direction: column; }
  .md\:items-center    { align-items: center; }
  .md\:items-end       { align-items: flex-end; }
  .md\:justify-between { justify-content: space-between; }
  .md\:justify-end     { justify-content: flex-end; }
  .md\:px-8            { padding-left: 2rem; padding-right: 2rem; }
  .md\:py-24           { padding-top: 6rem; padding-bottom: 6rem; }
  .md\:py-32           { padding-top: 8rem; padding-bottom: 8rem; }
  .md\:py-16           { padding-top: 4rem; padding-bottom: 4rem; }
  .md\:py-12           { padding-top: 3rem; padding-bottom: 3rem; }
  .md\:mt-0            { margin-top: 0; }
  .md\:mb-0            { margin-bottom: 0; }
  .md\:gap-4           { gap: 1rem; }
  .md\:gap-6           { gap: 1.5rem; }
  .md\:gap-8           { gap: 2rem; }
  .md\:gap-12          { gap: 3rem; }
  .md\:gap-16          { gap: 4rem; }
  .md\:text-6xl        { font-size: 3.75rem; line-height: 1.05; }
  .md\:text-7xl        { font-size: 4.5rem; line-height: 1; }
  .md\:text-8xl        { font-size: 6rem; line-height: 1; }
  .md\:text-\[80px\]   { font-size: 80px; line-height: 0.95; }
  .md\:text-\[96px\]   { font-size: 96px; line-height: 0.9; }
  .md\:text-5xl        { font-size: 3rem; line-height: 1.1; }
  .md\:text-4xl        { font-size: 2.25rem; line-height: 2.5rem; }
  .md\:text-3xl        { font-size: 1.875rem; line-height: 2.25rem; }
  .md\:text-2xl        { font-size: 1.5rem; line-height: 2rem; }
  .md\:aspect-\[21\/9\]{ aspect-ratio: 21 / 9; }
  .md\:min-h-\[600px\] { min-height: 600px; }
  .md\:min-h-\[500px\] { min-height: 500px; }
  .md\:min-h-\[400px\] { min-height: 400px; }
  .md\:w-auto          { width: auto; }
  .md\:w-1\/2          { width: 50%; }
  .md\:max-w-lg        { max-width: 32rem; }
  .md\:max-w-xl        { max-width: 36rem; }
  .md\:max-w-2xl       { max-width: 42rem; }
  .md\:max-w-3xl       { max-width: 48rem; }
}

@media (min-width: 1024px) {
  .lg\:block           { display: block; }
  .lg\:flex            { display: flex; }
  .lg\:hidden          { display: none; }
  .lg\:grid-cols-2     { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lg\:grid-cols-3     { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lg\:grid-cols-4     { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .lg\:col-span-1      { grid-column: span 1 / span 1; }
  .lg\:col-span-2      { grid-column: span 2 / span 2; }
  .lg\:col-span-3      { grid-column: span 3 / span 3; }
  .lg\:gap-8           { gap: 2rem; }
  .lg\:gap-12          { gap: 3rem; }
  .lg\:py-24           { padding-top: 6rem; padding-bottom: 6rem; }
  .lg\:px-8            { padding-left: 2rem; padding-right: 2rem; }
  .lg\:text-\[80px\]   { font-size: 80px; line-height: 0.95; }
  .lg\:text-\[96px\]   { font-size: 96px; line-height: 0.9; }
  .lg\:text-\[120px\]  { font-size: 120px; line-height: 0.9; }
  .lg\:text-7xl        { font-size: 4.5rem; line-height: 1; }
  .lg\:text-8xl        { font-size: 6rem; line-height: 1; }
}

@media (min-width: 1280px) {
  .xl\:grid-cols-4     { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .xl\:col-span-3      { grid-column: span 3 / span 3; }
  .xl\:text-\[120px\]  { font-size: 120px; line-height: 0.9; }
}

/* ============================================================
   15. SWISS BRUTALIST COMPONENT PATTERNS
   ============================================================ */

/* Mono label / terminal tag */
.mono-label {
  font-family: 'Courier New', Courier, monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #6B6B66;
}

/* Section number marker */
.section-num {
  font-family: 'Archivo Black', sans-serif;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #6B6B66;
}

/* Bento card base */
.bento-card {
  border: 1px solid #2E2E2B;
  background-color: #181815;
  padding: 1.5rem;
  position: relative;
  transition: box-shadow 0.2s ease;
}
.bento-card:hover {
  box-shadow: 4px 4px 0 #9CA097;
}

/* Hard border block */
.hard-block {
  border: 2px solid #F0EDE8;
  background-color: #0C0C0A;
  padding: 2rem;
}

/* Accent block */
.accent-block {
  border: 2px solid #9CA097;
  background-color: #181815;
  box-shadow: 4px 4px 0 #9CA097;
  padding: 2rem;
}

/* Stat number */
.stat-num {
  font-family: 'Archivo Black', sans-serif;
  font-size: 3.5rem;
  line-height: 1;
  letter-spacing: -0.04em;
  color: #F0EDE8;
}

/* Tag chip */
.tag-chip {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.25rem 0.6rem;
  border: 1px solid #6B6B66;
  color: #9CA097;
  font-family: 'Courier New', monospace;
}

/* CTA button — Swiss Brutalist */
.btn-brutal {
  display: inline-block;
  background-color: #F0EDE8;
  color: #0C0C0A;
  font-family: 'Archivo Black', sans-serif;
  font-weight: 900;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.875rem 2rem;
  border: 2px solid #F0EDE8;
  box-shadow: 4px 4px 0 #9CA097;
  transition: box-shadow 0.15s ease, transform 0.15s ease;
  cursor: pointer;
}
.btn-brutal:hover {
  box-shadow: 6px 6px 0 #9CA097;
  transform: translate(-1px, -1px);
  color: #0C0C0A;
}

/* Ghost button */
.btn-ghost {
  display: inline-block;
  background-color: transparent;
  color: #F0EDE8;
  font-family: 'Archivo', sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.875rem 2rem;
  border: 1px solid #6B6B66;
  transition: border-color 0.15s ease, color 0.15s ease;
}
.btn-ghost:hover {
  border-color: #9CA097;
  color: #9CA097;
}

/* Hairline divider */
.hr-accent {
  border: none;
  border-top: 1px solid #2E2E2B;
  margin: 0;
}

/* Input field */
.input-brutal {
  width: 100%;
  background-color: #0C0C0A;
  border: 1px solid #2E2E2B;
  color: #F0EDE8;
  padding: 0.75rem 1rem;
  font-family: 'Archivo', sans-serif;
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.15s ease;
  border-radius: 0;
}
.input-brutal:focus {
  border-color: #9CA097;
}

/* Rotated vertical label */
.vertical-label {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #6B6B66;
  font-family: 'Courier New', monospace;
}

/* Image overlay caption */
.img-caption-overlay {
  position: absolute;
  bottom: 0.75rem;
  left: 0.75rem;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #F0EDE8;
  font-family: 'Courier New', monospace;
  background-color: rgba(12,12,10,0.7);
  padding: 0.2rem 0.5rem;
}

/* Marquee container */
.marquee-container {
  overflow: hidden;
  width: 100%;
  border-top: 1px solid #2E2E2B;
  border-bottom: 1px solid #2E2E2B;
  background-color: #181815;
}

/* Accordion item */
.accordion-item {
  border-bottom: 1px solid #2E2E2B;
}
.accordion-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0;
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  color: #F0EDE8;
  font-family: 'Archivo', sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.accordion-trigger:hover { color: #9CA097; }
.accordion-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.accordion-body.open {
  max-height: 400px;
}
.accordion-body-inner {
  padding-bottom: 1.25rem;
  color: #6B6B66;
  font-size: 0.875rem;
  line-height: 1.7;
}

/* Nav sticky */
header.sticky-nav {
  position: sticky;
  top: 0;
  z-index: 40;
  background-color: rgba(12,12,10,0.96);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
}

/* Form elements reset */
input, textarea, select {
  font-family: 'Archivo', sans-serif;
  background-color: #0C0C0A;
  color: #F0EDE8;
  border: 1px solid #2E2E2B;
  border-radius: 0;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
}
input:focus, textarea:focus, select:focus {
  border-color: #9CA097;
}
input::placeholder, textarea::placeholder { color: #6B6B66; }
select option { background-color: #181815; color: #F0EDE8; }

/* Map iframe */
.map-frame {
  width: 100%;
  border: 1px solid #2E2E2B;
  display: block;
}

/* ASCII-style decorative divider */
.ascii-divider {
  font-family: 'Courier New', monospace;
  font-size: 11px;
  color: #2E2E2B;
  letter-spacing: 0.08em;
}

/* Numbered methodology step */
.step-num-display {
  font-family: 'Archivo Black', sans-serif;
  font-size: 4rem;
  line-height: 1;
  letter-spacing: -0.05em;
  color: #2E2E2B;
  user-select: none;
}

/* Table utilities */
.w-\[30\%\]  { width: 30%; }
.w-\[70\%\]  { width: 70%; }

/* Cookie banner text color */
.cookie-link { color: #D8E2DC; text-decoration: underline; text-underline-offset: 4px; }

/* Print */
@media print {
  .no-print { display: none !important; }
}
