/* Trovlix shared design system */

*{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  background:#f5f1eb;
  scroll-padding-bottom:calc(16px + env(safe-area-inset-bottom));
}
body{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,-apple-system,sans-serif;
  color:#18212d;
  background:
    radial-gradient(circle at 18% 12%, rgba(172,161,255,.18), transparent 24%),
    radial-gradient(circle at 78% 18%, rgba(155,216,247,.22), transparent 22%),
    radial-gradient(circle at 50% 78%, rgba(243,188,151,.24), transparent 20%),
    linear-gradient(180deg,#f6f3ee 0%,#f4f1f5 34%,#eef2f9 62%,#f8eee8 84%,#fcfaf7 100%);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  min-height:100svh;
}
body::before,
body::after{
  content:"";
  position:fixed;
  width:38vw;
  height:38vw;
  border-radius:50%;
  filter:blur(72px);
  pointer-events:none;
  z-index:0;
  opacity:.42;
}
body::before{top:10vh;right:-8vw;background:rgba(158,208,245,.24)}
body::after{bottom:4vh;left:-6vw;background:rgba(235,190,165,.22)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Layout */
.wrap{
  position:relative;
  z-index:1;
  max-width:1120px;
  margin:0 auto;
  padding:0 24px;
}
@media(min-width:768px){.wrap{padding:0 40px}}

/* Header */
header{
  padding:28px 0 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-weight:700;
  font-size:18px;
  letter-spacing:-.3px;
  color:#18212d;
}
nav{
  display:flex;
  align-items:center;
  gap:24px;
  font-size:15px;
  color:rgba(54,66,84,.62);
}
@media(max-width:560px){
  header{padding:18px 0;align-items:flex-start;flex-direction:column;gap:12px}
  nav{width:100%;gap:16px;flex-wrap:wrap;font-size:14px}
}
nav a{transition:color .15s}
nav a:hover,nav a[aria-current]{color:#111827}
.lang-toggle{
  background:rgba(255,255,255,.58);
  border:1px solid rgba(255,255,255,.72);
  border-radius:999px;
  padding:6px 14px;
  font:inherit;
  font-size:13px;
  font-weight:600;
  color:#334155;
  cursor:pointer;
  transition:background .15s;
  box-shadow:0 16px 34px rgba(144,153,176,.14);
  backdrop-filter:blur(18px);
}
.lang-toggle:hover{background:rgba(255,255,255,.74)}

/* Shared page blocks */
.hero{padding:80px 0 60px;max-width:680px}
@media(min-width:768px){.hero{padding:120px 0 80px}}
.hero h1{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-size:40px;
  font-weight:700;
  line-height:1.02;
  letter-spacing:-1.5px;
  color:#18212d;
}
@media(min-width:768px){.hero h1{font-size:56px}}
.hero .sub{
  margin-top:20px;
  font-size:18px;
  color:rgba(64,76,96,.74);
  line-height:1.72;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 32px;
  border-radius:999px;
  font:inherit;
  font-size:16px;
  font-weight:600;
  border:none;
  cursor:pointer;
  transition:background .15s;
  text-decoration:none;
}
.btn-primary{
  background:#18212d;
  color:#f8fbff;
  box-shadow:0 18px 38px rgba(110,121,148,.16);
}
.btn-primary:hover{background:#243246}
.btn-secondary{
  background:rgba(255,255,255,.58);
  color:#18212d;
  border:1px solid rgba(255,255,255,.78);
  box-shadow:0 18px 36px rgba(141,152,175,.12);
}
.btn-secondary:hover{background:rgba(255,255,255,.74)}
.cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}

/* Section */
.section{padding:80px 0}
@media(min-width:768px){.section{padding:104px 0}}
.section-title{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-size:32px;
  font-weight:700;
  letter-spacing:-.8px;
  line-height:1.08;
  margin-bottom:16px;
  color:#18212d;
}
@media(min-width:768px){.section-title{font-size:42px}}
.section-sub{
  font-size:17px;
  color:rgba(64,76,96,.74);
  line-height:1.72;
  max-width:560px;
}

/* FAQ */
.faq{margin-top:32px}
.faq details{
  border-top:1px solid rgba(194,205,221,.54);
  padding:20px 0;
}
.faq summary{
  font-size:16px;
  font-weight:600;
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  color:#18212d;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:20px;color:rgba(92,111,144,.5);transition:transform .2s}
details[open] summary::after{content:'−'}
.faq p{
  margin-top:12px;
  font-size:15px;
  color:rgba(64,76,96,.74);
  line-height:1.7;
  max-width:600px;
}

/* Cards and forms */
.contact-card,
.recovery{
  margin-top:32px;
  padding:38px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.68) 0%,rgba(255,255,255,.38) 100%);
  border:1px solid rgba(255,255,255,.86);
  border-radius:34px;
  text-align:center;
  box-shadow:0 24px 54px rgba(146,156,181,.14);
  backdrop-filter:blur(20px);
}
.contact-card h2,
.recovery h2{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-size:28px;
  line-height:1.08;
  font-weight:700;
  letter-spacing:-.04em;
  margin-bottom:8px;
  color:#18212d;
}
@media(min-width:768px){
  .contact-card h2,
  .recovery h2{font-size:32px}
}
.contact-card p,
.recovery p{color:rgba(64,76,96,.74)}
.contact-card a,.recovery a{text-decoration:underline}

.signup-form{display:flex;gap:10px;max-width:420px;margin:20px auto 0}
.signup-form input[type="email"]{
  flex:1;
  min-width:0;
  padding:14px 18px;
  border:1px solid rgba(255,255,255,.84);
  border-radius:999px;
  background:rgba(255,255,255,.72);
  box-shadow:0 18px 34px rgba(146,156,181,.12);
  color:#18212d;
  font:inherit;
  font-size:15px;
  outline:none;
  transition:border-color .15s;
}
.signup-form input[type="email"]:focus{border-color:rgba(92,111,144,.52)}
.signup-form input[type="email"]::placeholder{color:rgba(78,91,112,.48)}
.signup-form button{
  padding:14px 24px;
  border-radius:999px;
  border:none;
  background:#18212d;
  color:#f8fbff;
  box-shadow:0 18px 38px rgba(110,121,148,.16);
  font:inherit;
  font-size:15px;
  font-weight:600;
  cursor:pointer;
  white-space:nowrap;
  transition:background .15s;
}
.signup-form button:hover{background:#243246}
.signup-form button:disabled{background:#9aa4b2;cursor:default}
.signup-form.has-note{flex-wrap:wrap;max-width:460px}
.signup-form.has-note .form-note{flex:1 0 100%;margin-top:2px;padding-left:4px;text-align:left}
.form-note{margin-top:10px;font-size:13px;color:rgba(64,76,96,.64)}
.form-trust{margin-top:4px}
.form-trust a{text-decoration:underline}
.signup-ok{color:#1f9d72;font-weight:600;font-size:15px;margin-top:16px}
.signup-err{color:#d9485f;font-size:14px;margin-top:8px}
@media(max-width:480px){
  .signup-form{flex-direction:column}
  .signup-form button{width:100%}
}

/* Footer */
footer{
  padding:40px 0;
  border-top:1px solid rgba(193,203,219,.46);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:16px;
  font-size:14px;
  color:rgba(74,86,106,.68);
}
footer a{color:rgba(74,86,106,.68);transition:color .15s}
footer a:hover{color:#111827}
.foot-links{display:flex;gap:20px}
@media(max-width:640px){
  footer{padding-bottom:calc(40px + env(safe-area-inset-bottom) + 16px)}
}

/* Accessibility */
.skip-link{
  position:absolute;left:-999px;top:10px;z-index:9999;
  background:#fff;border:1px solid rgba(190,200,215,.6);
  border-radius:12px;padding:10px 14px;font-size:14px;
}
.skip-link:focus{left:12px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto;transition:none!important}}
a:focus-visible,
button:focus-visible,
summary:focus-visible,
input:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid #18212d;
  outline-offset:3px;
  border-radius:4px;
}
.signup-form input[type="email"]:focus-visible{
  outline:2px solid #18212d;
  outline-offset:0;
  border-radius:999px;
}
.signup-form button:focus-visible,
.btn:focus-visible,
.lang-toggle:focus-visible{
  outline-offset:3px;
  border-radius:999px;
}

/* Value checklist */
.value-checks{
  list-style:none;
  padding:0;
  margin:0 0 20px;
  display:flex;
  flex-wrap:wrap;
  gap:6px 20px;
  font-size:14px;
  color:#243244;
}
.value-checks li::before{content:'✓ ';font-weight:700;color:#6fb5dc}

/* Steps */
.steps{counter-reset:step;margin-top:40px}
.step{
  display:flex;
  gap:20px;
  margin-bottom:18px;
  padding:22px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.58) 0%,rgba(255,255,255,.34) 100%);
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 18px 40px rgba(146,156,181,.1);
  backdrop-filter:blur(20px);
}
.step-num{
  counter-increment:step;
  flex-shrink:0;
  width:40px;
  height:40px;
  border-radius:999px;
  background:rgba(214,233,246,.68);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:700;
  color:#43637f;
}
.step-num::before{content:counter(step)}
.step-body h3{font-size:17px;font-weight:700;margin-bottom:4px;color:#18212d}
.step-body p{font-size:15px;color:rgba(64,76,96,.74);line-height:1.7}

/* Shared content pages */
.page-content{
  max-width:840px;
  margin:24px auto 0;
  padding:42px 30px;
  border-radius:36px;
  background:linear-gradient(180deg,rgba(255,255,255,.68) 0%,rgba(255,255,255,.38) 100%);
  border:1px solid rgba(255,255,255,.86);
  box-shadow:0 28px 64px rgba(146,156,181,.14);
  backdrop-filter:blur(20px);
}
@media(min-width:768px){.page-content{padding:52px 46px}}
.page-content-center{
  text-align:center;
  padding-top:120px;
  padding-bottom:120px;
}
.page-content h1{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-size:36px;
  font-weight:700;
  letter-spacing:-.04em;
  line-height:1.04;
  margin-bottom:18px;
  color:#18212d;
}
@media(min-width:768px){.page-content h1{font-size:48px}}
.page-content .page-lead{
  font-size:18px;
  line-height:1.78;
  color:#334155;
}
.page-content .page-meta{
  color:rgba(74,86,106,.62);
  font-size:14px;
  line-height:1.6;
}
.page-content p{
  font-size:16px;
  color:rgba(64,76,96,.74);
  line-height:1.78;
  margin-bottom:16px;
}
.page-content ul{
  margin:0 0 16px 20px;
  color:rgba(64,76,96,.74);
  font-size:16px;
  line-height:1.74;
}
.page-content li{margin:8px 0}
.page-content h2{
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-size:22px;
  font-weight:700;
  line-height:1.18;
  color:#18212d;
  margin:30px 0 10px;
}
.page-content a{text-decoration:underline}
.page-content strong{color:#18212d}
.page-content .page-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:20px;
}
.page-content .page-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

/* Utility lists */
.about-list,
.contact-list{
  list-style:none;
  margin:16px 0 18px;
  padding:0;
  display:grid;
  gap:12px;
}
.about-list li,
.contact-list li{
  margin:0;
  padding:16px 18px;
  border-radius:22px;
  background:rgba(255,255,255,.52);
  border:1px solid rgba(255,255,255,.82);
  box-shadow:0 16px 32px rgba(146,156,181,.1);
}
.contact-list li a{font-weight:600;text-decoration:underline}

/* Notes */
.note-list{
  list-style:none;
  margin:20px 0 0;
  padding:0;
  display:grid;
  gap:16px;
}
.note-card{
  padding:22px 22px 20px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.64) 0%,rgba(255,255,255,.38) 100%);
  border:1px solid rgba(255,255,255,.84);
  box-shadow:0 20px 40px rgba(146,156,181,.12);
}
.note-card a{
  display:block;
  text-decoration:none;
}
.note-card h2{
  margin:0 0 8px;
  font-family:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  font-size:24px;
  line-height:1.15;
  letter-spacing:-.03em;
  color:#18212d;
}
.note-card p{
  margin:0;
  font-size:15px;
  line-height:1.72;
  color:rgba(64,76,96,.74);
}
.note-meta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#5c6f90;
}
.article-crumb{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
  font-size:13px;
  color:rgba(74,86,106,.68);
}
.article-crumb a{text-decoration:underline}
.article-body h2{
  margin-top:34px;
  margin-bottom:10px;
}
.article-body h3{
  margin:22px 0 8px;
  font-size:18px;
  font-weight:700;
  line-height:1.25;
  color:#18212d;
}
.article-body p,
.article-body li{
  font-size:16px;
  line-height:1.82;
}
.article-body ul{
  margin:8px 0 18px 20px;
}
.article-callout{
  margin:24px 0;
  padding:18px 20px;
  border-radius:24px;
  background:rgba(255,255,255,.56);
  border:1px solid rgba(255,255,255,.82);
  box-shadow:0 18px 34px rgba(146,156,181,.1);
}
.article-callout p:last-child,
.article-body p:last-child{margin-bottom:0}

/* 404 helper */
.recovery{
  max-width:520px;
  margin-left:auto;
  margin-right:auto;
  text-align:left;
}
.recovery .signup-form{max-width:100%}
.not-found-code{
  font-size:64px;
  letter-spacing:-2px;
  margin-bottom:0;
}
