/*
Theme Name: LOQOS UNO
Theme URI: https://loqos.az/
Description: Umbrella landing for the LOQOS group of companies. Single-page, Polylang RU/AZ/EN, server-side i18n.
Author: LOQOS
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
Text Domain: loqos-uno
*/
/* ============================================================
   LOQOS — экосистема проектов · Титульная страница loqos.az
   2026 design system: editorial serif × generous whitespace ×
   bento × glass × motion-soft. Палитра наследована от
   qadin.loqos.az (teal-led + warm sand).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  /* Inherited from qadin.loqos.az */
  --primary:        #3DAAB0;
  --primary-dark:   #268A90;
  --primary-light:  #A8DCE0;
  --primary-pale:   #EAF4F5;
  --secondary:      #5E8A93;
  --accent-warm:    #E5DDC9;
  --accent-sand:    #DDCEBD;
  --accent-sage:    #B2D4CE;
  --accent-clay:    #B8907A;          /* warm tone for Tarana brand */
  --accent-clay-d:  #8E6A55;
  --bg:             #F7FBFC;
  --warm-white:     #FDFEFE;
  --cream:          #F4ECDD;
  --text:           #1F3B44;
  --text-body:      #4A6670;
  --text-light:     #7A949D;
  --border:         #D5E8EA;
  --border-soft:    #E9EFF1;
  --dark-bg:        #112B30;
  --shadow-sm:      0 2px 10px rgba(21,48,54,.05);
  --shadow:         0 8px 24px rgba(21,48,54,.07);
  --shadow-lg:      0 24px 56px rgba(21,48,54,.12);
  --shadow-card:    0 30px 60px -22px rgba(21,48,54,.18);

  --font-heading:   'Playfair Display', Georgia, serif;
  --font-body:      'Inter', 'Segoe UI', sans-serif;
  --transition:     .35s cubic-bezier(.4,0,.2,1);
  --ease:           cubic-bezier(.2,.6,.2,1);

  --radius-sm: 12px;
  --radius:    20px;
  --radius-lg: 28px;
  --radius-xl: 36px;
}

/* ---------- reset ---------- */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--font-body);
  color: var(--text-body);
  background: var(--bg);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; transition: color var(--transition); }
