@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@500;600;700;800&display=swap');

:root {
  --navy: #071b42;
  --blue: #0757d8;
  --blue-2: #0a72ee;
  --cyan: #16b7ca;
  --gold: #f3bd31;
  --green: #1e9d72;
  --purple: #7654d6;
  --ink: #12203a;
  --muted: #64718a;
  --line: #dce3ed;
  --soft: #f3f7fb;
  --white: #fff;
  --shadow: 0 18px 55px rgba(7, 27, 66, .11);
  --radius: 20px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fff; font: 16px/1.65 "DM Sans", sans-serif; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.narrow { max-width: 520px; }
.skip-link { position: fixed; left: 16px; top: -60px; z-index: 1000; background: #fff; padding: 10px 16px; }
.skip-link:focus { top: 10px; }
.eu-line { background: var(--navy); color: #d9e6ff; font-size: 12px; letter-spacing: .02em; }
.eu-line-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; }
.eu-line-links { display: flex; gap: 22px; }
.eu-line a:hover { color: #fff; }
.site-header { position: sticky; top: 0; z-index: 3000; overflow: visible; background: rgba(255,255,255,.96); border-bottom: 1px solid rgba(220,227,237,.9); backdrop-filter: blur(14px); }
.nav-wrap { position: relative; z-index: 3010; min-height: 82px; display: flex; align-items: center; gap: 20px; overflow: visible; }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 270px; }
.brand img { object-fit: contain; }
.brand .municipality-logo { width: 66px; height: 48px; }
.brand .eu-emblem { width: 48px; height: 32px; object-fit: cover; }
.brand-divider { width: 1px; height: 36px; background: var(--line); }
.brand span { display: flex; flex-direction: column; line-height: 1.1; }
.brand b { font: 800 19px/1.1 "Manrope", sans-serif; color: var(--navy); }
.brand small { margin-top: 4px; color: var(--blue); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; }
.main-nav { position: relative; z-index: 3020; margin-left: auto; display: flex; align-items: center; gap: 4px; font-weight: 600; font-size: 14px; }
.nav-home, .nav-group-toggle { min-height: 42px; padding: 10px 13px; border: 0; border-radius: 9px; color: var(--ink); background: transparent; font-weight: 700; cursor: pointer; }
.nav-home { display: none; align-items: center; }
.nav-home:hover, .nav-group-toggle:hover, .nav-group.open > .nav-group-toggle { color: var(--blue); background: #edf4ff; }
.nav-group { position: relative; }
.nav-group-toggle { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.nav-group-toggle i { width: 7px; height: 7px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg) translateY(-2px); transition: transform .2s ease; }
.nav-group.open > .nav-group-toggle i { transform: rotate(225deg) translate(-1px,-1px); }
.nav-dropdown { display: none; position: absolute; z-index: 3100; top: calc(100% + 13px); left: 0; width: 300px; padding: 10px; background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: 0 22px 55px rgba(7,27,66,.18); }
.nav-group.open > .nav-dropdown { display: grid; }
.nav-dropdown:before { content: ""; position: absolute; left: 24px; top: -7px; width: 12px; height: 12px; background: #fff; border-left: 1px solid var(--line); border-top: 1px solid var(--line); transform: rotate(45deg); }
.nav-dropdown a { position: relative; z-index: 1; display: flex; flex-direction: column; padding: 11px 12px; border-radius: 9px; line-height: 1.35; }
.nav-dropdown a:hover { color: var(--blue); background: var(--soft); }
.nav-dropdown b { font-size: 13px; }
.nav-dropdown small { margin-top: 3px; color: var(--muted); font-size: 11px; font-weight: 500; }
.nav-dropdown-wide { width: 340px; }
.nav-dropdown-admin { left: auto; right: 0; width: 330px; max-height: min(650px, calc(100vh - 140px)); overflow-y: auto; grid-template-columns: repeat(2, minmax(0,1fr)); }
.nav-dropdown-admin:before { left: auto; right: 28px; }
.nav-dropdown-admin a:first-child, .nav-dropdown-label { grid-column: 1 / -1; }
.nav-dropdown-admin a:not(:first-child) { padding-block: 9px; font-size: 12px; }
.nav-dropdown-label { margin: 8px 8px 2px; padding-top: 8px; color: var(--muted); border-top: 1px solid var(--line); font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.nav-actions { display: flex; align-items: center; gap: 12px; }
.lang-switch { display: flex; gap: 4px; padding: 4px; background: #f2f6fb; border: 1px solid var(--line); border-radius: 999px; }.lang-switch a { padding: 6px 9px; color: var(--muted); border-radius: 999px; font-size: 11px; font-weight: 900; }.lang-switch a.active { color: #fff; background: var(--blue); }
.nav-actions form { display: flex; }
.text-link, .text-button { border: 0; background: none; padding: 8px; color: var(--navy); font-weight: 600; cursor: pointer; }
.menu-toggle { display: none; align-items: center; gap: 9px; border: 1px solid var(--line); background: #fff; border-radius: 9px; padding: 8px 12px; font-weight: 700; }
.menu-toggle i, .menu-toggle i:before, .menu-toggle i:after { display: block; width: 17px; height: 2px; background: var(--navy); content: ""; transition: .2s ease; }
.menu-toggle i { position: relative; }.menu-toggle i:before { position: absolute; top: -5px; }.menu-toggle i:after { position: absolute; top: 5px; }
.menu-toggle[aria-expanded="true"] i { background: transparent; }.menu-toggle[aria-expanded="true"] i:before { top: 0; transform: rotate(45deg); }.menu-toggle[aria-expanded="true"] i:after { top: 0; transform: rotate(-45deg); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 12px; border: 0; border-radius: 10px; padding: 12px 20px; font-weight: 700; cursor: pointer; transition: .2s ease; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, var(--blue), var(--blue-2)); color: #fff; box-shadow: 0 8px 20px rgba(7,87,216,.22); }
.btn-dark { background: var(--navy); color: #fff; }
.btn-light { background: var(--soft); color: var(--navy); border: 1px solid var(--line); }
.btn-ghost { color: #fff; border: 1px solid rgba(255,255,255,.35); background: rgba(255,255,255,.08); }
.btn-white { color: var(--blue); background: #fff; }
.btn-sm { padding: 9px 14px; font-size: 13px; }
.btn-lg { padding: 15px 24px; }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.hero { position: relative; min-height: 650px; overflow: hidden; color: #fff; background: radial-gradient(circle at 74% 34%, #0b75e7 0, #0758c7 24%, transparent 49%), linear-gradient(120deg, #06193d 10%, #073d99 70%, #0870d6); }
.hero:before { content: ""; position: absolute; inset: 0; opacity: .16; background-image: linear-gradient(rgba(255,255,255,.14) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.14) 1px, transparent 1px); background-size: 52px 52px; mask-image: linear-gradient(90deg, #000, transparent 72%); }
.hero-grid { position: relative; z-index: 2; min-height: 650px; display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 70px; }
.hero-copy { padding: 78px 0; }
.eyebrow { display: inline-flex; align-items: center; gap: 9px; color: #d6e8ff; font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow i { width: 24px; height: 2px; background: var(--gold); }
.eyebrow.dark { color: var(--blue); }
.hero h1, .page-hero h1, .detail-hero h1, .profile-head h1, .admin-head h1 { font: 800 clamp(42px, 6vw, 72px)/1.05 "Manrope", sans-serif; letter-spacing: -.045em; margin: 20px 0 24px; }
.hero h1 span { color: #82ccff; }
.hero-copy > p { max-width: 650px; color: #d6e5fa; font-size: 19px; line-height: 1.7; }
.hero-actions { display: flex; gap: 14px; margin: 34px 0 42px; }
.trust-row { display: flex; gap: 30px; color: #bdd2ef; font-size: 13px; }
.trust-row span { padding-left: 16px; border-left: 1px solid rgba(255,255,255,.22); }
.trust-row b { display: block; color: #fff; font: 700 21px "Manrope"; }
.journey-card { position: relative; padding: 28px; border: 1px solid rgba(255,255,255,.24); border-radius: 26px; background: linear-gradient(145deg, rgba(255,255,255,.18), rgba(255,255,255,.06)); box-shadow: 0 35px 80px rgba(0,17,63,.34); backdrop-filter: blur(18px); }
.journey-head { display: flex; justify-content: space-between; align-items: center; font-size: 13px; text-transform: uppercase; letter-spacing: .11em; }
.journey-head b { color: var(--gold); }
.journey-progress { height: 4px; margin: 18px 0 12px; background: rgba(255,255,255,.16); border-radius: 8px; overflow: hidden; }
.journey-progress i { display: block; height: 100%; background: linear-gradient(90deg, var(--gold), #fff); }
.journey-map { position: relative; height: 280px; border-radius: 18px; overflow: hidden; background: radial-gradient(circle at center, rgba(34,184,255,.4), transparent 43%), linear-gradient(150deg, rgba(5,20,61,.35), rgba(1,59,136,.16)); }
.journey-map:before, .journey-map:after { content: ""; position: absolute; border: 1px solid rgba(255,255,255,.17); border-radius: 50%; inset: 34px 70px; }
.journey-map:after { inset: 70px 106px; }
.map-center { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; z-index: 2; }
.map-center small { color: #afd4fa; text-transform: uppercase; letter-spacing: .12em; }
.map-center b { font: 700 25px/1.25 "Manrope"; }
.map-dot { position: absolute; z-index: 3; width: 12px; height: 12px; border: 3px solid white; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 8px rgba(243,189,49,.15); }
.dot-one { left: 19%; top: 38%; }.dot-two { right: 17%; top: 29%; }.dot-three { left: 44%; bottom: 14%; }
.journey-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; margin-top: 15px; color: #9cb9dd; font-size: 11px; text-align: center; }
.journey-steps span:before { content: ""; display: block; width: 8px; height: 8px; margin: 0 auto 7px; border: 1px solid #8caacb; border-radius: 50%; }
.journey-steps .done, .journey-steps .active { color: #fff; }.journey-steps .done:before { background: var(--green); border-color: var(--green); }.journey-steps .active:before { background: var(--gold); border-color: var(--gold); }
.hero-orbit { position: absolute; border: 1px solid rgba(255,255,255,.08); border-radius: 50%; }.orbit-one { width: 600px; height: 600px; right: -190px; top: -190px; }.orbit-two { width: 300px; height: 300px; right: 22%; bottom: -190px; }
.quick-section { position: relative; z-index: 4; margin-top: -42px; }
.quick-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.quick-card { min-height: 118px; display: flex; align-items: center; gap: 14px; padding: 20px; color: #fff; border-radius: 16px; box-shadow: var(--shadow); transition: .2s ease; }
.quick-card:hover { transform: translateY(-5px); }
.quick-card.blue { background: #0757d8; }.quick-card.green { background: #14845f; }.quick-card.gold { background: #b9790a; }.quick-card.purple { background: #6443bb; }
.quick-icon { display: grid; place-items: center; flex: 0 0 40px; height: 40px; border: 1px solid rgba(255,255,255,.35); border-radius: 50%; font-size: 11px; }
.quick-card div { display: flex; flex-direction: column; line-height: 1.25; }.quick-card b { font: 700 16px "Manrope"; }.quick-card small { margin-top: 6px; color: rgba(255,255,255,.76); }.quick-card i { margin-left: auto; font-style: normal; }
.section, .page-section { padding: 100px 0; }
.section-tint { background: var(--soft); }
.section-head { margin-bottom: 34px; display: flex; justify-content: space-between; align-items: end; gap: 20px; }
.section-head h2, .split-feature h2, .cta-band h2 { margin: 8px 0 0; font: 800 clamp(30px,4vw,45px)/1.15 "Manrope"; letter-spacing: -.035em; color: var(--navy); }
.section-head.small { margin-bottom: 20px; align-items: center; }.section-head.small h2 { font-size: 22px; }
.arrow-link { color: var(--blue); font-weight: 700; }
.card-grid, .opportunity-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.content-card, .opportunity-card { padding: 28px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: 0 10px 35px rgba(13,40,86,.06); }
.content-card h3, .opportunity-card h3 { font: 700 21px/1.35 "Manrope"; margin: 18px 0 12px; }
.content-card h3 a:hover { color: var(--blue); }
.content-card p, .opportunity-card p { color: var(--muted); }
.card-meta { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.card-meta.light { color: #c8d9f1; }
.status { display: inline-flex; width: max-content; border-radius: 50px; padding: 5px 10px; background: #edf1f6; color: #536079; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; font-style: normal; }
.status-open, .status-active, .status-accepted, .status-registered { background: #e3f6ed; color: #147154; }
.status-planned, .status-in_review, .status-in_progress, .status-pending { background: #fff2d3; color: #91650a; }
.status-closed, .status-rejected, .status-cancelled { background: #fbe7e9; color: #a33948; }
.status-reported, .status-answered, .status-implemented, .status-completed { background: #e8edff; color: #3c54ac; }
.deadline { margin-top: 22px; padding: 14px 16px; display: flex; justify-content: space-between; align-items: center; border-radius: 10px; background: var(--soft); }
.deadline small { color: var(--muted); }.deadline b { color: var(--navy); }
.card-foot { margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; color: var(--muted); font-size: 13px; }.card-foot a { color: var(--blue); font-weight: 700; }
.opportunity-card { position: relative; overflow: hidden; }
.opportunity-card:before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: linear-gradient(var(--blue), var(--cyan)); }
.program-badge { display: inline-grid; place-items: center; min-height: 42px; padding: 7px 12px; color: var(--blue); background: #eaf2ff; border-radius: 8px; font: 800 13px "Manrope"; }
.opportunity-card > .status { position: absolute; right: 22px; top: 25px; }
.opportunity-bottom { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: end; }
.opportunity-bottom span { display: flex; flex-direction: column; }.opportunity-bottom small { color: var(--muted); }.opportunity-bottom a { color: var(--blue); font-weight: 700; }
.split-feature { display: grid; grid-template-columns: .8fr 1.2fr; gap: 90px; align-items: center; }.lead { color: var(--muted); font-size: 18px; margin: 22px 0 30px; }
.official-eu-section { padding-top: 30px; }
.official-eu-card { padding: 30px; display: flex; align-items: center; justify-content: space-between; gap: 35px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.official-eu-card h2 { margin: 8px 0 0; }
.official-eu-card p { max-width: 760px; margin-bottom: 0; }
.event-stack { display: grid; gap: 10px; }.event-row { display: grid; grid-template-columns: 74px 1fr 32px; gap: 20px; align-items: center; padding: 18px; border: 1px solid var(--line); border-radius: 14px; }
.event-row time { height: 68px; display: grid; place-items: center; align-content: center; background: var(--navy); color: #fff; border-radius: 10px; line-height: 1; }.event-row time b { font-size: 25px; }.event-row time span { margin-top: 5px; color: #a9c8f0; font-size: 11px; text-transform: uppercase; }
.event-row h3 { margin: 3px 0; font: 700 17px "Manrope"; }.event-row div > span, .event-row small { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; }.event-row > a { color: var(--blue); font-size: 20px; }
.cta-band { padding: 76px 0; color: #fff; background: linear-gradient(110deg, #064dc0, #087adf); }.cta-inner { display: flex; justify-content: space-between; align-items: center; gap: 60px; }.cta-band h2 { max-width: 700px; color: #fff; }.cta-band p { color: #d9ebff; }
.site-footer { padding: 70px 0 24px; color: #afbdd4; background: #061631; }.footer-grid { display: grid; grid-template-columns: 1.5fr repeat(3,1fr); gap: 60px; }.brand-footer b { color: #fff; }.brand-footer .municipality-logo, .brand-footer .eu-emblem { background: #fff; border-radius: 6px; }.brand-footer .brand-divider { background: rgba(255,255,255,.2); }.footer-grid h3 { margin: 0 0 18px; color: #fff; font: 700 14px "Manrope"; }.footer-grid > div { display: flex; flex-direction: column; gap: 9px; }.footer-grid a:not(.brand):hover { color: #fff; }.footer-bottom { margin-top: 52px; padding-top: 22px; display: flex; justify-content: space-between; gap: 20px; border-top: 1px solid rgba(255,255,255,.1); font-size: 12px; }.footer-legal-links { display: flex; gap: 9px; flex-wrap: wrap; align-items: center; }.footer-legal-links a { color: #d7e3f5; }.footer-legal-links a:hover { color: #fff; }.footer-legal-links i { color: #62738f; font-style: normal; }
.flash-stack { position: fixed; right: 20px; top: 125px; z-index: 200; width: min(420px, calc(100% - 40px)); }.flash { margin-bottom: 8px; padding: 14px 18px; border-radius: 10px; box-shadow: var(--shadow); background: #fff; border-left: 4px solid var(--blue); }.flash-error { border-color: #d34c5f; }.flash-success { border-color: var(--green); }.flash-warning { border-color: var(--gold); }
.page-hero { padding: 95px 0 90px; color: #fff; background: linear-gradient(120deg, #071b42, #0757c9); }.page-hero.compact { padding: 70px 0; }.page-hero h1 { max-width: 850px; font-size: clamp(40px,6vw,66px); }.page-hero p { max-width: 720px; margin: 0; color: #cfdef2; font-size: 18px; }.funding-hero { background: radial-gradient(circle at 82% 40%, #2f91ff, transparent 28%), linear-gradient(120deg,#071b42,#0749ab); }.propose-hero { background: linear-gradient(120deg, #072b44, #10765d); }.business-hero { background: radial-gradient(circle at 82% 30%, #8069e8, transparent 30%), linear-gradient(120deg,#111841,#3b2a8c); }.transparency-hero { background: linear-gradient(120deg,#191f35,#3b526d); }
.filter-bar { margin-bottom: 28px; display: flex; justify-content: space-between; align-items: center; padding: 15px 18px; background: var(--soft); border-radius: 12px; }.filter-bar > span { font-weight: 700; }.filter-bar div { display: flex; gap: 6px; flex-wrap: wrap; }.filter-bar a { padding: 7px 12px; border-radius: 7px; font-size: 13px; font-weight: 600; }.filter-bar a.active { color: #fff; background: var(--blue); }
.list-stack, .event-list { display: grid; gap: 16px; }.consultation-list-item { display: grid; grid-template-columns: 104px 1fr 46px; gap: 28px; align-items: center; padding: 28px; border: 1px solid var(--line); border-radius: 16px; transition: .2s; }.consultation-list-item:hover { border-color: #aac7ed; box-shadow: var(--shadow); }
.date-tile { height: 104px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; background: var(--navy); border-radius: 13px; line-height: 1.1; }.date-tile b { font: 700 30px "Manrope"; }.date-tile span { font-size: 12px; }.date-tile small { margin-top: 9px; color: #9fb9da; text-transform: uppercase; font-size: 9px; }
.list-main h2 { margin: 10px 0 8px; font: 700 23px "Manrope"; }.list-main h2 a:hover { color: var(--blue); }.list-main p { margin: 0; color: var(--muted); }.list-facts { margin-top: 14px; display: flex; gap: 18px; flex-wrap: wrap; color: var(--muted); font-size: 12px; }.list-facts span:before { content: "•"; margin-right: 7px; color: var(--blue); }.round-arrow { display: grid; place-items: center; width: 42px; height: 42px; color: var(--blue); background: #edf4ff; border-radius: 50%; font-size: 20px; }
.detail-hero { padding: 76px 0; color: #fff; background: linear-gradient(120deg, var(--navy), #074db0); }.detail-grid { display: grid; grid-template-columns: 1fr 250px; gap: 70px; align-items: center; }.detail-hero h1 { font-size: clamp(36px,5vw,55px); }.detail-hero p { max-width: 760px; color: #cfdef2; font-size: 18px; }.deadline-panel { padding: 26px; display: flex; flex-direction: column; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); border-radius: 16px; }.deadline-panel small { color: #b7cae4; }.deadline-panel b { margin: 5px 0; font: 700 25px "Manrope"; }.deadline-panel span { color: var(--gold); font-size: 13px; }
.detail-layout { display: grid; grid-template-columns: minmax(0,1fr) 370px; gap: 70px; }.prose h2 { margin: 44px 0 14px; color: var(--navy); font: 700 26px "Manrope"; }.prose h2:first-child { margin-top: 0; }.prose p { color: #4d5b72; }.info-grid { margin-top: 34px; display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; }.info-grid div { padding: 18px; display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 12px; }.info-grid small { color: var(--muted); }.info-grid a { color: var(--blue); font-size: 13px; }.document-list { display: grid; gap: 8px; }.document-list a { display: grid; grid-template-columns: 45px 1fr 20px; align-items: center; gap: 14px; padding: 14px; border: 1px solid var(--line); border-radius: 10px; }.document-list span { display: grid; place-items: center; width: 40px; height: 40px; color: #fff; background: #d64a55; border-radius: 7px; font-size: 10px; }.count { display: inline-grid; place-items: center; width: 30px; height: 30px; color: var(--blue); background: #edf4ff; border-radius: 50%; font-size: 13px; }
.feedback-list { display: grid; gap: 12px; }.feedback-list article { padding: 20px; border: 1px solid var(--line); border-radius: 12px; }.feedback-list article > div { display: flex; justify-content: space-between; gap: 12px; }.feedback-list span { color: var(--muted); font-size: 12px; }.feedback-list blockquote { margin: 15px 0 0; padding: 14px; background: var(--soft); border-left: 3px solid var(--blue); }.feedback-list blockquote b { display: block; }
.form-card { padding: 34px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow); }.form-card h1, .form-card h2 { margin: 8px 0; font: 800 30px "Manrope"; color: var(--navy); }.form-card > p { color: var(--muted); }.sticky-form { position: sticky; top: 115px; }.sticky-form label { display: flex; flex-direction: column; gap: 6px; margin-top: 16px; font-weight: 600; font-size: 13px; }.sticky-form .btn { width: 100%; margin-top: 20px; }
input, select, textarea { width: 100%; min-height: 48px; padding: 11px 13px; color: var(--ink); background: #fff; border: 1px solid #cbd5e2; border-radius: 9px; outline: none; }.form-card input:focus, .form-card select:focus, .form-card textarea:focus, .qkb-search input:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(7,87,216,.1); } textarea { resize: vertical; }
.form-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }.form-grid.one { grid-template-columns: 1fr; }.form-grid > label:not(.check) { display: flex; flex-direction: column; gap: 6px; font-weight: 600; font-size: 13px; }.full { grid-column: 1 / -1; }.form-grid fieldset { margin: 0; padding: 18px; border: 1px solid var(--line); border-radius: 12px; }.form-grid legend { padding: 0 8px; font-weight: 700; }.check-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }.check { display: flex; align-items: flex-start; gap: 9px; font-weight: 500; }.check input { width: 17px; min-height: 17px; margin-top: 3px; }.consent { color: var(--muted); font-size: 13px; }.form-note { margin: 20px 0 0; text-align: center; }.form-note a { color: var(--blue); font-weight: 700; }.auth-page { min-height: 650px; background: var(--soft); }.form-layout { display: grid; grid-template-columns: 1.4fr .6fr; gap: 45px; align-items: start; }.form-aside { padding: 32px; border-radius: var(--radius); background: var(--soft); }.form-aside h2 { font: 800 31px/1.2 "Manrope"; color: var(--navy); }.feature-list { padding: 0; margin: 26px 0; list-style: none; }.feature-list li { padding: 12px 0 12px 28px; border-bottom: 1px solid var(--line); position: relative; }.feature-list li:before { content: "✓"; position: absolute; left: 0; color: var(--green); font-weight: 800; }.hidden { display: none !important; }
.notice-box { margin-bottom: 28px; padding: 18px 22px; display: flex; gap: 16px; color: #294267; background: #edf5ff; border-left: 4px solid var(--blue); border-radius: 9px; }.notice-box span { color: var(--muted); }.opportunity-grid.large { grid-template-columns: repeat(2,1fr); }.audience { margin-top: 20px; display: flex; flex-direction: column; padding: 13px; background: var(--soft); border-radius: 9px; }.audience small { color: var(--muted); }
.event-large { display: grid; grid-template-columns: 110px 1fr auto; gap: 30px; align-items: center; padding: 28px; border: 1px solid var(--line); border-radius: 16px; }.event-large > time { height: 110px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; background: var(--navy); border-radius: 13px; line-height: 1.1; }.event-large time b { font: 800 35px "Manrope"; }.event-large time span { color: #b9cff0; text-transform: uppercase; }.event-large time small { color: #7f9bc1; }.event-body h2 { margin: 8px 0; font: 700 23px "Manrope"; }.event-body p { margin: 0; color: var(--muted); }
.location-row { display: flex; align-items: center; gap: 14px; }.location-row span { color: var(--muted); font-size: 13px; }.number-steps { display: grid; gap: 20px; margin-top: 28px; }.number-steps > div { display: flex; gap: 14px; }.number-steps b { flex: 0 0 36px; height: 36px; display: grid; place-items: center; color: #fff; background: var(--blue); border-radius: 50%; }.number-steps span { color: var(--muted); }.number-steps strong { display: block; color: var(--navy); }
.business-layout { display: grid; grid-template-columns: 1.2fr .8fr; gap: 45px; align-items: start; }.qkb-search { padding: 28px; color: #fff; background: var(--navy); border-radius: var(--radius); }.qkb-search label { display: block; margin-bottom: 10px; font: 700 20px "Manrope"; }.qkb-search > div { display: flex; gap: 8px; }.qkb-search input { background: #fff; }.qkb-search small { display: block; margin-top: 9px; color: #9db2d2; }.lookup-result { margin-top: 16px; padding: 22px; border-radius: 12px; background: var(--soft); }.lookup-result.success { border-left: 4px solid var(--green); }.lookup-result.error { border-left: 4px solid #d64a55; }.lookup-result h2 { margin: 0; font: 700 22px "Manrope"; }.privacy-panel { margin-top: 40px; }.privacy-panel h2 { font: 800 30px "Manrope"; }.privacy-levels { display: grid; gap: 10px; }.privacy-levels article { display: flex; gap: 18px; padding: 18px; border: 1px solid var(--line); border-radius: 12px; }.privacy-levels article > span { color: var(--blue); font: 800 20px "Manrope"; }.privacy-levels p { margin: 4px 0 0; color: var(--muted); }.business-aside { background: #f1efff; }
.company-result { margin-top: 22px; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow); }.company-result-head { padding: 26px; display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; color: #fff; background: linear-gradient(120deg,var(--navy),#174f92); }.company-result-head .eyebrow { color: #9dc8ff; }.company-result-head h2 { margin: 7px 0 0; font: 800 29px "Manrope"; }.company-result-head p { margin: 2px 0 0; color: #c8d9ef; }.company-facts { margin: 0; padding: 22px; display: grid; grid-template-columns: repeat(2,1fr); gap: 0; }.company-facts > div { padding: 14px; border-bottom: 1px solid var(--line); }.company-facts dt { color: var(--muted); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }.company-facts dd { margin: 5px 0 0; color: var(--navy); font-weight: 700; }.company-facts ul { margin: 0; padding-left: 18px; }.company-facts .activity-object { max-height: 260px; overflow: auto; color: #46556d; font-weight: 400; white-space: normal; }.registry-meta { padding: 0 35px 18px; color: var(--muted); font-size: 11px; }.extract-panel { padding: 24px; display: grid; gap: 20px; background: var(--soft); border-top: 1px solid var(--line); }.extract-panel h3 { margin: 0; font: 700 20px "Manrope"; }.extract-panel p { margin: 3px 0 0; color: var(--muted); }.extract-actions { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }.extract-actions > div { display: flex; flex-direction: column; gap: 6px; }.extract-actions .btn { width: 100%; padding-inline: 10px; font-size: 12px; }.download-link { color: var(--blue); text-align: center; font-size: 11px; font-weight: 700; }.extract-login { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.empty-state { padding: 35px; text-align: center; color: var(--muted); background: var(--soft); border-radius: 14px; }.empty-state.large { padding: 80px 30px; }.empty-state h1, .empty-state h2 { color: var(--navy); font-family: "Manrope"; }.empty-state a:not(.btn) { color: var(--blue); font-weight: 700; }.document-table { display: grid; gap: 8px; }.document-table a { display: grid; grid-template-columns: 100px 1fr 250px 30px; gap: 15px; align-items: center; padding: 17px 20px; border: 1px solid var(--line); border-radius: 10px; }.document-table span { color: var(--blue); font-weight: 700; }.document-table small { color: var(--muted); }
.legal-hero { position: relative; overflow: hidden; padding: 66px 0 74px; color: #fff; background: radial-gradient(circle at 88% 20%, rgba(255,213,79,.35), transparent 24%), radial-gradient(circle at 16% 78%, rgba(47,145,255,.45), transparent 28%), linear-gradient(120deg, #071b42, #2f5bd1); }
.legal-hero:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px); background-size: 56px 56px; mask-image: linear-gradient(90deg, #000, transparent 85%); }
.legal-hero-grid { position: relative; display: grid; grid-template-columns: minmax(0,1fr) 330px; gap: 70px; align-items: center; }
.legal-hero h1 { max-width: 980px; margin: 14px 0 18px; color: #fff; font: 800 clamp(42px,5vw,72px)/1.05 "Manrope"; letter-spacing: -.04em; }
.legal-hero p { max-width: 920px; margin: 0; color: #d9e7ff; font-size: 20px; line-height: 1.65; }
.legal-chips { margin-top: 26px; display: flex; gap: 10px; flex-wrap: wrap; }
.legal-chips span { padding: 9px 13px; color: #fff; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); border-radius: 999px; font-size: 12px; font-weight: 800; }
.legal-hero-card { padding: 26px; display: grid; gap: 12px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); border-radius: 22px; box-shadow: 0 24px 70px rgba(0,0,0,.18); backdrop-filter: blur(10px); }
.legal-hero-card b { font: 800 24px "Manrope"; }
.legal-hero-card span { color: #dce9ff; line-height: 1.6; }
.legal-hero-card small { padding-top: 14px; border-top: 1px solid rgba(255,255,255,.18); color: #bcd0f3; }
.legal-page { padding: 52px 0 90px; background: linear-gradient(#fff, #f8fbff); }
.legal-layout { display: grid; grid-template-columns: 260px minmax(0,1fr); gap: 28px; align-items: start; }
.legal-toc { position: sticky; top: 112px; padding: 20px; display: grid; gap: 9px; background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 18px 50px rgba(7,27,66,.07); }
.legal-toc b { color: var(--navy); font: 800 15px "Manrope"; }
.legal-toc a { padding: 9px 10px; color: #536079; background: var(--soft); border-radius: 10px; font-size: 12px; font-weight: 700; }
.legal-toc a:hover { color: var(--blue); background: #eaf2ff; }
.legal-card { width: min(980px, 100%); padding: 12px 42px 38px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 22px 70px rgba(7,27,66,.08); }
.legal-card article { scroll-margin-top: 120px; padding: 28px 0; display: grid; grid-template-columns: 54px 1fr; gap: 22px; border-bottom: 1px solid var(--line); }
.legal-card article > span { width: 44px; height: 44px; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg,var(--navy),var(--blue)); border-radius: 14px; font: 800 13px "Manrope"; }
.legal-card article:last-of-type { border-bottom: 0; }
.legal-card h2 { margin: 0 0 10px; color: var(--navy); font: 800 25px "Manrope"; }
.legal-card p { margin: 0; color: #4d5b72; font-size: 16px; line-height: 1.75; }
.legal-note { margin-top: 18px; padding: 22px; background: #edf5ff; border-left: 4px solid var(--blue); border-radius: 14px; }
.legal-note b { color: var(--navy); font: 800 17px "Manrope"; }
.legal-note p { margin: 6px 0 0; color: #4d5b72; }
.profile-head, .admin-head { padding: 60px 0; color: #fff; background: linear-gradient(120deg,var(--navy),var(--blue)); }.profile-head .container, .admin-head .container { display: flex; align-items: center; justify-content: space-between; }.profile-head h1, .admin-head h1 { margin: 10px 0; font-size: 44px; }.profile-head p, .admin-head p { color: #cbdcf2; }.dashboard-grid { display: grid; grid-template-columns: 290px 1fr; gap: 35px; align-items: start; }.profile-card { padding: 28px; text-align: center; border: 1px solid var(--line); border-radius: 16px; }.avatar { width: 80px; height: 80px; margin: 0 auto 15px; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg,var(--blue),var(--purple)); border-radius: 50%; font: 800 29px "Manrope"; }.profile-card h2 { margin: 5px 0; }.profile-card h3 { margin-top: 30px; text-align: left; font-size: 14px; }.tag-list { display: flex; flex-wrap: wrap; gap: 6px; }.tag-list span { padding: 5px 9px; color: var(--blue); background: #edf4ff; border-radius: 30px; font-size: 11px; }.dashboard-main { display: grid; gap: 25px; }.dash-section { padding: 25px; border: 1px solid var(--line); border-radius: 16px; }.tracking-row { padding: 14px 0; display: flex; justify-content: space-between; align-items: center; gap: 15px; border-top: 1px solid var(--line); }.tracking-row h3 { margin: 3px 0; font: 700 16px "Manrope"; }.tracking-row div > span, .tracking-row small { color: var(--muted); font-size: 11px; }
.admin-head { background: #0a1730; }.admin-user { display: flex; flex-direction: column; text-align: right; }.admin-user small { color: #91a5c2; }.admin-page { background: #f3f6fa; }.stat-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 12px; margin-top: -65px; margin-bottom: 25px; }.stat-grid article { padding: 21px; display: flex; flex-direction: column; background: #fff; border-radius: 13px; box-shadow: 0 10px 30px rgba(7,27,66,.08); }.stat-grid span, .stat-grid small { color: var(--muted); font-size: 11px; }.stat-grid b { font: 800 34px "Manrope"; color: var(--navy); }.admin-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }.admin-panel { padding: 24px; background: #fff; border: 1px solid #e3e8ef; border-radius: 15px; }.admin-panel.wide { grid-column: 1 / -1; }.panel-head { margin-bottom: 20px; display: flex; justify-content: space-between; align-items: center; }.panel-head h2 { margin: 0; font: 700 20px "Manrope"; }.panel-head span { color: var(--muted); font-size: 12px; }.panel-head a { color: var(--blue); font-size: 13px; font-weight: 700; }.admin-table { display: grid; }.admin-table > div { display: grid; grid-template-columns: 90px 1.8fr 1fr 100px 90px; align-items: center; gap: 10px; padding: 13px 0; border-top: 1px solid var(--line); font-size: 12px; }.admin-table small, .admin-table time { color: var(--muted); }.activity-list { display: grid; }.activity-list article { display: grid; grid-template-columns: 36px 1fr auto; gap: 12px; align-items: center; padding: 12px 0; border-top: 1px solid var(--line); }.activity-list article > span { width: 34px; height: 34px; display: grid; place-items: center; color: var(--blue); background: #edf4ff; border-radius: 8px; font-size: 10px; font-weight: 800; }.activity-list div { min-width: 0; }.activity-list b { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 13px; }.activity-list small { color: var(--muted); font-size: 10px; }
.admin-create summary { display: flex; justify-content: space-between; align-items: center; cursor: pointer; color: var(--navy); font: 700 20px "Manrope"; }.admin-create summary span { display: grid; place-items: center; width: 34px; height: 34px; color: #fff; background: var(--blue); border-radius: 50%; }.admin-create[open] summary { margin-bottom: 24px; }.admin-form { padding-top: 20px; border-top: 1px solid var(--line); }.admin-actions-list details { border-top: 1px solid var(--line); }.admin-actions-list summary { display: grid; grid-template-columns: 36px 1fr auto; gap: 12px; align-items: center; padding: 12px 0; cursor: pointer; list-style: none; }.admin-actions-list summary::-webkit-details-marker { display: none; }.admin-actions-list summary > span { width: 34px; height: 34px; display: grid; place-items: center; color: var(--blue); background: #edf4ff; border-radius: 8px; font-size: 10px; font-weight: 800; }.admin-actions-list form { padding: 0 0 16px 48px; display: grid; gap: 8px; }.admin-actions-list textarea, .admin-actions-list select { min-height: 38px; font-size: 12px; }
.registry-layout { display: grid; grid-template-columns: 310px 1fr; gap: 20px; align-items: start; }.registry-sidebar { position: sticky; top: 115px; }.registry-sidebar h2 { margin: 0 0 6px; font: 700 20px "Manrope"; }.registry-sidebar p { margin: 0 0 18px; color: var(--muted); font-size: 13px; }.registry-sidebar hr { margin: 26px 0; border: 0; border-top: 1px solid var(--line); }.stack-form { display: grid; gap: 12px; }.stack-form label { display: grid; gap: 5px; font-size: 12px; font-weight: 700; }.registry-list { display: grid; gap: 10px; }.registry-list > a { padding: 18px; display: grid; grid-template-columns: minmax(240px,1.5fr) 1fr auto; gap: 20px; align-items: center; border: 1px solid var(--line); border-radius: 12px; transition: .2s; }.registry-list > a:hover { border-color: #a9c5eb; box-shadow: 0 9px 25px rgba(7,27,66,.08); }.registry-list h3 { margin: 4px 0 2px; font: 700 17px "Manrope"; }.registry-list p { margin: 0; color: var(--muted); font-size: 12px; }.registry-code { color: var(--blue); font-size: 11px; font-weight: 800; letter-spacing: .06em; }.registry-facts { display: flex; flex-direction: column; color: var(--muted); font-size: 11px; }.registry-list > a > div:last-child { display: flex; flex-direction: column; gap: 5px; align-items: flex-end; }.record-summary { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-top: -65px; margin-bottom: 20px; }.record-summary article { padding: 19px; display: flex; flex-direction: column; background: #fff; border-radius: 13px; box-shadow: 0 10px 30px rgba(7,27,66,.08); }.record-summary small { color: var(--muted); }.record-summary b { margin-top: 4px; color: var(--navy); }.registry-detail { align-items: start; }.record-data { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; margin: 0 0 20px; background: var(--line); border: 1px solid var(--line); }.record-data > div { padding: 14px; background: #fff; }.record-data dt { color: var(--muted); font-size: 10px; font-weight: 700; text-transform: uppercase; }.record-data dd { margin: 5px 0 0; }.record-data ul { margin: 0; padding-left: 18px; }.compact-list { display: grid; margin-bottom: 20px; }.compact-list article { padding: 12px 0; display: flex; flex-direction: column; border-top: 1px solid var(--line); }.compact-list article > span:not(.status), .compact-list small { color: var(--muted); font-size: 11px; }.timeline { display: grid; margin-bottom: 20px; }.timeline article { display: grid; grid-template-columns: 150px 1fr; gap: 22px; padding: 15px 0; border-top: 1px solid var(--line); }.timeline time, .timeline small { color: var(--muted); font-size: 11px; }.timeline p { margin: 4px 0; }.campaign-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }.campaign-grid article { padding: 18px; border: 1px solid var(--line); border-radius: 12px; }.campaign-grid h3 { margin: 12px 0 6px; font: 700 17px "Manrope"; }.campaign-grid p, .campaign-grid small { color: var(--muted); font-size: 12px; }.campaign-grid form { margin-top: 12px; }.consent-table { display: grid; }.consent-table article { padding: 14px 0; display: grid; grid-template-columns: 1.2fr 1fr auto 1fr auto; gap: 14px; align-items: center; border-top: 1px solid var(--line); }.consent-table article > div { display: flex; flex-direction: column; }.consent-table small { color: var(--muted); }.consent-table form { display: flex; gap: 5px; }.registry-shortcuts { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }.registry-shortcuts a { padding: 20px; display: flex; flex-direction: column; color: #fff; background: linear-gradient(135deg,var(--navy),var(--blue)); border-radius: 12px; }.registry-shortcuts span { color: #c9dcf5; font-size: 12px; }.consent-field { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }.consent-field > p, .consent-field > .full { grid-column: 1 / -1; }.status-pending_consent, .status-action_required, .status-overdue { background: #fff2d3; color: #91650a; }.status-priority { background: #eee8ff; color: #6040b0; }.status-volunteer, .status-community_contact { background: #e8edff; color: #3c54ac; }.filter-form { display: grid; grid-template-columns: 1.4fr repeat(3,1fr) auto; gap: 8px; margin-bottom: 22px; }.filter-form input, .filter-form select { min-width: 0; }
.settings-divider { margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--line); }.queue-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 20px; }.queue-grid article { padding: 18px; display: flex; flex-direction: column; background: var(--soft); border-radius: 12px; }.queue-grid b { font: 800 30px "Manrope"; color: var(--navy); }.queue-grid span { color: var(--muted); font-size: 12px; }.registry-campaign { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--line); }.campaign-grid.single { grid-template-columns: 1fr; }
.import-report { margin-bottom: 22px; padding: 18px; border: 1px solid #f1c7a8; border-left: 4px solid #e58a1f; border-radius: 12px; background: #fff8ed; }
.import-report h2 { margin: 0 0 6px; font: 800 20px "Manrope"; color: var(--navy); }
.import-report p { margin: 0 0 12px; color: var(--muted); }
.import-errors > div { grid-template-columns: 90px 170px 1fr; }
.import-errors > div:first-child { color: var(--navy); font-weight: 800; }
.user-admin-list { display: grid; gap: 10px; }
.user-admin-row { border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.user-admin-row summary { padding: 16px; display: grid; grid-template-columns: 1fr auto minmax(160px,auto); gap: 16px; align-items: center; cursor: pointer; list-style: none; }
.user-admin-row summary::-webkit-details-marker { display: none; }
.user-admin-row h3 { margin: 4px 0 2px; font: 700 17px "Manrope"; }
.user-admin-row p { margin: 0; color: var(--muted); font-size: 12px; }
.user-admin-row > form { margin: 0 16px 16px; }
.notification-summary { grid-template-columns: repeat(5,1fr); }.settings-tabs-panel { padding: 0; overflow: hidden; }.settings-tabs { display: flex; gap: 6px; padding: 12px; overflow-x: auto; background: #f8fbff; border-bottom: 1px solid var(--line); }.settings-tabs button { padding: 12px 18px; color: var(--navy); background: transparent; border: 1px solid transparent; border-radius: 999px; font-weight: 800; cursor: pointer; white-space: nowrap; }.settings-tabs button.active { color: #fff; background: linear-gradient(135deg,var(--navy),var(--blue)); box-shadow: 0 8px 20px rgba(7,27,66,.12); }.settings-tab-form { padding: 24px; }.settings-tab-content { display: none; }.settings-tab-content.active { display: block; }.settings-tab-content .admin-form { padding-top: 18px; }.settings-actions { margin-top: 24px; padding-top: 18px; display: flex; justify-content: flex-end; border-top: 1px solid var(--line); }.settings-external-actions { padding: 0 24px 24px; }.settings-queue-grid { grid-template-columns: repeat(5,1fr); margin-top: 18px; }
.queue-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.registry-shortcuts { grid-template-columns: repeat(5,1fr); }
.registry-shortcuts.compact { grid-template-columns: repeat(2,1fr); }
.registry-shortcuts.communication-shortcuts { grid-template-columns: 1fr; }
.registry-shortcuts a { min-height: 112px; justify-content: center; transition: transform .2s ease, box-shadow .2s ease; }
.registry-shortcuts a:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(7,27,66,.18); }
.admin-module-group .panel-head { padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.calendar-layout { align-items: start; }.planning-calendar-panel { overflow-x: auto; }.calendar-toolbar { text-align: center; }.planning-calendar { min-width: 860px; display: grid; grid-template-columns: repeat(7, minmax(0,1fr)); gap: 8px; }.calendar-weekday { padding: 10px; color: var(--muted); font-size: 11px; font-weight: 800; text-align: center; text-transform: uppercase; letter-spacing: .05em; }.calendar-day { min-height: 132px; padding: 10px; display: flex; flex-direction: column; gap: 8px; text-align: left; background: #fff; border: 1px solid var(--line); border-radius: 14px; cursor: pointer; transition: .2s; }.calendar-day:hover { border-color: #9bb7e6; box-shadow: 0 10px 24px rgba(7,27,66,.08); transform: translateY(-1px); }.calendar-day.muted { background: #f7f9fc; color: #8a96aa; }.calendar-day.today { border-color: var(--blue); box-shadow: inset 0 0 0 1px var(--blue); }.calendar-date { width: 30px; height: 30px; display: grid; place-items: center; color: var(--navy); background: #edf4ff; border-radius: 50%; font-weight: 800; }.calendar-day.today .calendar-date { color: #fff; background: var(--blue); }.calendar-items { display: grid; gap: 5px; }.calendar-item { padding: 6px 7px; display: block; overflow: hidden; color: #123; background: #eef5ff; border-left: 3px solid var(--blue); border-radius: 8px; font-size: 11px; font-style: normal; white-space: nowrap; text-overflow: ellipsis; }.calendar-item b { color: var(--blue); }.calendar-item-campaign { background: #fff6df; border-left-color: #e58a1f; }.calendar-item-campaign b { color: #9a5a0f; }.calendar-items em { color: var(--muted); font-size: 11px; font-style: normal; }.planning-shortcuts { display: grid; gap: 10px; }.planning-shortcuts a { padding: 16px; display: flex; justify-content: space-between; gap: 14px; align-items: center; color: var(--navy); background: var(--soft); border: 1px solid var(--line); border-radius: 12px; }.planning-shortcuts a:hover { border-color: #aac2e8; }.planning-shortcuts span { color: var(--muted); font-size: 12px; }.planning-agenda { display: grid; gap: 10px; }.agenda-row { padding: 14px; display: grid; grid-template-columns: 64px 1fr auto; gap: 16px; align-items: center; color: inherit; background: #fff; border: 1px solid var(--line); border-radius: 13px; }.agenda-row:hover { border-color: #aac2e8; box-shadow: 0 8px 20px rgba(7,27,66,.06); }.agenda-row time { width: 58px; height: 58px; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg,var(--navy),var(--blue)); border-radius: 13px; }.agenda-row time b { margin-bottom: -9px; font: 800 24px "Manrope"; }.agenda-row time span { color: #cddbf4; font-size: 11px; text-transform: uppercase; }.agenda-row h3 { margin: 2px 0; font: 700 16px "Manrope"; }.agenda-row p, .agenda-row small { margin: 0; color: var(--muted); font-size: 12px; }.agenda-campaign time { background: linear-gradient(135deg,#6d3c00,#e58a1f); }
.staff-assignment-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }.staff-assignment-grid article { position: relative; padding: 18px; border: 1px solid var(--line); border-radius: 14px; background: #fff; }.staff-assignment-grid h3 { margin: 4px 0 2px; font: 800 18px "Manrope"; color: var(--navy); }.staff-assignment-grid p { color: var(--muted); font-size: 12px; }.staff-assignment-grid dl { display: grid; gap: 1px; margin: 14px 0; background: var(--line); border: 1px solid var(--line); }.staff-assignment-grid dl div { padding: 9px; background: var(--soft); }.staff-assignment-grid dt { color: var(--muted); font-size: 10px; font-weight: 800; text-transform: uppercase; }.staff-assignment-grid dd { margin: 3px 0 0; font-size: 12px; }.staff-assignment-grid .status { position: absolute; top: 16px; right: 16px; }.staff-activity-table > div { grid-template-columns: 90px 1.5fr 1fr 95px 115px; }
.campaign-summary { grid-template-columns: repeat(5,1fr); }
.campaign-audiences { display: grid; grid-template-columns: repeat(5,1fr); gap: 10px; }
.campaign-audiences a { min-height: 105px; padding: 18px; display: flex; flex-direction: column; justify-content: center; color: #fff; background: linear-gradient(135deg,var(--navy),var(--blue)); border-radius: 12px; }
.campaign-audiences span { margin-top: 5px; color: #c9dcf5; font-size: 11px; }
.campaign-queue { grid-template-columns: repeat(3,1fr); margin: 0; }
.information-links { display: grid; grid-template-columns: repeat(4,1fr); gap: 9px; }
.information-links a { padding: 15px; display: flex; flex-direction: column; background: var(--soft); border-radius: 10px; }
.information-links b { color: var(--navy); font: 800 25px "Manrope"; }.information-links span { color: var(--muted); font-size: 11px; }
.campaign-filter { display: grid; grid-template-columns: 1.6fr repeat(3,1fr) auto; gap: 8px; margin-bottom: 24px; }
.campaign-register { display: grid; gap: 10px; }
.campaign-register article { padding: 17px; display: grid; grid-template-columns: minmax(280px,1.7fr) minmax(180px,.7fr) minmax(165px,.55fr); gap: 20px; align-items: center; border: 1px solid var(--line); border-radius: 12px; }
.campaign-register h3 { margin: 3px 0; font: 700 17px "Manrope"; }.campaign-register p { margin: 0; color: var(--muted); font-size: 12px; }
.campaign-metrics, .campaign-state { display: flex; flex-direction: column; gap: 4px; color: var(--muted); font-size: 11px; }
.campaign-state { align-items: flex-end; }.campaign-state a { color: var(--blue); font-weight: 700; }.campaign-state form { margin-top: 4px; }
.metric-error { color: #b4233c; font-weight: 700; }
.map-admin-page { padding-top: 32px; }
.map-container { width: min(1480px, calc(100% - 32px)); }
.map-admin-page .admin-panel { padding: 16px; }
.registry-map { position: relative; z-index: 0; isolation: isolate; width: 100%; height: min(760px, calc(100vh - 235px)); min-height: 620px; border: 1px solid var(--line); border-radius: 16px; overflow: hidden; background: var(--soft); }
.coordinate-picker { position: relative; z-index: 0; isolation: isolate; width: 100%; height: 440px; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; background: var(--soft); }
.leaflet-container { z-index: 0; }
.coordinate-picker .leaflet-control-layers { color: var(--navy); border: 0; border-radius: 9px; box-shadow: 0 4px 16px rgba(7,27,66,.2); }
.coordinate-picker .leaflet-control-layers-expanded { width: 230px; padding: 10px 12px; }
.coordinate-picker .leaflet-control-layers label { margin: 0; display: block; font-size: 12px; line-height: 1.35; }
.coordinate-picker .leaflet-control-layers-selector { position: static; width: 15px; height: 15px; min-height: 0; margin: 0 7px 0 0; padding: 0; vertical-align: -2px; accent-color: var(--blue); box-shadow: none; }
.coordinate-picker .leaflet-control-layers-toggle { width: 38px; height: 38px; background-size: 22px 22px; }
.map-branding { display: flex; align-items: center; gap: 8px; padding: 6px 8px; background: rgba(255,255,255,.88); border-radius: 10px; box-shadow: 0 4px 16px rgba(7,27,66,.18); }
.map-branding img { height: 42px; width: auto; object-fit: contain; }
.map-help { margin: 12px 2px 0; color: var(--muted); font-size: 12px; }
.registry-map .leaflet-control-layers { color: var(--navy); border: 0; border-radius: 10px; box-shadow: 0 4px 18px rgba(7,27,66,.22); }
.registry-map .leaflet-control-layers-expanded { width: 275px; max-height: min(560px, calc(100vh - 270px)); padding: 12px 14px; overflow-y: auto; }
.registry-map .leaflet-control-layers-base, .registry-map .leaflet-control-layers-overlays { display: grid; gap: 3px; }
.registry-map .leaflet-control-layers label { margin: 0; display: block; font-size: 12px; line-height: 1.35; }
.registry-map .leaflet-control-layers-selector { position: static; width: 15px; height: 15px; min-height: 0; margin: 0 7px 0 0; padding: 0; vertical-align: -2px; accent-color: var(--blue); box-shadow: none; }
.registry-map .leaflet-control-layers-toggle { width: 38px; height: 38px; background-size: 22px 22px; }
.map-territory-button { width: 34px; height: 34px; padding: 0; cursor: pointer; color: var(--navy); background: #fff; border: 0; font-size: 22px; font-weight: 800; line-height: 34px; }
.map-territory-button:hover { color: var(--blue); background: #f4f7fb; }
.map-fullscreen-button { width: 34px; height: 34px; padding: 0; cursor: pointer; color: var(--navy); background: #fff; border: 0; font-size: 22px; font-weight: 700; line-height: 34px; }
.map-fullscreen-button:hover { color: var(--blue); background: #f4f7fb; }
.registry-map:fullscreen, .coordinate-picker:fullscreen { width: 100vw; height: 100vh; min-height: 100vh; border: 0; border-radius: 0; background: #fff; }
.registry-map.map-is-fullscreen, .coordinate-picker.map-is-fullscreen { z-index: 5000; }
.map-legend { margin-top: 14px; display: flex; gap: 10px; flex-wrap: wrap; }
.map-legend span { padding: 8px 12px; background: var(--soft); border-radius: 999px; color: var(--muted); font-size: 12px; }
.map-legend b { color: var(--navy); }

/* Layout refinements */
body { min-height: 100vh; overflow-x: hidden; }
main { min-height: calc(100vh - 280px); }
::selection { color: var(--navy); background: rgba(7,87,216,.16); }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, summary:focus-visible { outline: 3px solid rgba(7,87,216,.26); outline-offset: 2px; }
.site-header { box-shadow: 0 10px 30px rgba(7,27,66,.05); }
.brand, .nav-actions { flex-shrink: 0; }
.main-nav { min-width: 0; }
.nav-dropdown { animation: dropdownIn .16s ease both; }
@keyframes dropdownIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.nav-dropdown-admin { width: 380px; gap: 2px 4px; overscroll-behavior: contain; }
.nav-dropdown-admin a:not(:first-child) { min-height: 40px; justify-content: center; }
.page-hero, .detail-hero, .profile-head, .admin-head { position: relative; overflow: hidden; }
.page-hero:before, .admin-head:before { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .1; background-image: linear-gradient(rgba(255,255,255,.16) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.16) 1px, transparent 1px); background-size: 54px 54px; mask-image: linear-gradient(90deg, #000, transparent 86%); }
.page-hero .container, .detail-hero .container, .profile-head .container, .admin-head .container { position: relative; z-index: 1; }
.admin-head { padding: 58px 0 82px; background: radial-gradient(circle at 86% 18%, rgba(47,145,255,.32), transparent 28%), linear-gradient(120deg,#071b42,#0a1730); }
.admin-page { background: linear-gradient(180deg,#f3f6fa 0,#fff 100%); }
.admin-panel, .form-card, .legal-card, .company-result { box-shadow: 0 18px 50px rgba(7,27,66,.08); }
.admin-panel { transition: border-color .2s ease, box-shadow .2s ease; }
.admin-panel:hover { border-color: #d0dbea; box-shadow: 0 22px 55px rgba(7,27,66,.1); }
.panel-head { gap: 18px; }
.panel-head > div { min-width: 0; }
.panel-head h2 { letter-spacing: -.015em; }
.admin-create + .admin-create { margin-top: 18px; }
.admin-create summary, .user-admin-row summary { border-radius: 12px; }
.admin-create summary:hover, .user-admin-row summary:hover { color: var(--blue); }
.admin-form { margin-top: 14px; }
.stat-grid article, .record-summary article, .queue-grid article { border: 1px solid rgba(220,227,237,.8); transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.stat-grid article:hover, .record-summary article:hover, .queue-grid article:hover, .content-card:hover, .opportunity-card:hover, .planning-shortcuts a:hover, .agenda-row:hover { transform: translateY(-3px); box-shadow: 0 18px 45px rgba(7,27,66,.1); }
.registry-list > a, .planning-shortcuts a, .agenda-row, .campaign-register article, .staff-assignment-grid article { background: #fff; }
.registry-list > a:hover, .campaign-register article:hover, .staff-assignment-grid article:hover { border-color: #aac2e8; box-shadow: 0 14px 34px rgba(7,27,66,.08); }
.registry-shortcuts a { position: relative; overflow: hidden; }
.registry-shortcuts a:after, .campaign-audiences a:after { content: ""; position: absolute; inset: auto -35% -65% 35%; height: 110px; opacity: .22; background: #fff; border-radius: 50%; transform: rotate(-10deg); }
.registry-shortcuts a b, .registry-shortcuts a span, .campaign-audiences a b, .campaign-audiences a span { position: relative; z-index: 1; }
.filter-form, .campaign-filter { align-items: end; }
.stack-form .btn, .filter-form .btn, .campaign-filter .btn { min-height: 48px; }
.form-grid fieldset { background: #fbfdff; }
input[type="file"] { padding: 10px; background: #fff; }
.legal-card, .form-card, .admin-panel { scroll-margin-top: 120px; }

@media (max-width: 1050px) {
  .brand { min-width: 245px; }.main-nav { gap: 1px; }.nav-home, .nav-group-toggle { padding-inline: 9px; font-size: 12px; }.nav-actions .btn { display: none; }.nav-dropdown-admin { width: min(360px, calc(100vw - 40px)); }
  .registry-shortcuts { grid-template-columns: repeat(3,1fr); }.registry-shortcuts.compact { grid-template-columns: repeat(2,1fr); }
  .campaign-audiences { grid-template-columns: repeat(3,1fr); }.campaign-filter { grid-template-columns: 1fr 1fr; }.campaign-register article { grid-template-columns: 1fr 1fr; }.campaign-state { grid-column: 1 / -1; align-items: flex-start; }
  .hero-grid { grid-template-columns: 1fr 430px; gap: 30px; }.quick-grid { grid-template-columns: repeat(2,1fr); }.stat-grid { grid-template-columns: repeat(3,1fr); }
}

@media (max-width: 820px) {
  .eu-line-links { display: none; }.nav-wrap { min-height: 70px; }.brand { margin-right: auto; }.menu-toggle { display: inline-flex; }.nav-actions { margin-left: auto; }
  .main-nav { display: none; position: absolute; left: 20px; right: 20px; top: 70px; max-height: calc(100vh - 105px); overflow-y: auto; padding: 10px; flex-direction: column; align-items: stretch; gap: 3px; background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow); }.main-nav.open { display: flex; }.nav-home { display: flex; }.nav-group-toggle { width: 100%; justify-content: space-between; padding: 12px; }.nav-dropdown, .nav-dropdown-wide, .nav-dropdown-admin { position: static; width: auto; max-height: none; margin: 2px 5px 8px; padding: 5px; grid-template-columns: 1fr; background: var(--soft); border: 0; border-radius: 10px; box-shadow: none; }.nav-dropdown:before { display: none; }.nav-dropdown-admin a:first-child, .nav-dropdown-label { grid-column: auto; }.nav-dropdown a { padding: 10px; }.nav-dropdown-label { margin-top: 4px; }.nav-actions { gap: 3px; }
  .hero-grid { grid-template-columns: 1fr; padding-bottom: 90px; }.hero-copy { padding: 70px 0 20px; }.journey-card { max-width: 550px; width: 100%; }.quick-section { margin-top: -50px; }
  .card-grid, .opportunity-grid, .opportunity-grid.large { grid-template-columns: 1fr 1fr; }.split-feature, .form-layout, .business-layout { grid-template-columns: 1fr; gap: 35px; }.footer-grid { grid-template-columns: 1fr 1fr; }.detail-layout { grid-template-columns: 1fr; }.sticky-form { position: static; }.detail-grid { grid-template-columns: 1fr; gap: 25px; }.deadline-panel { max-width: 320px; }
  .dashboard-grid { grid-template-columns: 1fr; }.profile-card { text-align: left; }.avatar { margin-left: 0; }.admin-head { padding: 46px 0 66px; }.admin-table > div { grid-template-columns: 90px 1fr 90px; }.admin-table small, .admin-table strong { display: none; }.document-table a { grid-template-columns: 90px 1fr 20px; }.document-table small { display: none; }.registry-layout { grid-template-columns: 1fr; }.registry-sidebar { position: static; }.campaign-grid, .staff-assignment-grid { grid-template-columns: 1fr 1fr; }.consent-table article { grid-template-columns: 1fr 1fr auto; }.consent-table article form { grid-column: 1 / -1; }.registry-shortcuts { grid-template-columns: repeat(2,1fr); }.filter-form { grid-template-columns: 1fr 1fr; }.user-admin-row summary { grid-template-columns: 1fr; align-items: start; }
  .legal-hero-grid { grid-template-columns: 1fr; gap: 30px; }.legal-layout { grid-template-columns: 1fr; }.legal-toc { position: static; }.legal-card { padding: 8px 26px 30px; }
  .campaign-summary { grid-template-columns: 1fr 1fr; }.campaign-audiences, .information-links { grid-template-columns: 1fr 1fr; }.campaign-register article { grid-template-columns: 1fr; }.campaign-state { grid-column: auto; }
  .map-container { width: min(100% - 20px, 1480px); }.map-admin-page .admin-panel { padding: 9px; }.registry-map { height: 68vh; min-height: 500px; }.registry-map .leaflet-control-layers-expanded { max-width: 245px; max-height: 55vh; }
}

@media (max-width: 600px) {
  .container { width: min(100% - 28px, 1180px); }.nav-actions .text-link, .nav-actions .text-button { display: none; }.brand { min-width: 0; gap: 7px; }.brand span { display: none; }.brand .municipality-logo { width: 54px; height: 40px; }.brand .eu-emblem { width: 42px; height: 28px; }.brand-divider { height: 30px; }.menu-toggle span { display: none; }.main-nav { left: 14px; right: 14px; }.lang-switch a { padding-inline: 8px; }
  .hero { min-height: auto; }.hero-grid { min-height: auto; }.hero h1 { font-size: 43px; }.hero-copy > p { font-size: 16px; }.hero-actions { flex-direction: column; align-items: stretch; }.trust-row { gap: 12px; flex-wrap: wrap; }.trust-row span { flex: 1; min-width: 90px; }
  .journey-card { padding: 18px; }.journey-map { height: 220px; }.quick-grid { grid-template-columns: 1fr; }.quick-card { min-height: 92px; }
  .section, .page-section { padding: 68px 0; }.section-head { align-items: start; flex-direction: column; }.card-grid, .opportunity-grid, .opportunity-grid.large { grid-template-columns: 1fr; }.cta-inner { align-items: flex-start; flex-direction: column; }.footer-grid { grid-template-columns: 1fr; gap: 35px; }.footer-bottom { flex-direction: column; }
  .filter-bar { align-items: flex-start; flex-direction: column; }.consultation-list-item { grid-template-columns: 74px 1fr; gap: 15px; padding: 18px; }.date-tile { width: 74px; height: 82px; }.round-arrow { display: none; }.list-facts { gap: 7px; flex-direction: column; }
  .legal-hero { padding: 48px 0 54px; }.legal-hero h1 { font-size: 42px; }.legal-hero p { font-size: 16px; }.legal-hero-card { padding: 20px; }.legal-card article { grid-template-columns: 1fr; gap: 12px; }.legal-card article > span { width: 38px; height: 38px; }.legal-card h2 { font-size: 22px; }
  .detail-hero { padding: 55px 0; }.detail-hero h1 { font-size: 36px; }.info-grid { grid-template-columns: 1fr; }.form-card { padding: 22px; }.form-grid { grid-template-columns: 1fr; }.full { grid-column: auto; }.check-grid { grid-template-columns: 1fr 1fr; }.notice-box { flex-direction: column; }
  .event-large { grid-template-columns: 80px 1fr; padding: 18px; gap: 16px; }.event-large > time { height: 85px; }.event-large form { grid-column: 1 / -1; }.event-large form .btn { width: 100%; }
  .qkb-search > div { flex-direction: column; }.company-facts { grid-template-columns: 1fr; }.extract-actions { grid-template-columns: 1fr; }.extract-login { align-items: flex-start; flex-direction: column; }.profile-head .container, .admin-head .container { align-items: flex-start; flex-direction: column; }.profile-head h1, .admin-head h1 { font-size: 34px; }.stat-grid, .record-summary, .notification-summary { grid-template-columns: 1fr; margin-top: -35px; }.settings-queue-grid { grid-template-columns: 1fr; margin-top: 18px; }.admin-grid { grid-template-columns: 1fr; }.admin-panel { padding: 18px; }.admin-panel.wide { grid-column: auto; }.panel-head { align-items: flex-start; flex-direction: column; }.admin-table > div { grid-template-columns: 75px 1fr; }.admin-table time { display: none; }.activity-list article { grid-template-columns: 36px 1fr; }.activity-list i { grid-column: 2; }.document-table a { grid-template-columns: 1fr 20px; }.document-table span { grid-column: 1; font-size: 11px; }.registry-list > a { grid-template-columns: 1fr; }.registry-list > a > div:last-child { align-items: flex-start; }.record-data { grid-template-columns: 1fr; }.record-data .full { grid-column: auto; }.timeline article { grid-template-columns: 1fr; gap: 4px; }.campaign-grid, .staff-assignment-grid, .registry-shortcuts, .registry-shortcuts.compact { grid-template-columns: 1fr; }.consent-table article { grid-template-columns: 1fr; }.consent-field { grid-template-columns: 1fr; }.consent-field > p, .consent-field > .full { grid-column: auto; }.footer-legal-links { align-items: flex-start; }
}
