/* ===================================================================
   Software Ukraine — Joomla 5 Template  v3.0
   Single CSS file: shell + content design system
   =================================================================== */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body,.su-page{font:400 16px/1.65 Inter,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;color:#10233e;background:#fff;margin:0!important;padding:0!important}
img{display:block;max-width:100%;height:auto}
a{color:#2563eb;text-decoration:none;transition:color .15s}
a:hover{color:#1d4ed8}
svg{display:inline-block;vertical-align:middle}

/* --- Container --- */
.su-container{width:min(1200px,calc(100% - 40px));margin-inline:auto}

/* ===================================================================
   HEADER
   =================================================================== */
.su-header{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,rgba(10,25,50,.94),rgba(16,40,72,.92));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06)}
.su-header__row{display:flex;align-items:center;min-height:76px;gap:20px}
.su-header__logo{flex-shrink:0;line-height:0;margin-right:auto}
.su-header__logo img{height:40px;width:auto}

/* Nav */
.su-header__nav{display:flex}
.su-header__nav ul{display:flex;gap:2px;list-style:none;padding:0}
.su-header__nav a{display:block;padding:9px 16px;color:rgba(255,255,255,.82);font-weight:600;font-size:.9rem;border-radius:12px;transition:background .15s,color .15s;text-decoration:none;white-space:nowrap}
.su-header__nav a:hover,.su-header__nav a[aria-current]{background:rgba(255,255,255,.1);color:#fff}

/* Header CTA */
.su-header__cta{flex-shrink:0;margin-left:12px;min-height:42px!important;padding:0 20px!important;font-size:13px!important}

/* Search button */
.su-search-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:0;border-radius:10px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);cursor:pointer;transition:background .15s,color .15s;flex-shrink:0;font-size:15px}
.su-search-btn:hover{background:rgba(255,255,255,.15);color:#fff}

/* Search overlay — command palette style */
.su-search-overlay{position:fixed;inset:0;z-index:2000;background:rgba(4,12,24,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:none;align-items:flex-start;justify-content:center;padding:min(20vh,160px) 20px 40px;opacity:0;transition:opacity .2s ease}
.su-search-overlay.is-open{opacity:1}
.su-search-overlay__inner{width:100%;max-width:560px;background:linear-gradient(165deg,#162a48,#0f2037);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 40px 100px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.05) inset;overflow:hidden;transform:scale(.96) translateY(12px);transition:transform .25s cubic-bezier(.16,1,.3,1),opacity .2s ease;opacity:0}
.su-search-overlay.is-open .su-search-overlay__inner{transform:scale(1) translateY(0);opacity:1}
.su-search-form{display:flex;align-items:center;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.su-search-form i{color:rgba(255,255,255,.35);font-size:17px;flex-shrink:0}
.su-search-form input{flex:1;padding:20px 16px;border:0;background:transparent;color:#fff;font:400 17px/1.4 Inter,sans-serif;outline:none;-webkit-appearance:none}
.su-search-form input::placeholder{color:rgba(255,255,255,.3)}
.su-search-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;color:rgba(255,255,255,.3);font-size:12px}
.su-search-bar kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.4);font:500 11px/1 Inter,sans-serif}
.su-search-bar span{display:flex;align-items:center;gap:6px}
/* Close button */
.su-search-overlay__close{position:absolute;top:16px;right:16px;display:none}

/* Burger */
.su-burger{display:none;background:0;border:0;width:44px;height:44px;cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent;flex-shrink:0}
.su-burger span,.su-burger span::before,.su-burger span::after{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .2s;position:absolute;left:11px}
.su-burger span{top:21px}
.su-burger span::before{content:'';top:-7px}
.su-burger span::after{content:'';top:7px}
.su-burger.is-open span{background:transparent}
.su-burger.is-open span::before{top:0;transform:rotate(45deg)}
.su-burger.is-open span::after{top:0;transform:rotate(-45deg)}

/* ===================================================================
   BUTTONS
   =================================================================== */
.su-btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:0 26px;border:0;border-radius:999px;font:700 15px/1 Inter,sans-serif;cursor:pointer;text-decoration:none;transition:transform .18s,box-shadow .18s,opacity .18s;letter-spacing:.01em}
.su-btn:hover{transform:translateY(-2px);text-decoration:none}
.su-btn--primary{background:linear-gradient(135deg,#2563eb,#1d4fd8);color:#fff;box-shadow:0 8px 24px rgba(37,99,235,.22)}
.su-btn--primary:hover{box-shadow:0 14px 32px rgba(37,99,235,.3);color:#fff}
.su-btn--secondary{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.2);box-shadow:none}
.su-btn--secondary:hover{background:rgba(255,255,255,.14);color:#fff}
.su-btn--light{background:#fff;color:#0f2a4a;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.su-btn--sm{min-height:42px;padding:0 20px;font-size:13px}

/* ===================================================================
   SECTIONS
   =================================================================== */
.su-section{padding:clamp(56px,8vw,100px) 0}
.su-section--white{background:#fff}
.su-section--light{background:#f6f9fd}
.su-section--dark{background:linear-gradient(135deg,#0b1e38 0%,#152f54 60%,#1a3d6a 100%);color:#fff}
.su-section--accent{background:linear-gradient(135deg,#0f2d52 0%,#1c4f8a 100%);color:#fff}

/* --- Headings --- */
.su-eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#2563eb}
.su-section--dark .su-eyebrow{color:#93c5fd}
.su-title{margin:0 0 16px;font-size:clamp(28px,4.2vw,48px);line-height:1.1;font-weight:800;letter-spacing:-.02em;color:#0f2a4a}
.su-title--light,.su-section--dark .su-title{color:#fff}
.su-lead,.su-text{font-size:17px;line-height:1.75;color:#52657f}
.su-text--light,.su-section--dark .su-text,.su-section--dark .su-lead,.su-section--dark p{color:rgba(255,255,255,.82)}
.su-section-heading{max-width:740px;margin-bottom:40px}
.su-section-heading--center{margin-inline:auto;text-align:center}

/* ===================================================================
   HERO
   =================================================================== */
.su-hero{position:relative;overflow:hidden;padding:clamp(72px,10vw,110px) 0;background:radial-gradient(ellipse at 70% 10%,rgba(56,136,255,.14),transparent 50%),radial-gradient(ellipse at 10% 90%,rgba(37,99,235,.08),transparent 40%),linear-gradient(150deg,#081829 0%,#0f2a4a 40%,#163a64 100%);color:#fff}
.su-hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 30h60M30 0v60' stroke='rgba(255,255,255,0.025)' stroke-width='.5'/%3E%3C/svg%3E");pointer-events:none}
.su-hero__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.su-hero__title{margin:0 0 20px;font-size:clamp(34px,5.2vw,62px);line-height:1.04;font-weight:800;letter-spacing:-.03em}
.su-hero__text{max-width:600px;margin:0;font-size:18px;color:rgba(255,255,255,.78);line-height:1.75}
.su-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}

/* Hero visual card */
.su-hero__visual{display:flex;justify-content:center}
.su-hero-card{position:relative;width:min(380px,100%);aspect-ratio:1/1;border-radius:28px;background:linear-gradient(160deg,rgba(255,255,255,.1),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);box-shadow:0 32px 80px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.1);overflow:hidden}
.su-hero-card__line{position:absolute;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,rgba(147,197,253,.5),transparent)}
.su-hero-card__line--1{top:28%}.su-hero-card__line--2{top:50%}.su-hero-card__line--3{top:72%}
.su-hero-card__badge{position:absolute;left:20px;bottom:20px;padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);color:#fff;font-weight:700;font-size:13px;letter-spacing:.01em}

/* ===================================================================
   GRIDS
   =================================================================== */
.su-grid{display:grid;gap:24px}
.su-grid--2{grid-template-columns:repeat(2,1fr)}
.su-grid--3{grid-template-columns:repeat(3,1fr)}
.su-grid--4{grid-template-columns:repeat(4,1fr)}
.su-grid--stretch>*{height:100%}

/* ===================================================================
   CARDS
   =================================================================== */
.su-card,.su-panel{border-radius:20px;background:#fff;box-shadow:0 4px 24px rgba(15,42,74,.06),0 1px 3px rgba(15,42,74,.04);border:1px solid rgba(15,42,74,.06);padding:30px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.su-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(15,42,74,.1)}
.su-section--dark .su-card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.08);box-shadow:0 8px 32px rgba(0,0,0,.2)}
.su-section--dark .su-card:hover{background:rgba(255,255,255,.09)}
.su-card__icon{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:16px;margin-bottom:18px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#2563eb;font-size:20px}
.su-section--dark .su-card__icon{background:rgba(147,197,253,.12);color:#93c5fd}
.su-card__title{margin:0 0 10px;font-size:1.15rem;font-weight:700;line-height:1.3;color:#0f2a4a}
.su-section--dark .su-card__title{color:#fff}
.su-card__text{margin:0;color:#52657f;line-height:1.7;font-size:.92rem;flex-grow:1}
.su-section--dark .su-card__text{color:rgba(255,255,255,.72)}

/* ===================================================================
   STATS
   =================================================================== */
.su-stat{padding:32px 22px;text-align:center;border-radius:20px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);transition:background .2s}
.su-stat:hover{background:rgba(255,255,255,.1)}
.su-stat__num{font-size:clamp(32px,4.5vw,50px);font-weight:800;line-height:1;letter-spacing:-.02em;color:#fff;background:linear-gradient(135deg,#fff,#93c5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.su-stat__label{margin-top:12px;font-size:14px;line-height:1.55;color:rgba(255,255,255,.7);font-weight:500}

/* ===================================================================
   CONTACT ITEMS
   =================================================================== */
.su-contact-list{display:grid;gap:16px}
.su-contact-item{padding:24px;display:grid;grid-template-columns:52px 1fr;gap:16px;align-items:start;border-radius:20px;background:#fff;box-shadow:0 4px 24px rgba(15,42,74,.06);border:1px solid rgba(15,42,74,.06);transition:transform .2s,box-shadow .2s}
.su-contact-item:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(15,42,74,.1)}
.su-contact-item__icon{width:52px;height:52px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#2563eb;font-size:18px}
.su-contact-item__label{margin:0 0 4px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#64748b;font-weight:700}
.su-contact-item__body{font-size:.95rem;line-height:1.6;color:#0f2a4a}
.su-contact-item__body a{color:#0f2a4a;text-decoration:none}
.su-contact-item__body a:hover{color:#2563eb}

/* ===================================================================
   NEWS CARDS
   =================================================================== */
.su-news-card{border-radius:20px;background:#fff;box-shadow:0 4px 24px rgba(15,42,74,.06);border:1px solid rgba(15,42,74,.06);overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.su-news-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(15,42,74,.1)}
.su-news-card__image{display:block;background:linear-gradient(135deg,#e0e7f1,#c7d5e8);overflow:hidden}
.su-news-card__image img{width:100%;height:auto;display:block}
.su-news-card__body{padding:24px;display:flex;flex-direction:column;flex:1}
.su-news-card__meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#64748b}
.su-news-card__title{margin:0 0 10px;font-size:1.2rem;line-height:1.3;font-weight:700}
.su-news-card__title a{color:#0f2a4a;text-decoration:none}
.su-news-card__title a:hover{color:#2563eb}
.su-news-card__text{margin:0;color:#52657f;line-height:1.7;font-size:.9rem;flex:1}

/* ===================================================================
   HELPERS
   =================================================================== */
.su-list{margin:16px 0 0;padding-left:20px;color:#52657f;line-height:1.8}
.su-list li+li{margin-top:6px}
.su-link{font-weight:700;color:#2563eb}
.su-link:hover{text-decoration:underline}

/* ===================================================================
   COMPONENT LAYOUT (3-col + bots)
   =================================================================== */
.su-layout-3col{display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
.su-layout-3col.has-left{grid-template-columns:260px 1fr}
.su-layout-3col.has-right{grid-template-columns:1fr 260px}
.su-layout-3col.has-left.has-right{grid-template-columns:260px 1fr 260px}
.su-sidebar{min-width:0}
.su-layout-main{min-width:0}
.su-layout-bots{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.su-pos--top1{margin-bottom:0}
@media(max-width:980px){
  .su-layout-3col,.su-layout-3col.has-left,.su-layout-3col.has-right,.su-layout-3col.has-left.has-right{grid-template-columns:1fr}
}
@media(max-width:767px){
  .su-layout-bots{grid-template-columns:1fr}
}

/* ===================================================================
   FOOTER
   =================================================================== */
.su-footer{background:linear-gradient(180deg,#081829,#0a1f38);color:rgba(255,255,255,.7);padding:48px 0 24px}
.su-footer a{color:rgba(255,255,255,.78);text-decoration:none}
.su-footer a:hover{color:#fff}
.su-footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.07);font-size:.84rem}

/* Joomla system — kill the gap */
#system-message-container{width:min(1200px,calc(100% - 40px));margin:0 auto!important;padding:0!important;line-height:0;font-size:0;max-height:0;overflow:hidden}
#system-message-container:not(:empty){max-height:none;overflow:visible;padding:10px 0;line-height:1.5;font-size:16px}
#system-message-container .alert{margin-bottom:0}
main{margin:0!important;padding:0!important;display:block}
main>:first-child{margin-top:0!important}
.su-hero{margin-top:0!important}
.su-header{margin-bottom:0!important}
/* SP Page Builder overrides */
.com-sppagebuilder #system-message-container{max-height:0;overflow:hidden}
div[aria-live="polite"]:empty{display:none!important;height:0!important;margin:0!important;padding:0!important}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(max-width:1100px){
  .su-grid--4{grid-template-columns:repeat(2,1fr)}
  .su-grid--3{grid-template-columns:repeat(2,1fr)}
  .su-hero__grid{grid-template-columns:1fr;text-align:center}
  .su-hero__text{margin-inline:auto}
  .su-actions{justify-content:center}
}
@media(max-width:980px){
  .su-burger{display:flex!important;align-items:center;justify-content:center;z-index:1002;position:relative}
  .su-header__cta{display:none!important}
  .su-header__nav{position:absolute!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;height:100dvh!important;z-index:1001;background:#081829!important;display:none!important;flex-direction:column!important;align-items:center!important;justify-content:flex-start!important;padding:90px 24px 40px!important;overflow-y:auto}
  .su-header__nav.is-open{display:flex!important}
  /* Items */
  .su-header__nav.is-open ul{display:flex!important;flex-direction:column!important;gap:2px!important;align-items:center!important;padding:0!important;margin:0!important;list-style:none!important;width:100%!important;max-width:320px!important}
  .su-header__nav.is-open li{display:block!important;width:100%!important}
  .su-header__nav.is-open a{font-size:1.15rem!important;padding:14px 24px!important;color:#fff!important;border-radius:14px!important;display:block!important;text-align:center!important}
  .su-header__nav.is-open a:hover,.su-header__nav.is-open a[aria-current]{background:rgba(255,255,255,.1)!important}
  body.nav-open{overflow:hidden!important}
}
@media(max-width:767px){
  .su-section{padding:48px 0}
  .su-hero{padding:64px 0}
  .su-grid--2,.su-grid--3,.su-grid--4{grid-template-columns:1fr}
  .su-header__row{min-height:64px}
  .su-header__logo img{height:32px}
  .su-hero__title{font-size:32px}
  .su-title{font-size:26px}
  .su-card,.su-panel{padding:22px}
  .su-footer__bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .su-contact-item{grid-template-columns:44px 1fr}
  .su-contact-item__icon{width:44px;height:44px}
  .su-hero__visual{display:none}
}

/* ===================================================================
   ANIMATIONS & EFFECTS
   =================================================================== */

/* Scroll-reveal */
.will-animate{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.will-animate.is-visible{opacity:1;transform:translateY(0)}

/* Stat number gradient shimmer */
@keyframes shimmer{0%{background-position:200% center}100%{background-position:-200% center}}
.su-stat__num{background-size:200% auto;animation:shimmer 6s linear infinite}

/* Card hover glow */
.su-card::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,rgba(37,99,235,.15),transparent 60%);opacity:0;transition:opacity .3s;z-index:-1;pointer-events:none}
.su-card{position:relative;overflow:hidden}
.su-card:hover::before{opacity:1}

/* Hero floating animation */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.su-hero-card{animation:float 5s ease-in-out infinite}

/* Hero line pulse */
@keyframes linePulse{0%,100%{opacity:.4}50%{opacity:1}}
.su-hero-card__line{animation:linePulse 3s ease-in-out infinite}
.su-hero-card__line--2{animation-delay:.5s}
.su-hero-card__line--3{animation-delay:1s}

/* Button ripple on hover */
.su-btn{position:relative;overflow:hidden}
.su-btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--x,50%) var(--y,50%),rgba(255,255,255,.2) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.su-btn:hover::after{opacity:1}

/* Header nav underline effect */
.su-header__nav a::after{content:'';position:absolute;bottom:2px;left:16px;right:16px;height:2px;background:#fff;border-radius:1px;transform:scaleX(0);transition:transform .25s cubic-bezier(.16,1,.3,1)}
.su-header__nav a{position:relative}
.su-header__nav a:hover::after,.su-header__nav a[aria-current]::after{transform:scaleX(1)}

/* Smooth page transitions */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
main{animation:fadeIn .4s ease-out}

/* Contact item icon pulse on hover */
.su-contact-item:hover .su-contact-item__icon{transform:scale(1.08);transition:transform .2s ease}

/* Prefers reduced motion */
@media(prefers-reduced-motion:reduce){
  .will-animate{opacity:1;transform:none;transition:none}
  .su-hero-card{animation:none}
  .su-hero-card__line{animation:none}
  .su-stat__num{animation:none}
  main{animation:none}
}

/* ===================================================================
   FORM — mod_contactform override (.su-cf)
   =================================================================== */
.su-cf{font-family:Inter,sans-serif}
.su-cf-row{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.su-cf-field{margin-bottom:14px}
.su-cf-field label{display:block;margin-bottom:5px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.su-cf-field input,.su-cf-field textarea,.su-cf-field select{display:block;width:100%;padding:11px 14px;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:rgba(255,255,255,.07);color:#fff;font:400 15px/1.5 Inter,sans-serif;outline:none;transition:border-color .15s,background .15s,box-shadow .15s}
.su-cf-field input::placeholder,.su-cf-field textarea::placeholder{color:rgba(255,255,255,.3)}
.su-cf-field input:focus,.su-cf-field textarea:focus{border-color:rgba(147,197,253,.5);background:rgba(255,255,255,.11);box-shadow:0 0 0 3px rgba(37,99,235,.18)}
.su-cf-field textarea{resize:vertical;min-height:90px}
.su-cf-submit{display:block;width:100%;padding:13px 24px;border:0;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4fd8);color:#fff;font:700 15px/1 Inter,sans-serif;cursor:pointer;transition:transform .15s,box-shadow .15s;margin-top:6px}
.su-cf-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.35)}
/* Light section */
.su-section--white .su-cf-field label{color:#52657f}
.su-section--white .su-cf-field input,.su-section--white .su-cf-field textarea{border-color:#e2e5ee;background:#f8f9fc;color:#1a1d2e}
.su-section--white .su-cf-field input::placeholder,.su-section--white .su-cf-field textarea::placeholder{color:#94a3b8}
.su-section--white .su-cf-field input:focus,.su-section--white .su-cf-field textarea:focus{border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
@media(max-width:540px){.su-cf-row{grid-template-columns:1fr}}

/* ===================================================================
   BLOG — Category Blog Override
   =================================================================== */
.su-tag{display:inline-block;padding:3px 10px;border-radius:8px;background:rgba(37,99,235,.08);color:#2563eb;font-size:12px;font-weight:600;letter-spacing:.01em;text-decoration:none;transition:background .15s}
.su-tag:hover{background:rgba(37,99,235,.15);color:#2563eb;text-decoration:none}
.su-section--dark .su-tag{background:rgba(147,197,253,.15);color:#93c5fd}
/* Lead card — image covers left half */
.su-blog .su-news-card--lead{display:grid;grid-template-columns:1fr 1fr;overflow:hidden}
.su-blog .su-news-card--lead .su-news-card__image{min-height:0}
.su-blog .su-news-card--lead .su-news-card__image img{width:100%;height:100%;object-fit:cover}
.su-blog .su-news-card--lead .su-news-card__body{display:flex;flex-direction:column;padding:28px}
@media(max-width:767px){
  .su-blog .su-news-card--lead{grid-template-columns:1fr}
}

/* Joomla pagination */
.pagination{display:flex;gap:4px;list-style:none;padding:0;margin:0;flex-wrap:wrap;justify-content:center;align-items:center}
.pagination li,.pagination .page-item{display:inline-flex;margin:0}
.pagination a,.pagination span,.pagination .page-link{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:8px;font:600 13px/1 Inter,sans-serif;text-decoration:none!important;transition:background .15s,color .15s;border:none!important;box-shadow:none!important}
.pagination a,.pagination .page-link{background:#f1f5f9;color:#334155}
.pagination a:hover,.pagination .page-link:hover{background:#2563eb;color:#fff}
.pagination .active .page-link,.pagination .active>span{background:#2563eb!important;color:#fff!important}
.pagination .disabled .page-link,.pagination .disabled>span,.pagination .disabled a{color:#cbd5e1!important;background:transparent!important;pointer-events:none}
/* Nav arrows — ensure visible */
.pagination .page-link[aria-label],.pagination a[title]{min-width:36px;font-size:14px}
.pagination .page-link .visually-hidden{position:static!important;width:auto!important;height:auto!important;overflow:visible!important;clip:auto!important;white-space:nowrap}
/* Hide default Joomla pagination text, show icons */
.pagination li:first-child .page-link::before{content:'«';font-weight:700}
.pagination li:last-child .page-link::before{content:'»';font-weight:700}
.pagination li:nth-child(2) .page-link::before{content:'‹';font-weight:700;font-size:16px}
.pagination li:nth-last-child(2) .page-link::before{content:'›';font-weight:700;font-size:16px}

/* Joomla article single view */
.item-page{max-width:800px;margin:0 auto;padding:clamp(32px,5vw,64px) 0}
.item-page .page-header h1,.item-page .page-header h2{font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin-bottom:16px}
.item-page .article-info{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:24px;font-size:13px;color:#64748b}
.item-page .article-info dd{margin:0}
.item-page p{margin-bottom:16px;line-height:1.8;color:#374151}
.item-page img{border-radius:16px;margin:24px 0}


/* ===================================================================
   FORM — mod_simplecontact on dark backgrounds
   =================================================================== */
.su-section--dark form,
.su-section--dark form *,
[style*="rgba(255"] form,
[style*="rgba(255"] form * {
  color: #fff !important;
}
.su-section--dark form table,
[style*="rgba(255"] form table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 8px !important;
}
.su-section--dark form td,
[style*="rgba(255"] form td {
  padding: 0 4px !important;
  vertical-align: top !important;
}
/* mod_simplecontact — 2-col pairs */
.simplecontact {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 14px !important;
}
.simplecontact > * {
  grid-column: span 2 !important;
}
/* All .mb-3 fields default to 1 column (half width) */
.simplecontact > .mb-3 {
  grid-column: span 1 !important;
}
/* Textarea, captcha, submit — force full width */
.simplecontact > .mb-3:has(textarea),
.simplecontact > .mb-3:has([type="number"]),
.simplecontact > .mb-3:has([type="submit"]),
.simplecontact > .mb-3:last-of-type,
.simplecontact > button,
.simplecontact > input[type="submit"] {
  grid-column: span 2 !important;
}
/* Remove card styling on dark bg */
.su-section--dark .simplecontact.card {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: #fff !important;
}
@media(max-width:540px){
  .simplecontact { grid-template-columns: 1fr !important; }
  .simplecontact > .mb-3 { grid-column: span 1 !important; }
}
/* Style all inputs */
.su-section--dark form input[type="text"],
.su-section--dark form input[type="email"],
.su-section--dark form input[type="tel"],
.su-section--dark form input[type="number"],
.su-section--dark form input[type="url"],
.su-section--dark form textarea,
.su-section--dark form select,
[style*="rgba(255"] form input[type="text"],
[style*="rgba(255"] form input[type="email"],
[style*="rgba(255"] form input[type="tel"],
[style*="rgba(255"] form input[type="number"],
[style*="rgba(255"] form input[type="url"],
[style*="rgba(255"] form textarea,
[style*="rgba(255"] form select {
  display: block !important;
  width: 100% !important;
  padding: 11px 14px !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,.07) !important;
  color: #fff !important;
  font: 400 15px/1.5 Inter,sans-serif !important;
  outline: none !important;
  -webkit-appearance: none !important;
  box-sizing: border-box !important;
  margin: 0 0 4px !important;
  transition: border-color .15s, background .15s, box-shadow .15s !important;
}
.su-section--dark form input::placeholder,
.su-section--dark form textarea::placeholder,
[style*="rgba(255"] form input::placeholder,
[style*="rgba(255"] form textarea::placeholder {
  color: rgba(255,255,255,.3) !important;
}
.su-section--dark form input:focus,
.su-section--dark form textarea:focus,
[style*="rgba(255"] form input:focus,
[style*="rgba(255"] form textarea:focus {
  border-color: rgba(147,197,253,.5) !important;
  background: rgba(255,255,255,.11) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.18) !important;
}
.su-section--dark form textarea,
[style*="rgba(255"] form textarea {
  resize: vertical !important;
  min-height: 90px !important;
}
/* Labels */
.su-section--dark form label,
[style*="rgba(255"] form label {
  display: block !important;
  margin-bottom: 5px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.55) !important;
}
/* Submit button */
.su-section--dark form input[type="submit"],
.su-section--dark form button[type="submit"],
[style*="rgba(255"] form input[type="submit"],
[style*="rgba(255"] form button[type="submit"] {
  display: block !important;
  width: 100% !important;
  padding: 13px 24px !important;
  border: 0 !important;
  border-radius: 10px !important;
  background: linear-gradient(135deg,#2563eb,#1d4fd8) !important;
  color: #fff !important;
  font: 700 15px/1 Inter,sans-serif !important;
  cursor: pointer !important;
  transition: transform .15s, box-shadow .15s !important;
  margin-top: 8px !important;
  -webkit-appearance: none !important;
}
.su-section--dark form input[type="submit"]:hover,
.su-section--dark form button[type="submit"]:hover,
[style*="rgba(255"] form input[type="submit"]:hover,
[style*="rgba(255"] form button[type="submit"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(37,99,235,.35) !important;
}
/* Hide table borders/bg */
.su-section--dark form table,
.su-section--dark form table td,
.su-section--dark form table tr,
[style*="rgba(255"] form table,
[style*="rgba(255"] form table td,
[style*="rgba(255"] form table tr {
  background: transparent !important;
  border: none !important;
}
@media(max-width:540px){
  .su-section--dark form table tr,
  [style*="rgba(255"] form table tr {
    grid-template-columns: 1fr !important;
  }
}