ul,ol { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; color:inherit; }
h1,h2,h3,h4 { font-family: var(--font-heading); font-weight:600; line-height:1.15; color: var(--text); letter-spacing:-.01em; }
h1 { font-size: clamp(2.6rem, 6vw, 5.5rem); font-weight:500; letter-spacing:-.02em; }
h2 { font-size: clamp(1.9rem, 3.6vw, 3.2rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
p  { color: var(--text-body); font-size: 1rem; }

::selection { background: var(--primary); color:#fff; }

/* ---------- layout helpers ---------- */
.container { max-width: 1280px; margin:0 auto; padding: 0 28px; }
.section   { padding: 120px 0; position:relative; }
.eyebrow {
  display:inline-flex; align-items:center; gap:.55rem;
  font-family: var(--font-body); font-weight:600;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color: var(--primary-dark);
}
.eyebrow::before {
  content:""; width:24px; height:1px; background: var(--primary);
}
.section-head { max-width: 760px; margin: 0 auto 70px; text-align:center; }
.section-head .eyebrow { margin-bottom:1rem; justify-content:center; }
.section-head h2 { margin-bottom:1rem; }
.section-head p  { font-size:1.05rem; color: var(--text-body); }

/* ---------- scroll progress bar ---------- */
.scroll-progress {
  position: fixed; top: 0; left: 0;
  height: 3px; width: 0;
  background: linear-gradient(90deg, var(--primary) 0%, var(--primary-dark) 50%, var(--accent-clay) 100%);
  z-index: 60;
  transition: width .1s linear;
  box-shadow: 0 0 12px rgba(61,170,176,.5);
}

/* ---------- glassy nav ---------- */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:50;
  padding: 18px 0;
  transition: background .4s var(--ease), backdrop-filter .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
}
.nav.scrolled { padding: 12px 0; }
.nav.scrolled {
  background: rgba(247,251,252,.78);
  -webkit-backdrop-filter: saturate(170%) blur(16px);
          backdrop-filter: saturate(170%) blur(16px);
  box-shadow: 0 1px 0 rgba(21,48,54,.05);
}
.nav-inner {
  max-width: 1320px; margin:0 auto; padding: 0 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  display:flex; align-items:center; gap:12px;
  font-family: var(--font-heading); font-size: 1.45rem;
  font-weight:600; color: var(--text);
  letter-spacing:.02em;
}
.nav-logo .mark {
  width:38px; height:38px; border-radius:50%;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color:#fff; display:grid; place-items:center;
  font-style: italic; font-size:1.25rem; font-weight:600;
  box-shadow: 0 6px 16px rgba(38,138,144,.32);
}
.nav-logo .logo-text { display:flex; flex-direction:column; line-height:1.05; }
.nav-logo .logo-sub {
  font-family: var(--font-body);
  font-size:.6rem; font-weight:600; letter-spacing:.16em;
  text-transform:uppercase; color: var(--text-light);
  margin-top:3px;
}
.footer-brand .nav-logo .logo-sub { color: rgba(255,255,255,.5); }
.nav-links {
  display:flex; gap: 36px; align-items:center;
  font-size:.92rem; font-weight:500;
}
.nav-links a {
  color: var(--text); position:relative; padding:6px 0;
}
.nav-links a::after {
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:1px; background: var(--primary);
  transform: scaleX(0); transform-origin: right;
  transition: transform .4s var(--ease);
}
.nav-links a:hover { color: var(--primary-dark); }
.nav-links a:hover::after { transform: scaleX(1); transform-origin: left; }
.nav-cta {
  display:inline-flex; align-items:center; gap:.5rem;
  background: var(--text); color:#fff;
  padding: 10px 20px; border-radius: 999px;
  font-size:.88rem; font-weight:500;
  transition: transform .35s var(--ease), background .35s var(--ease);
}
.nav-cta:hover { background: var(--primary-dark); transform: translateY(-2px); }

/* ---------- LANGUAGE SWITCH ---------- */
.lang-switch {
  display:inline-flex; gap:2px; padding:3px;
  border-radius:999px;
  background: rgba(31,59,68,.06);
  margin-left: 8px;
}
.lang-switch button {
  appearance: none; border:0; cursor:pointer;
  padding:6px 11px;
  background:transparent; color:var(--text-light);
  font:inherit; font-size:.74rem; font-weight:600; letter-spacing:.08em;
  border-radius:999px;
  transition: color .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
}
.lang-switch button:hover { color: var(--text); }
.lang-switch button.active {
  background:#fff; color:var(--text);
  box-shadow: 0 2px 8px rgba(31,59,68,.08);
}
@media (max-width: 768px) {
  .lang-switch { margin-left: 6px; padding:2px; }
  .lang-switch button { padding:5px 8px; font-size:.7rem; letter-spacing:.06em; }
}

.nav-burger { display:none; width:34px; height:34px; position:relative; }
.nav-burger span {
  position:absolute; left:6px; right:6px; height:1.5px;
  background: var(--text); border-radius:2px;
  transition: transform .35s var(--ease), opacity .35s var(--ease), top .35s var(--ease);
}
.nav-burger span:nth-child(1) { top: 12px; }
.nav-burger span:nth-child(2) { top: 17px; }
.nav-burger span:nth-child(3) { top: 22px; }
body.menu-open .nav-burger span:nth-child(1) { top:17px; transform: rotate(45deg); }
body.menu-open .nav-burger span:nth-child(2) { opacity:0; }
body.menu-open .nav-burger span:nth-child(3) { top:17px; transform: rotate(-45deg); }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  padding: 180px 0 120px;
  overflow: hidden;
  background:
    radial-gradient(60% 60% at 80% 20%, rgba(168,220,224,.45) 0%, transparent 60%),
    radial-gradient(50% 50% at 10% 90%, rgba(229,221,201,.55) 0%, transparent 65%),
    linear-gradient(180deg, #F4FAFB 0%, #F7FBFC 100%);
}
/* subtle grain layer */
.hero::before {
  content:""; position:absolute; inset:0;
  background-image:
    radial-gradient(rgba(38,138,144,.06) 1px, transparent 1px);
  background-size: 22px 22px;
  opacity:.5; pointer-events:none;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative; z-index:2;
}
.hero-content .eyebrow { margin-bottom: 28px; }
.hero h1 em {
  font-style: italic;
  background: linear-gradient(120deg,
    var(--primary) 0%,
    var(--primary-dark) 25%,
    var(--accent-clay) 50%,
    var(--primary-dark) 75%,
    var(--primary) 100%);
  background-size: 300% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  font-weight: 400;
  animation: gradientShift 9s ease-in-out infinite;
}
@keyframes gradientShift {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}
.hero h1 .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(40px);
  animation: wordIn .9s var(--ease) forwards;
}
.hero h1 .word:nth-child(1) { animation-delay: .15s; }
.hero h1 .word:nth-child(2) { animation-delay: .25s; }
.hero h1 .word:nth-child(3) { animation-delay: .35s; }
.hero h1 .word:nth-child(4) { animation-delay: .45s; }
.hero h1 .word:nth-child(5) { animation-delay: .55s; }
.hero h1 .word:nth-child(6) { animation-delay: .65s; }
.hero h1 .word:nth-child(7) { animation-delay: .75s; }
.hero h1 .word:nth-child(8) { animation-delay: .85s; }
.hero h1 .word:nth-child(9) { animation-delay: .95s; }
.hero h1 .word:nth-child(10) { animation-delay: 1.05s; }
.hero h1 .word:nth-child(11) { animation-delay: 1.15s; }
.hero h1 .word:nth-child(12) { animation-delay: 1.25s; }
.hero h1 .word:nth-child(13) { animation-delay: 1.35s; }
.hero h1 .word:nth-child(14) { animation-delay: 1.45s; }
@keyframes wordIn {
  to { opacity: 1; transform: translateY(0); }
}
.hero-content p.lead {
  font-size: 1.18rem;
  margin: 28px 0 38px;
  max-width: 540px;
  color: var(--text-body);
  line-height: 1.7;
}
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.btn {
  display:inline-flex; align-items:center; gap:.55rem;
  padding: 16px 28px; border-radius: 999px;
  font-size:.95rem; font-weight:500;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease);
}
.btn-primary {
  background: var(--primary-dark); color:#fff;
  box-shadow: 0 12px 28px -10px rgba(38,138,144,.55);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 20px 36px -12px rgba(38,138,144,.65); background: var(--text); }
