/* tettosveglio.com — tailwind overrides */
:root { --lr-accent: #15803d; --lr-max: 42rem; }
.font-serif { font-family: Georgia, 'Times New Roman', serif; }
.lr-main { max-width: 1100px; margin: 0 auto; padding: 2rem 1.25rem 4rem; }
.lr-article { max-width: var(--lr-max); margin: 0 auto; }
.lr-header h1 { font-size: clamp(1.85rem, 4vw, 2.75rem); line-height: 1.15; margin: .5rem 0 1rem; }
.lr-deck { font-size: 1.2rem; opacity: .85; line-height: 1.55; }
.lr-meta { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--lr-accent); font-weight: 600; }
.lr-hero-img img, .lr-figure img { width: 100%; background: #c8c8c8; border-radius: .5rem; display: block; }
.lr-body { font-size: 1.08rem; line-height: 1.75; }
.lr-body h2 { margin-top: 2.5rem; font-size: 1.45rem; }
.lr-lead { font-size: 1.2rem; line-height: 1.65; margin-bottom: 1.5rem; }
.lr-dropcap::first-letter { float: left; font-size: 3.2rem; line-height: 1; padding-right: .5rem; font-weight: 700; color: var(--lr-accent); }
.lr-pullquote { border-left: 4px solid var(--lr-accent); margin: 2rem 0; padding: 1rem 1.5rem; font-style: italic; background: rgba(0,0,0,.03); }
.lr-h-rule { border-bottom: 2px solid var(--lr-accent); padding-bottom: .35rem; margin-top: 2rem; }
.lr-table { width: 100%; border-collapse: collapse; margin: 1.25rem 0; font-size: .95rem; }
.lr-table th, .lr-table td { border: 1px solid rgba(0,0,0,.12); padding: .6rem .75rem; text-align: left; }
.lr-tip { background: color-mix(in srgb, var(--lr-accent) 10%, #fff); border-left: 4px solid var(--lr-accent); padding: .85rem 1rem; margin: 1.25rem 0; border-radius: 0 .5rem .5rem 0; }
.lr-steps-num { counter-reset: step; list-style: none; padding: 0; margin: 1.5rem 0; }
.lr-steps-num li { counter-increment: step; padding: .65rem 0 .65rem 2.5rem; position: relative; border-bottom: 1px solid rgba(0,0,0,.08); }
.lr-steps-num li::before { content: counter(step); position: absolute; left: 0; width: 1.75rem; height: 1.75rem; background: var(--lr-accent); color: #fff; border-radius: 999px; text-align: center; font-size: .8rem; line-height: 1.75rem; font-weight: 700; }
.lr-highlight { background: #fff8e6; border: 1px solid #f0d78c; padding: 1rem 1.25rem; border-radius: .5rem; margin: 1.5rem 0; }
.lr-codehint { font-family: ui-monospace, monospace; font-size: .85rem; opacity: .85; background: rgba(0,0,0,.06); padding: .5rem .75rem; border-radius: .35rem; }
.lr-card-block { border: 1px solid rgba(0,0,0,.1); border-radius: .65rem; padding: 1rem 1.25rem; margin: 1rem 0; }
.lr-card-block h3 { margin: 0 0 .5rem; font-size: 1.05rem; }
.lr-serif-intro { font-family: Georgia, serif; font-size: 1.25rem; line-height: 1.6; }
.lr-margin-note { font-size: .9rem; opacity: .75; font-style: italic; border-left: 3px solid var(--lr-accent); padding-left: 1rem; }
.lr-intro-cols { display: grid; gap: 1rem; margin-bottom: 1.5rem; }
@media (min-width: 640px) { .lr-intro-cols { grid-template-columns: 1fr 1fr; } }
.lr-callout { background: color-mix(in srgb, var(--lr-accent) 12%, transparent); padding: 1rem 1.25rem; border-radius: .5rem; margin: 1.5rem 0; }
.cat-list { display: flex; flex-direction: column; gap: 1rem; }
.cat-list-item { display: block; padding: 1.25rem; border: 1px solid rgba(0,0,0,.1); border-radius: .65rem; text-decoration: none; color: inherit; transition: border-color .2s, box-shadow .2s; }
.cat-list-item:hover { border-color: var(--lr-accent); box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.cat-list-item h2 { font-size: 1.2rem; margin: 0 0 .35rem; }
.cat-list-item p { margin: 0; opacity: .85; font-size: .95rem; }
.cat-list-item small { display: block; margin-top: .5rem; opacity: .6; font-size: .8rem; }
.cat-head { margin-bottom: 1.5rem; }
.lr-header--center { text-align: center; }
.lr-mag-grid { display: grid; gap: 1.5rem; margin-bottom: 1rem; }
@media (min-width: 768px) { .lr-mag-grid { grid-template-columns: 1fr 280px; align-items: start; } }
.lr-hero-img--side img { aspect-ratio: 4/3; object-fit: cover; }
.lr-article--wide { max-width: 52rem; }
.lr-body--columns p { max-width: 38rem; }
.lr-body--serif { font-family: 'Source Serif 4', Georgia, serif; font-size: 1.12rem; }
.site-home { width: 100%; }
.home-grid { justify-items: stretch; }
.lr-promo { margin: 2rem 0; padding: 1.25rem 1.5rem; border-radius: .65rem; }
.lr-promo--shield { background: #eef4f8; border-left: 4px solid var(--lr-accent); }
.lr-promo--warm { background: #faf3ef; border: 1px solid #e8d5cc; }
.lr-promo--bold { background: #111; color: #fff; border: 3px solid #111; }
.lr-promo--bold strong { display: block; font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: .35rem; }
.lr-promo--green { background: #ecfdf5; border: 1px dashed #15803d; display: flex; gap: .75rem; align-items: flex-start; }
.lr-promo--amber { background: linear-gradient(135deg,#fff7ed,#ffedd5); border-radius: .75rem; padding: 1.5rem; }
.lr-promo--tech { background: #f0f7ff; border: 1px solid #bfdbfe; font-family: ui-monospace,monospace; }
.lr-promo--tech code { color: var(--lr-accent); font-weight: 700; margin-right: .5rem; }
.lr-promo--violet { background: #f5f3ff; border-left: 5px solid #5b4cdb; }
.lr-promo--serif { background: #f4f2ef; font-family: Georgia,serif; font-style: italic; border-top: 2px solid #9a6b4a; }
.lr-promo--clean { background: #faf8ff; border: 1px solid #ddd6fe; }
.lr-promo-tag, .lr-promo-kicker { display: block; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; margin-bottom: .4rem; color: var(--lr-accent); }
.lr-quiz-wrap { margin: 2.5rem 0; }
.lr-quiz-sub { font-size: .95rem; opacity: .8; margin: 0 0 1.25rem; line-height: 1.5; }
.lr-quiz-progress { height: 8px; background: #e8e8e8; border-radius: 99px; overflow: hidden; margin: 0 0 1.25rem; }
.lr-quiz-fill { height: 100%; width: 0; background: var(--lr-accent); transition: width .35s ease; }
.lr-quiz-label { font-size: .8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; margin: 0 0 .75rem; color: var(--lr-accent); }
.lr-quiz-q { font-weight: 600; font-size: 1.1rem; margin: 0 0 1rem; line-height: 1.4; }
.lr-quiz-answers { display: flex; flex-direction: column; gap: .5rem; }
.lr-quiz-proc { text-align: center; padding: 2rem 1rem; opacity: .85; }
.lr-quiz-res { text-align: center; padding: 1.5rem 1rem 1rem; border-top: 1px solid rgba(0,0,0,.08); margin-top: 1rem; }
.lr-quiz-res-title { font-size: 1.25rem; margin: 0 0 .75rem; }
.lr-quiz-res-text { margin: 0 0 1.25rem; opacity: .85; line-height: 1.55; max-width: 32rem; margin-left: auto; margin-right: auto; }
.lr-quiz--semantic { padding: 1.75rem !important; margin: 2.5rem 0 !important; }
.lr-quiz--semantic .lr-quiz-answers { margin-top: .5rem; }
.lr-quiz--semantic .ui.button.lr-quiz-btn { margin-bottom: .5rem !important; text-align: left; justify-content: flex-start; }
.lr-quiz--tw { max-width: 100%; }
.lr-quiz--water { border: 2px solid #e5e5e5; padding: 1.5rem; border-radius: .5rem; }
.lr-quiz--card { border-color: rgba(0,0,0,.1) !important; }
.lr-faq { margin: .75rem 0; padding: .75rem 1rem; border: 1px solid rgba(0,0,0,.1); border-radius: .5rem; }
.lr-promo-strip { background: var(--lr-accent); color: #fff; text-align: center; padding: .5rem; font-size: .85rem; }
.lr-promo-strip span { font-weight: 700; text-transform: uppercase; margin-right: .5rem; }
.lr-badge { background: var(--lr-accent); color: #fff; font-size: .7rem; padding: .25rem .65rem; border-radius: 999px; text-transform: uppercase; }
.hidden, .hide { display: none !important; }
.legal-overlay { position: fixed; inset: 0; z-index: 2000; background: rgba(15,23,42,.55); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; padding: 1rem; }
.legal-overlay[hidden] { display: none !important; }
.legal-panel { background: #fff; color: #1a1a1a; max-width: 520px; width: 100%; max-height: 85vh; overflow: auto; padding: 1.75rem; border-radius: 1rem; box-shadow: 0 25px 50px rgba(0,0,0,.2); position: relative; }
.legal-close { position: absolute; top: .75rem; right: .75rem; border: none; background: #f1f5f9; width: 2rem; height: 2rem; border-radius: 999px; cursor: pointer; font-size: 1.25rem; line-height: 1; }
.legal-title { margin: 0 2rem 1rem 0; font-size: 1.35rem; }
.legal-body { font-size: .95rem; line-height: 1.65; }
.home-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.5rem; }
.home-card { border-radius: .75rem; overflow: hidden; background: var(--card, #fff); border: 1px solid rgba(0,0,0,.08); transition: transform .2s, box-shadow .2s; }
.home-card:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(0,0,0,.1); }
.home-card a { display: block; text-decoration: none; color: inherit; }
.home-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; background: #c8c8c8; display: block; }
.home-card h3 { font-size: 1.1rem; margin: .75rem 1rem .35rem; line-height: 1.35; }
.home-card p { margin: 0 1rem 1rem; font-size: .92rem; opacity: .8; line-height: 1.5; }
.home-cat-title { font-size: 1.35rem; border-bottom: 2px solid var(--lr-accent); padding-bottom: .5rem; display: inline-block; }
.ns-featured-box { border-left: 4px solid var(--lr-accent) !important; }
.qs-featured-block { display: block; border: 3px solid #000; padding: 1.5rem; margin: 2rem 0; text-decoration: none; color: inherit; }
.qs-featured-block:hover { background: #f5f5f5; }
.lr-cta-btn, .lr-cta-banner a { display: inline-block; padding: .9rem 1.8rem; background: var(--lr-accent); color: #fff !important; text-decoration: none; border-radius: .5rem; font-weight: 600; border: none; cursor: pointer; }
.quiz-btn, .lr-quiz-btn { display: block; width: 100%; text-align: left; padding: .85rem 1.1rem; border: 1px solid rgba(0,0,0,.12); background: #fff; border-radius: .5rem; cursor: pointer; font: inherit; transition: border-color .2s, background .2s; }
.quiz-btn:hover, .lr-quiz-btn:hover { border-color: var(--lr-accent); color: var(--lr-accent); background: color-mix(in srgb, var(--lr-accent) 5%, #fff); }
.text-brand { color: var(--lr-accent); } .bg-brand { background: var(--lr-accent); }
.site-home .home-cat { margin: 0 auto; }