/* Magnetic-button shimmer on idle */
.btn-primary { position: relative; overflow: hidden; isolation: isolate; }
.btn-primary::before {
  content:""; position:absolute; inset:0;
  background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,.28) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform 1s var(--ease);
  z-index: -1;
}
.btn-primary:hover::before { transform: translateX(100%); }
.btn-ghost {
  color: var(--text); border:1px solid rgba(31,59,68,.18);
  background: rgba(255,255,255,.5);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
}
.btn-ghost:hover { border-color: var(--text); background: #fff; }
.btn .arrow { transition: transform .35s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

/* hero visual: stacked screenshot mosaic */
.hero-visual {
  position: relative;
  height: 560px;
}
.hero-mock {
  position: absolute;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow-card);
  border: 1px solid rgba(255,255,255,.7);
  transition: transform .6s var(--ease);
}
.hero-mock img { width:100%; height:100%; object-fit: cover; object-position: top; }
.hero-mock-1 { /* big card */
  width: 78%; height: 76%; top: 8%; right: 0;
  z-index: 3;
  animation: floatA 7s ease-in-out infinite;
}
.hero-mock-2 { /* small card top-left */
  width: 46%; height: 38%; top: 0; left: 0;
  z-index: 4;
  transform: rotate(-3deg);
  animation: floatB 6s ease-in-out infinite .4s;
}
.hero-mock-3 { /* small card bottom-left */
  width: 52%; height: 36%; bottom: 0; left: 4%;
  z-index: 5;
  transform: rotate(2deg);
  animation: floatC 8s ease-in-out infinite .8s;
}
@keyframes floatA {
  0%,100% { transform: translateY(0) rotate(0deg); }
  50%     { transform: translateY(-14px) rotate(.5deg); }
}
@keyframes floatB {
  0%,100% { transform: translateY(0) rotate(-3deg); }
  50%     { transform: translateY(-10px) rotate(-1.5deg); }
}
@keyframes floatC {
  0%,100% { transform: translateY(0) rotate(2deg); }
  50%     { transform: translateY(12px) rotate(.8deg); }
}
.hero-mock:hover {
  animation-play-state: paused;
  transform: translateY(-8px) rotate(0deg) scale(1.02) !important;
  z-index: 10;
}
/* organic blob behind */
.hero-blob {
  position: absolute; right: -8%; top: 10%;
  width: 520px; height: 520px;
  background: radial-gradient(circle at 30% 30%, rgba(168,220,224,.6) 0%, transparent 65%);
  filter: blur(40px);
  z-index: 1;
  border-radius: 50%;
  animation: blobMorph 14s ease-in-out infinite;
}
@keyframes blobMorph {
  0%,100% { transform: translate(0,0)   scale(1);    border-radius: 50%; }
  33%     { transform: translate(-30px,20px) scale(1.1); border-radius: 60% 40% 55% 45% / 50% 60% 40% 50%; }
  66%     { transform: translate(20px,-15px) scale(.95); border-radius: 45% 55% 50% 50% / 60% 40% 60% 40%; }
}

/* Cursor-following soft spotlight */
.cursor-glow {
  position: fixed; pointer-events: none;
  width: 420px; height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(61,170,176,.18) 0%, transparent 65%);
  transform: translate(-50%,-50%);
  z-index: 1;
  transition: transform .12s ease-out, opacity .4s var(--ease);
  opacity: 0;
  mix-blend-mode: multiply;
}
.cursor-glow.active { opacity: 1; }

/* hero metrics row */
.hero-metrics {
  margin-top: 56px;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 36px;
  border-top: 1px solid rgba(31,59,68,.08);
  padding-top: 36px;
  position: relative; z-index:2;
}
.hero-metrics .container { display:contents; }
.metric-num {
  font-family: var(--font-heading);
  font-size: clamp(1.9rem, 3vw, 2.6rem);
  color: var(--text);
  font-weight: 500;
  display:block;
  letter-spacing: -.01em;
  position: relative;
}
.metric-num em { color: var(--primary); font-style: normal; }
.hero-metrics > div {
  position: relative;
  transition: transform .5s var(--ease);
}
.hero-metrics > div::before {
  content:""; position: absolute; left:0; top:-37px;
  width: 0; height: 2px; background: var(--primary);
  transition: width .9s var(--ease);
}
.hero-metrics.in > div::before { width: 32px; }
.hero-metrics.in > div:nth-child(2)::before { transition-delay: .15s; }
.hero-metrics.in > div:nth-child(3)::before { transition-delay: .3s; }
.hero-metrics.in > div:nth-child(4)::before { transition-delay: .45s; }
.hero-metrics > div:hover { transform: translateY(-4px); }
.metric-label {
  font-size: .82rem; color: var(--text-light);
  letter-spacing: .04em; margin-top: 4px; display:block;
}

/* ---------- MARQUEE STRIP ---------- */
.marquee {
  background: var(--text);
  color: #fff;
  padding: 22px 0;
  overflow: hidden;
  position: relative;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.marquee-track {
  display: flex; gap: 56px;
  width: max-content;
  animation: marquee 32s linear infinite;
  font-family: var(--font-heading);
  font-size: 1.45rem;
  letter-spacing: .01em;
  align-items: center;
}
.marquee-track span {
  display: inline-flex; align-items: center; gap: 56px;
  white-space: nowrap;
}
.marquee-track .star {
  color: var(--primary);
  font-size: 1rem;
  font-style: italic;
}
.marquee-track em {
  font-style: italic;
  color: var(--primary-light);
  font-weight: 400;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ---------- ECOSYSTEM (bento) ---------- */
.ecosystem { background: var(--warm-white); position: relative; }
.ecosystem::before {
  content:""; position:absolute; top:-1px; left:0; right:0; height:80px;
  background: linear-gradient(180deg, var(--text) 0%, transparent 100%);
  opacity: .04; pointer-events:none;
}
.bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}
.bento > * { align-self: stretch; }
.proj {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--border-soft);
  display: flex; flex-direction: column;
  transition: transform .55s var(--ease), box-shadow .55s var(--ease);
  isolation: isolate;
  transform-style: preserve-3d;
  will-change: transform;
}
.proj:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-card);
}
/* Animated gradient ring on hover */
.proj::before {
  content:""; position: absolute; inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(135deg,
    var(--primary) 0%, transparent 35%, transparent 65%, var(--primary-dark) 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0;
  transition: opacity .5s var(--ease);
  pointer-events: none;
  z-index: 5;
}
.proj:hover::before { opacity: 1; }
/* Shine sweep on hover */
.proj-img::before {
  content:""; position: absolute; inset: 0;
  background: linear-gradient(115deg,
    transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .9s var(--ease);
  z-index: 2;
  pointer-events: none;
}
.proj:hover .proj-img::before { transform: translateX(100%); }
.proj.accent-clay::before {
  background: linear-gradient(135deg,
    var(--accent-clay) 0%, transparent 35%, transparent 65%, var(--accent-clay-d) 100%);
}
.proj-img {
  position: relative;
  flex: 0 0 auto;
  background: var(--primary-pale);
  overflow: hidden;
  aspect-ratio: 16 / 10;
}
.proj-lg .proj-img { aspect-ratio: 16 / 9; }
.proj-img::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 55%, rgba(17,43,48,.05) 100%);
  pointer-events:none;
}
.proj-img img {
  width: 100%; height: 100%; object-fit: cover;
  object-position: top center;
  transition: transform 1s var(--ease);
}
.proj:hover .proj-img img { transform: scale(1.04); }
.proj-body {
  padding: 28px 30px 30px;
  display: flex; flex-direction: column; gap: 14px;
}
.proj-tag {
  display: inline-flex; align-items: center; gap: .45rem;
  font-size: .72rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--primary-dark);
  align-self: flex-start;
  padding: 6px 12px; border-radius: 999px;
  background: var(--primary-pale);
}
.proj-tag .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--primary);
}
.proj h3 {
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  line-height: 1.2; margin-bottom: 2px;
}
.proj p { font-size: .95rem; color: var(--text-body); line-height: 1.6; }
.proj-link {
  margin-top: 6px;
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .9rem; font-weight: 600;
  color: var(--primary-dark);
  align-self: flex-start;
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
  transition: border-color .35s var(--ease), gap .35s var(--ease);
}
.proj-link:hover { border-color: var(--primary); gap: .8rem; }
.proj-link .arrow { transition: transform .35s var(--ease); }
.proj-link-soon {
  margin-top: 6px; align-self: flex-start;
  display: inline-flex; align-items: center;
  font-size: .72rem; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text-light);
  background: rgba(0,0,0,.05); border-radius: 999px;
  padding: 4px 12px;
}
.footer-soon { color: rgba(255,255,255,.4); cursor: default; }

/* size variants */
.proj-lg  { grid-column: span 7; }
.proj-md  { grid-column: span 5; }
.proj-sm  { grid-column: span 6; }

/* per-project accents */
.proj.accent-clay .proj-tag { background: rgba(184,144,122,.14); color: var(--accent-clay-d); }
.proj.accent-clay .proj-tag .dot { background: var(--accent-clay); }
.proj.accent-clay .proj-link { color: var(--accent-clay-d); }
.proj.accent-clay .proj-link:hover { border-color: var(--accent-clay); }
.proj.accent-clay .proj-img { background: #F5EBE3; }

.proj.accent-sand .proj-tag { background: rgba(221,206,189,.35); color: #6E5A45; }
.proj.accent-sand .proj-tag .dot { background: var(--accent-clay); }

.proj.accent-sage .proj-tag { background: rgba(178,212,206,.32); color: #2E6E66; }
.proj.accent-sage .proj-tag .dot { background: #4FA294; }

/* ---------- ABOUT BAND ---------- */
.about {
  background:
    radial-gradient(ellipse at 20% 0%, rgba(168,220,224,.25) 0%, transparent 55%),
    linear-gradient(180deg, #F5EEE0 0%, var(--accent-sand) 100%);
  position: relative;
}
.about-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: center;
}
.about h2 { margin: 1rem 0 1.5rem; }
.about-quote {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  line-height: 1.55;
  color: var(--text);
  padding-left: 22px;
  border-left: 2px solid var(--primary);
  margin: 28px 0;
}
.about-pillars {
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px;
  margin-top: 36px;
}
.pillar {
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(255,255,255,.7);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border-radius: var(--radius);
  padding: 24px;
}
.pillar .num {
  font-family: var(--font-heading);
  font-size: 2rem; color: var(--primary-dark);
  font-style: italic; line-height:1; margin-bottom: 10px;
  display: block;
}
.pillar h4 {
  font-family: var(--font-body); font-size: .95rem;
  color: var(--text); font-weight: 600; margin-bottom: 4px;
}
.pillar p { font-size: .88rem; color: var(--text-body); }

.about-visual {
  position: relative; height: 540px;
}
.about-img-1 {
  position: absolute; inset: 0;
  border-radius: 200px 200px 24px 24px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.about-img-1 img { width:100%; height:100%; object-fit: cover; object-position: top; }
.about-card-float {
  position: absolute;
  bottom: 28px; right: -20px;
  background: #fff;
  border-radius: var(--radius);
  padding: 18px 22px;
  box-shadow: var(--shadow-card);
  display: flex; gap: 14px; align-items: center;
  max-width: 280px;
}
.about-card-float .icon {
  width: 44px; height: 44px;
  background: var(--primary-pale);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--primary-dark); font-size:1.2rem;
  flex-shrink: 0;
  position: relative;
}
.about-card-float .icon::after {
  content:""; position: absolute; inset: -6px;
  border: 2px solid var(--primary);
  border-radius: 50%;
  opacity: 0;
  animation: pulseRing 2.6s ease-out infinite;
}
@keyframes pulseRing {
  0%   { transform: scale(.8);  opacity: .65; }
  80%  { transform: scale(1.5); opacity: 0; }
  100% { transform: scale(1.5); opacity: 0; }
}
.about-card-float {
  animation: floatSoft 5s ease-in-out infinite;
}
@keyframes floatSoft {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-8px); }
}
.about-card-float strong { display:block; color: var(--text); font-size: .95rem; margin-bottom: 2px; }
.about-card-float span  { font-size: .82rem; color: var(--text-light); }

/* ---------- FOUNDER BAND ---------- */
.founder {
  background: var(--warm-white);
  position: relative;
}
.founder-grid {
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 80px; align-items: center;
}
.founder-portrait {
  position: relative;
  border-radius: 320px 320px 32px 32px;
  overflow: hidden;
  height: 600px;
  background:
    radial-gradient(ellipse at 50% 30%, var(--accent-warm) 0%, var(--cream) 70%);
}
.founder-portrait::after {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 40% at 50% 100%, rgba(184,144,122,.18) 0%, transparent 70%);
  pointer-events:none;
}
.founder-portrait img {
  width:100%; height:100%;
  object-fit: contain; object-position: center bottom;
  padding: 30px 20px 0;
  transition: transform 1.2s var(--ease);
}
.founder-portrait:hover img { transform: scale(1.04) translateY(-6px); }
/* slow rotation behind portrait */
.founder-portrait::before {
  content:""; position: absolute;
  inset: 60px 30px 30px;
  border: 1px dashed rgba(184,144,122,.35);
  border-radius: 240px 240px 28px 28px;
  animation: portraitSpin 26s linear infinite;
  pointer-events: none;
}
@keyframes portraitSpin {
  0%   { transform: rotate(0deg) scale(1); }
  50%  { transform: rotate(2deg) scale(1.02); }
  100% { transform: rotate(0deg) scale(1); }
}
.founder-eyebrow { color: var(--accent-clay-d); }
.founder-eyebrow::before { background: var(--accent-clay); }
.founder h2 em { font-style: italic; color: var(--accent-clay-d); }
.founder-meta {
  display:flex; gap: 28px; flex-wrap: wrap;
  margin: 24px 0 18px;
  font-size: .85rem; color: var(--text-light);
}
.founder-meta span strong { color: var(--text); display:block; font-family: var(--font-heading); font-size: 1.5rem; font-weight: 500; margin-bottom: 2px; }
.founder p { font-size: 1.05rem; line-height: 1.75; margin-bottom: 18px; }
.founder .btn-primary { background: var(--accent-clay-d); box-shadow: 0 12px 28px -10px rgba(142,106,85,.55); }
.founder .btn-primary:hover { background: var(--text); }

/* ---------- CTA BAND ---------- */
.cta-band {
  background: var(--dark-bg);
  color: rgba(255,255,255,.85);
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(50% 60% at 80% 30%, rgba(61,170,176,.28) 0%, transparent 60%),
    radial-gradient(40% 50% at 10% 90%, rgba(221,206,189,.18) 0%, transparent 60%);
  pointer-events:none;
  animation: ctaShift 14s ease-in-out infinite alternate;
}
@keyframes ctaShift {
  0%   { background-position: 0% 0%, 0% 0%; }
  100% { background-position: 20% 10%, -20% -10%; }
}
/* dotted decoration line that draws in */
.cta-band::after {
  content:""; position:absolute; left:50%; top:30px;
  width: 1px; height: 0;
  background: linear-gradient(180deg, transparent, var(--primary-light), transparent);
  transition: height 1.6s var(--ease) .2s;
}
.cta-band.in::after { height: 60px; }
.cta-inner { position: relative; z-index:2; text-align: center; max-width: 760px; margin: 0 auto; }
.cta-inner h2 { color: #fff; margin-bottom: 18px; }
.cta-inner h2 em { color: var(--primary-light); font-style: italic; }
.cta-inner p { color: rgba(255,255,255,.7); margin-bottom: 36px; font-size: 1.1rem; }
.cta-band .btn-primary { background: var(--primary); }
.cta-band .btn-primary:hover { background: #fff; color: var(--text); }
.cta-band .btn-ghost { color: #fff; border-color: rgba(255,255,255,.3); background: transparent; }
.cta-band .btn-ghost:hover { background: rgba(255,255,255,.1); border-color: #fff; }

/* ---------- FOOTER ---------- */
.footer {
  background: var(--dark-bg);
  color: rgba(255,255,255,.7);
  padding: 80px 0 36px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.footer-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 56px;
  margin-bottom: 56px;
}
.footer-brand .nav-logo { color:#fff; }
.footer-brand .nav-logo .mark { box-shadow: 0 6px 16px rgba(61,170,176,.45); }
.footer-brand p { color: rgba(255,255,255,.55); margin: 18px 0 0; font-size: .92rem; max-width: 320px; }
.footer-col h5 {
  color: #fff; font-family: var(--font-body); font-size: .82rem;
  font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  margin-bottom: 22px;
}
.footer-col ul li { margin-bottom: 12px; }
.footer-col a {
  color: rgba(255,255,255,.65); font-size: .92rem;
  transition: color .3s var(--ease);
}
.footer-col a:hover { color: var(--primary-light); }
.footer-bottom {
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex; justify-content: space-between; align-items: center;
  font-size: .82rem; color: rgba(255,255,255,.45);
}
.footer-bottom a { color: rgba(255,255,255,.65); }
.footer-bottom a:hover { color: var(--primary-light); }

/* ---------- motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .fade-in, .fade-in.in { opacity:1 !important; transform: none !important; transition:none !important; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
.fade-in {
  opacity:0; transform: translateY(36px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
  will-change: opacity, transform;
}
.fade-in.in { opacity:1; transform: translateY(0); }
.fade-in.delay-1 { transition-delay: .08s; }
.fade-in.delay-2 { transition-delay: .16s; }
.fade-in.delay-3 { transition-delay: .24s; }
.fade-in.delay-4 { transition-delay: .32s; }

/* ---------- responsive ---------- */
@media (max-width: 1080px) {
  .hero-grid, .about-grid, .founder-grid { grid-template-columns: 1fr; gap: 48px; }
  .hero-visual { height: 460px; }
  .about-visual { height: 460px; }
  .founder-portrait { height: 500px; }
  .hero-metrics { grid-template-columns: repeat(2, 1fr); gap: 28px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .proj-lg, .proj-md, .proj-sm { grid-column: span 12; }
  .section { padding: 90px 0; }
  .hero { padding: 150px 0 90px; }
}
@media (max-width: 768px) {
  .container { padding: 0 20px; }
  .nav-links { display: none; }
  .nav-burger { display: block; }
  .nav-links.open {
    display: flex; flex-direction: column;
    position: fixed; top: 72px; left: 0; right: 0;
    background: rgba(247,251,252,.96);
    -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
    padding: 32px 28px; gap: 24px;
    border-top: 1px solid var(--border-soft);
  }
  .hero { padding: 130px 0 70px; }
  .hero-visual { height: 380px; }
  .hero-mock-1 { width: 84%; height: 72%; }
  .hero-mock-2 { width: 50%; height: 36%; }
  .hero-mock-3 { width: 56%; height: 34%; }
  .hero-metrics { grid-template-columns: 1fr 1fr; gap: 20px; padding-top: 28px; margin-top: 36px; }
  .about-pillars { grid-template-columns: 1fr; }
  .about-card-float { right: 0; bottom: -16px; max-width: 240px; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
  .section { padding: 70px 0; }
  .section-head { margin-bottom: 50px; }
}

/* ===== loqos-uno WP overrides ===== */
.lang-switch a {
  appearance:none; border:0; cursor:pointer;
  padding:6px 11px; border-radius:999px;
  background:transparent; color:var(--text-light);
  font:inherit; font-size:.74rem; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; text-decoration:none; line-height:1;
  display:inline-flex; align-items:center;
  transition: color .25s var(--ease), background .25s var(--ease);
}
.lang-switch a:hover { color: var(--text); }
.lang-switch a.active {
  background:#fff; color:var(--text);
  box-shadow: 0 2px 8px rgba(31,59,68,.08);
}
@media (max-width: 768px){ .lang-switch a { padding:5px 8px; font-size:.7rem; letter-spacing:.06em; } }

/* ===== Contact page ===== */
.contact-page { padding-top: 140px; }
.section-head-left { text-align:left; max-width:680px; margin:0 0 48px; }
.section-head-left h1 { font-size: clamp(2.2rem,4.5vw,3.6rem); margin:.25em 0 .45em; }
.section-head-left .lead { color:var(--text-light); font-size:1.05rem; max-width:560px; }
.contact-grid { display:grid; grid-template-columns:.9fr 1.3fr; gap:48px; align-items:start; }
.contact-info { display:flex; flex-direction:column; gap:16px; }
.contact-card { display:flex; flex-direction:column; gap:6px; padding:22px 24px; border-radius:var(--radius-lg);
  background:#fff; border:1px solid rgba(31,59,68,.08); box-shadow:0 4px 18px rgba(31,59,68,.04);
  text-decoration:none; transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
a.contact-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-card); }
.contact-card-label { font-size:.72rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--text-light); }
.contact-card-value { font-family:var(--font-heading); font-size:1.15rem; color:var(--text); }
.contact-form-wrap { background:#fff; border:1px solid rgba(31,59,68,.08); border-radius:var(--radius-lg);
  padding:36px 36px 40px; box-shadow:0 10px 40px rgba(31,59,68,.06); position:relative; }
.contact-form-title { font-size:1.6rem; margin-bottom:6px; }
.contact-form-sub { color:var(--text-light); margin-bottom:24px; font-size:.95rem; }
.contact-form { display:flex; flex-direction:column; gap:18px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-field { display:flex; flex-direction:column; gap:7px; }
.form-field > span { font-size:.8rem; font-weight:600; color:var(--text); letter-spacing:.02em; }
.form-field input, .form-field textarea { font:inherit; font-size:.95rem; color:var(--text); padding:12px 14px;
  border:1px solid rgba(31,59,68,.16); border-radius:12px; background:#fbfcfc;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease); }
.form-field input:focus, .form-field textarea:focus { outline:none; border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(38,138,144,.12); background:#fff; }
.form-field textarea { resize:vertical; min-height:120px; }
.contact-form .btn { align-self:flex-start; margin-top:6px; }
.uno-hp { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-status { padding:14px 18px; border-radius:12px; font-size:.92rem; margin-bottom:20px; }
.form-status-ok { background:rgba(56,142,96,.12); color:#2e6e50; border:1px solid rgba(56,142,96,.3); }
.form-status-err { background:rgba(190,70,70,.1); color:#a3413b; border:1px solid rgba(190,70,70,.28); }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; gap:28px; } .form-row{ grid-template-columns:1fr; }
  .contact-page{ padding-top:110px; } .contact-form-wrap{ padding:26px 22px 30px; } }
