/*
Theme Name: OMR Sheet Maker
Theme URI: https://omrsheetmaker.in
Author: omrsheetmaker.in
Author URI: https://omrsheetmaker.in
Description: Generate printable OMR answer sheets as PDF & Word, add logos and booklet sets, auto-grade MCQs with analytics and report cards, scan filled sheets, and save templates. Includes a full blog, rich header/footer, SEO/GEO structured data, and login-aware UI. Self-contained WordPress theme for omrsheetmaker.in.
Version: 1.7.1
Requires at least: 5.5
Tested up to: 6.6
Requires PHP: 7.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: omrsheetmaker
*/

:root {
	--omr-primary: #2563eb;
	--omr-primary-dark: #1e40af;
	--omr-ink: #0f172a;
	--omr-muted: #64748b;
	--omr-line: #e2e8f0;
	--omr-bg: #f8fafc;
	--omr-card: #ffffff;
	--omr-ok: #16a34a;
	--omr-bad: #dc2626;
	--omr-warn: #d97706;
	--omr-radius: 14px;
	--omr-shadow: 0 1px 3px rgba(15,23,42,.08), 0 8px 24px rgba(15,23,42,.06);
}

* { box-sizing: border-box; }

body.omr {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--omr-ink);
	background: var(--omr-bg);
	line-height: 1.55;
}

a { color: var(--omr-primary); text-decoration: none; }
a:hover { text-decoration: underline; }

.omr-wrap { max-width: 1060px; margin: 0 auto; padding: 0 20px; }

/* Header / nav */
.omr-site-header {
	background: var(--omr-card);
	border-bottom: 1px solid var(--omr-line);
	z-index: 20;
}
.omr-site-header.is-sticky { position: sticky; top: 0; }

/* Announcement bar */
.omr-announce { background: var(--omr-primary-dark); color: #fff; text-align: center; font-size: 14px; padding: 9px 16px; }
.omr-announce a { color: #fff; text-decoration: underline; }

/* Brand image (custom logo / footer logo / site icon) */
.omr-brand-img { max-height: 40px; width: auto; height: auto; display: block; }
.omr-brand-icon { border-radius: 8px; }
.omr-site-footer .omr-brand-img { max-height: 48px; }
.omr-site-header .omr-wrap {
	display: flex; align-items: center; justify-content: space-between;
	height: 64px;
}
.omr-brand { display: flex; align-items: center; gap: 10px; font-weight: 800; font-size: 19px; color: var(--omr-ink); }
.omr-brand:hover { text-decoration: none; }
.omr-logo {
	width: 34px; height: 34px; border-radius: 9px;
	background: linear-gradient(135deg, var(--omr-primary), var(--omr-primary-dark));
	display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 15px;
}
/* Primary navigation (horizontal, no bullets) */
.omr-nav .omr-menu {
	list-style: none; margin: 0; padding: 0;
	display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.omr-nav .omr-menu li { margin: 0; padding: 0; list-style: none; }
.omr-nav .omr-menu a {
	display: inline-block; color: var(--omr-ink); font-weight: 600; font-size: 15px;
	padding: 8px 12px; border-radius: 8px; text-decoration: none;
}
.omr-nav .omr-menu a:hover,
.omr-nav .omr-menu .current-menu-item > a { color: var(--omr-primary); background: var(--omr-bg); }

/* Right-side group: nav + account control */
.omr-header-right { display: flex; align-items: center; gap: 18px; }
.omr-account-cta { display: flex; align-items: center; gap: 12px; }
.omr-account-cta .omr-btn { padding: 8px 16px; font-size: 14px; }
.omr-acc-login { color: var(--omr-ink); font-weight: 600; font-size: 15px; text-decoration: none; }
.omr-acc-login:hover { color: var(--omr-primary); text-decoration: none; }

/* Mobile menu toggle (hidden on desktop) */
.omr-navtoggle {
	display: none; width: 42px; height: 38px; border: 1px solid var(--omr-line);
	border-radius: 9px; background: #fff; cursor: pointer; padding: 9px 10px;
}
.omr-navtoggle span { display: block; height: 2px; width: 100%; background: var(--omr-ink); border-radius: 2px; margin: 4px 0; transition: transform .2s, opacity .2s; }
.omr-navtoggle.is-active span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.omr-navtoggle.is-active span:nth-child(2) { opacity: 0; }
.omr-navtoggle.is-active span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.omr-skip {
	position: absolute; left: -9999px; top: 0; background: var(--omr-primary); color: #fff;
	padding: 10px 16px; border-radius: 0 0 8px 0; z-index: 50;
}
.omr-skip:focus { left: 0; }

.omr-brand .custom-logo { max-height: 44px; width: auto; height: auto; }

@media (max-width: 980px) {
	.omr-navtoggle { display: block; order: 2; }
	.omr-site-header .omr-wrap { flex-wrap: wrap; height: auto; min-height: 64px; padding-top: 12px; padding-bottom: 12px; }
	.omr-brand { order: 1; }
	.omr-header-right {
		order: 3; flex-basis: 100%; display: none;
		flex-direction: column; align-items: stretch; gap: 6px;
		padding: 10px 0 6px; margin-top: 6px; border-top: 1px solid var(--omr-line);
	}
	.omr-header-right.is-open { display: flex; }
	.omr-nav { width: 100%; }
	.omr-nav .omr-menu { flex-direction: column; align-items: stretch; gap: 0; }
	.omr-nav .omr-menu a { padding: 13px 8px; border-bottom: 1px solid var(--omr-line); border-radius: 0; font-size: 16px; }
	.omr-account-cta { flex-direction: column; align-items: stretch; gap: 8px; margin-top: 8px; }
	.omr-account-cta .omr-btn, .omr-account-cta .omr-acc-login { width: 100%; text-align: center; box-sizing: border-box; }
	.omr-acc-login { padding: 12px 8px; border: 1px solid var(--omr-line); border-radius: 9px; }
}

/* Hero */
.omr-hero { padding: 64px 0 40px; text-align: center; }
.omr-hero h1 { font-size: 42px; line-height: 1.12; margin: 0 0 16px; letter-spacing: -.02em; }
.omr-hero p { font-size: 19px; color: var(--omr-muted); max-width: 640px; margin: 0 auto 28px; }
.omr-cta { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* Buttons */
.omr-btn {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--omr-primary); color: #fff; font-weight: 700; font-size: 15px;
	padding: 12px 22px; border-radius: 10px; border: 0; cursor: pointer; transition: .15s;
}
.omr-btn:hover { background: var(--omr-primary-dark); text-decoration: none; color: #fff; }
.omr-btn.secondary { background: #fff; color: var(--omr-ink); border: 1px solid var(--omr-line); }
.omr-btn.secondary:hover { background: var(--omr-bg); color: var(--omr-ink); }
.omr-btn.ghost { background: transparent; color: var(--omr-primary); padding-left: 4px; padding-right: 4px; }

/* Feature cards */
.omr-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 18px; margin: 8px 0 56px; }
.omr-card {
	background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius);
	padding: 24px; box-shadow: var(--omr-shadow);
}
.omr-card h3 { margin: 12px 0 8px; font-size: 18px; }
.omr-card p { margin: 0; color: var(--omr-muted); font-size: 15px; }
.omr-card .ico { width: 42px; height: 42px; border-radius: 11px; background: #eef2ff; color: var(--omr-primary); display: grid; place-items: center; font-size: 20px; }

/* Tool panels / forms */
.omr-tool { background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius); box-shadow: var(--omr-shadow); padding: 28px; margin: 28px 0; }
.omr-tool h2 { margin: 0 0 6px; font-size: 24px; }
.omr-tool .lead { color: var(--omr-muted); margin: 0 0 22px; }

.omr-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.omr-grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 18px; }
@media (max-width: 720px) { .omr-grid2, .omr-grid3 { grid-template-columns: 1fr; } }

.omr-field { margin-bottom: 16px; }
.omr-field label { display: block; font-weight: 600; font-size: 14px; margin-bottom: 6px; }
.omr-field .hint { font-weight: 400; color: var(--omr-muted); font-size: 12.5px; }
.omr-field input[type=text],
.omr-field input[type=number],
.omr-field select,
.omr-field textarea {
	width: 100%; padding: 10px 12px; border: 1px solid var(--omr-line); border-radius: 9px;
	font-size: 15px; font-family: inherit; background: #fff; color: var(--omr-ink);
}
.omr-field textarea { min-height: 120px; resize: vertical; font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 13.5px; }
.omr-field input:focus, .omr-field select:focus, .omr-field textarea:focus { outline: 2px solid #bfdbfe; border-color: var(--omr-primary); }

.omr-checks { display: flex; flex-wrap: wrap; gap: 14px; }
.omr-checks label { display: inline-flex; align-items: center; gap: 7px; font-weight: 500; font-size: 14px; }

.omr-presets { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 22px; }
.omr-chip {
	border: 1px solid var(--omr-line); background: #fff; border-radius: 999px; padding: 8px 16px;
	font-size: 14px; font-weight: 600; cursor: pointer; color: var(--omr-ink);
}
.omr-chip:hover { border-color: var(--omr-primary); color: var(--omr-primary); }

.omr-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 8px; padding-top: 18px; border-top: 1px solid var(--omr-line); }

.omr-note { background: #f0f7ff; border: 1px solid #dbeafe; color: #1e3a8a; padding: 12px 16px; border-radius: 10px; font-size: 14px; margin: 16px 0; }
.omr-note.omr-nudge { background: #fff7ed; border-color: #fed7aa; color: #9a3412; }
.omr-note.omr-nudge a { color: #9a3412; font-weight: 700; text-decoration: underline; }

/* Results */
.omr-summary { display: grid; grid-template-columns: repeat(auto-fit,minmax(120px,1fr)); gap: 12px; margin: 18px 0; }
.omr-stat { background: var(--omr-bg); border: 1px solid var(--omr-line); border-radius: 12px; padding: 14px 16px; }
.omr-stat .n { font-size: 26px; font-weight: 800; }
.omr-stat .l { font-size: 13px; color: var(--omr-muted); }

.omr-table { width: 100%; border-collapse: collapse; font-size: 14.5px; margin-top: 10px; }
.omr-table th, .omr-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--omr-line); }
.omr-table th { font-size: 12.5px; text-transform: uppercase; letter-spacing: .03em; color: var(--omr-muted); }
.omr-table tbody tr:hover { background: var(--omr-bg); }
.omr-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.omr-pill { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 12.5px; font-weight: 700; }
.omr-pill.pass { background: #dcfce7; color: var(--omr-ok); }
.omr-pill.fail { background: #fee2e2; color: var(--omr-bad); }

/* Footer */
.omr-site-footer { border-top: 1px solid var(--omr-line); background: var(--omr-card); padding: 30px 0; margin-top: 50px; color: var(--omr-muted); font-size: 14px; }
.omr-site-footer .omr-wrap { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; }

/* Generic content pages */
.omr-page { padding: 36px 0 10px; }
.omr-page h1 { margin-top: 0; }
.omr-page img { max-width: 100%; height: auto; }

/* SEO / GEO content sections */
.omr-content { max-width: 820px; margin: 10px auto 0; }
.omr-content h2 { font-size: 28px; margin: 40px 0 14px; letter-spacing: -.01em; }
.omr-content h3 { font-size: 19px; margin: 22px 0 6px; }
.omr-content p { color: #334155; font-size: 16.5px; margin: 0 0 14px; }
.omr-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 16px; margin: 16px 0 8px; }
.omr-step { background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius); padding: 20px; }
.omr-step .step-n { width: 30px; height: 30px; border-radius: 50%; background: var(--omr-primary); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 14px; margin-bottom: 10px; }
.omr-step h3 { margin: 0 0 6px; font-size: 17px; }
.omr-step p { margin: 0; font-size: 14.5px; color: var(--omr-muted); }

.omr-faq { margin: 10px 0 20px; }
.omr-faq details { border: 1px solid var(--omr-line); border-radius: 12px; background: var(--omr-card); padding: 4px 18px; margin-bottom: 10px; }
.omr-faq summary { cursor: pointer; font-weight: 700; font-size: 16.5px; padding: 14px 0; list-style: none; }
.omr-faq summary::-webkit-details-marker { display: none; }
.omr-faq summary::after { content: '+'; float: right; color: var(--omr-primary); font-weight: 800; }
.omr-faq details[open] summary::after { content: '\2212'; }
.omr-faq details p { color: #334155; font-size: 15.5px; margin: 0 0 14px; }

/* Breadcrumbs */
.omr-breadcrumbs { font-size: 13.5px; color: var(--omr-muted); padding: 18px 0 6px; }
.omr-breadcrumbs a { color: var(--omr-muted); }
.omr-breadcrumbs a:hover { color: var(--omr-primary); }
.omr-breadcrumbs span { margin: 0 4px; color: #cbd5e1; }

/* Blog index */
.omr-blog-head { padding: 8px 0 22px; }
.omr-blog-head h1 { margin: 0 0 6px; font-size: 34px; letter-spacing: -.02em; }
.omr-section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin: 8px 0 16px; }
.omr-section-head h2 { margin: 0; }

.omr-postgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 22px; }
.omr-postcard { background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius); overflow: hidden; box-shadow: var(--omr-shadow); display: flex; flex-direction: column; }
.omr-postcard-thumb { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--omr-bg); }
.omr-postcard-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.omr-postcard-body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 8px; }
.omr-postcard-cat { align-self: flex-start; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--omr-primary); background: #eef2ff; padding: 3px 10px; border-radius: 999px; }
.omr-postcard-cat:hover { text-decoration: none; }
.omr-postcard-title { margin: 2px 0 0; font-size: 18px; line-height: 1.3; }
.omr-postcard-title a { color: var(--omr-ink); }
.omr-postcard-title a:hover { color: var(--omr-primary); text-decoration: none; }
.omr-postcard-excerpt { margin: 0; color: var(--omr-muted); font-size: 14.5px; }
.omr-postcard-meta { margin-top: auto; padding-top: 6px; font-size: 12.5px; color: #94a3b8; }

/* Single post */
.omr-single { max-width: 820px; }
.omr-single-head { padding: 6px 0 10px; }
.omr-single-head h1 { font-size: 34px; line-height: 1.15; margin: 10px 0 8px; letter-spacing: -.02em; }
.omr-single-meta { color: var(--omr-muted); font-size: 14px; }
.omr-single-thumb { width: 100%; height: auto; border-radius: var(--omr-radius); margin: 14px 0 8px; }
.omr-article h2 { font-size: 25px; margin: 32px 0 12px; }
.omr-article h3 { font-size: 19px; margin: 22px 0 8px; }
.omr-article ul, .omr-article ol { padding-left: 22px; color: #334155; }
.omr-article li { margin: 6px 0; }
.omr-article a { color: var(--omr-primary); }
.omr-tags { margin: 22px 0; display: flex; flex-wrap: wrap; gap: 8px; }
.omr-tags a { font-size: 13px; color: var(--omr-muted); background: var(--omr-bg); border: 1px solid var(--omr-line); padding: 4px 12px; border-radius: 999px; }
.omr-related-h { margin: 40px 0 16px; font-size: 22px; }

/* Pagination */
.omr-pagination { margin: 32px 0; }
.omr-pagination .nav-links { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.omr-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px; border: 1px solid var(--omr-line); border-radius: 9px; color: var(--omr-ink); font-weight: 600; background: #fff; }
.omr-pagination .page-numbers.current { background: var(--omr-primary); color: #fff; border-color: var(--omr-primary); }
.omr-pagination a.page-numbers:hover { border-color: var(--omr-primary); color: var(--omr-primary); text-decoration: none; }

/* Search form */
.omr-searchform { display: flex; gap: 8px; }
.omr-searchform input[type=search] { flex: 1; padding: 11px 14px; border: 1px solid var(--omr-line); border-radius: 10px; font-size: 15px; }
.screen-reader-text { position: absolute; left: -9999px; }

/* CTA band */
.omr-cta-band { background: linear-gradient(135deg, var(--omr-primary), var(--omr-primary-dark)); color: #fff; border-radius: var(--omr-radius); padding: 40px 28px; text-align: center; margin: 48px 0 8px; }
.omr-cta-band h2 { color: #fff; margin: 0 0 8px; font-size: 26px; }
.omr-cta-band p { color: #dbe6ff; margin: 0 0 20px; }
.omr-cta-band .omr-btn { background: #fff; color: var(--omr-primary-dark); }
.omr-cta-band .omr-btn:hover { background: #f1f5ff; }
.omr-cta-band .omr-btn.secondary { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.4); }

.omr-home-blog { max-width: 1060px; margin: 48px auto 0; }

/* Footer (multi-column) */
.omr-site-footer { border-top: 1px solid var(--omr-line); background: var(--omr-card); margin-top: 56px; }
.omr-footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; padding: 44px 20px 30px; }
.omr-footer-brand p { color: var(--omr-muted); font-size: 14.5px; margin: 12px 0 0; max-width: 320px; }
.omr-footer-col h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--omr-ink); margin: 4px 0 12px; }
.omr-footer-col ul { list-style: none; margin: 0; padding: 0; }
.omr-footer-col li { margin: 0 0 9px; }
.omr-footer-col a { color: var(--omr-muted); font-size: 14.5px; }
.omr-footer-col a:hover { color: var(--omr-primary); }
.omr-footer-bottom { border-top: 1px solid var(--omr-line); padding: 18px 0; font-size: 13.5px; color: var(--omr-muted); }
.omr-footer-bottom .omr-wrap { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
@media (max-width: 800px) {
	.omr-footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
	.omr-footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 460px) {
	.omr-footer-grid { grid-template-columns: 1fr; }
}

/* Pricing plan cards */
.omr-plan-cards { align-items: stretch; }
.omr-plan { display: flex; flex-direction: column; position: relative; }
.omr-plan.featured { border-color: var(--omr-primary); border-width: 2px; }
.omr-plan .omr-badge { position: absolute; top: -12px; left: 24px; background: var(--omr-primary); color: #fff; font-size: 12px; font-weight: 700; padding: 4px 12px; border-radius: 999px; }
.omr-price { font-size: 30px; font-weight: 800; color: var(--omr-ink); margin: 6px 0 14px; }
.omr-price span { font-size: 14px; color: var(--omr-muted); font-weight: 500; }
.omr-feat { list-style: none; margin: 16px 0 0; padding: 0; }
.omr-feat li { position: relative; padding: 5px 0 5px 24px; font-size: 14.5px; color: #334155; border-top: 1px solid var(--omr-line); }
.omr-feat li:before { content: '\2713'; position: absolute; left: 0; color: var(--omr-ok); font-weight: 700; }
.omr-feat li.omr-feat-h { padding-left: 0; font-weight: 700; color: var(--omr-ink); border-top: 0; }
.omr-feat li.omr-feat-h:before { content: ''; }

/* Comparison table */
.omr-compare-h { text-align: center; margin: 36px 0 14px; }
.omr-compare-wrap { overflow-x: auto; }
.omr-compare { width: 100%; border-collapse: collapse; background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius); overflow: hidden; }
.omr-compare th, .omr-compare td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--omr-line); font-size: 14.5px; }
.omr-compare thead th { background: var(--omr-bg); font-size: 13px; text-transform: uppercase; letter-spacing: .03em; color: var(--omr-muted); }
.omr-compare th:nth-child(2), .omr-compare td:nth-child(2), .omr-compare th:nth-child(3), .omr-compare td:nth-child(3) { text-align: center; width: 22%; }
.omr-compare td:nth-child(3) { background: #f5f9ff; }
.omr-yes { color: var(--omr-ok); font-weight: 800; }
.omr-no { color: #cbd5e1; }

/* Vs columns */
.omr-vs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 16px 0 8px; }
.omr-vs-col { background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius); padding: 20px; }
.omr-vs-col h3 { margin: 0 0 10px; font-size: 17px; }
.omr-vs-col ul { margin: 0; padding-left: 18px; color: var(--omr-muted); font-size: 14.5px; }
.omr-vs-col li { margin: 7px 0; }
.omr-vs-col.best { border-color: var(--omr-primary); border-width: 2px; background: #f5f9ff; }
.omr-vs-col.best h3 { color: var(--omr-primary-dark); }
.omr-vs-col.best ul { color: #334155; }
@media (max-width: 720px) { .omr-vs { grid-template-columns: 1fr; } }

/* Flow strip */
.omr-flow { display: flex; align-items: stretch; gap: 8px; flex-wrap: wrap; margin: 14px 0 8px; }
.omr-flow-step { flex: 1; min-width: 150px; background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: 12px; padding: 16px; font-weight: 600; font-size: 14.5px; display: flex; align-items: center; gap: 10px; }
.omr-flow-step span { width: 26px; height: 26px; border-radius: 50%; background: var(--omr-primary); color: #fff; display: grid; place-items: center; font-size: 13px; flex: none; }
.omr-flow-arrow { display: flex; align-items: center; color: var(--omr-muted); font-size: 20px; }
@media (max-width: 720px) { .omr-flow-arrow { display: none; } }

/* Blog sidebar layout */
.omr-has-sidebar { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 36px; align-items: start; }
.omr-has-sidebar .omr-main-col.omr-single { max-width: none; margin: 0; }
.omr-sidebar { position: sticky; top: 84px; }
.omr-widget { background: var(--omr-card); border: 1px solid var(--omr-line); border-radius: var(--omr-radius); padding: 18px 20px; margin-bottom: 18px; }
.omr-widget-title { font-size: 16px; margin: 0 0 12px; }
.omr-widget ul { list-style: none; margin: 0; padding: 0; }
.omr-widget li { padding: 6px 0; border-bottom: 1px solid var(--omr-line); font-size: 14.5px; }
.omr-widget li:last-child { border-bottom: 0; }
.omr-widget a { color: var(--omr-ink); }
.omr-widget a:hover { color: var(--omr-primary); }
.omr-cta-widget { text-align: center; }
.omr-cta-widget h3 { margin: 0 0 6px; }
.omr-cta-widget p { color: var(--omr-muted); font-size: 14.5px; margin: 0 0 12px; }
@media (max-width: 880px) {
	.omr-has-sidebar { grid-template-columns: 1fr; }
	.omr-sidebar { position: static; }
}

/* Footer widgets row */
.omr-footer-widgets { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 22px; padding: 36px 20px 6px; }
.omr-footer-widgets .omr-widget { background: transparent; border: 0; padding: 0; margin: 0; }
.omr-footer-widgets .omr-widget-title { color: var(--omr-ink); }
.omr-footer-widgets .omr-widget li { border-color: var(--omr-line); }

/* Social icons */
.omr-social { display: flex; gap: 10px; margin-top: 14px; }
.omr-social-link { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: var(--omr-muted); border: 1px solid var(--omr-line); transition: .15s; }
.omr-social-link:hover { color: #fff; background: var(--omr-primary); border-color: var(--omr-primary); }

/* Horizontal-scroll wrapper for wide tables on small screens */
.omr-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 10px 0; }
.omr-scroll .omr-table { margin-top: 0; }
@media (max-width: 640px) { .omr-scroll .omr-table { min-width: 560px; } }

/* ---- Global mobile polish ---- */
@media (max-width: 600px) {
	.omr-wrap { padding: 0 16px; }
	.omr-hero { padding: 36px 0 22px; }
	.omr-hero h1 { font-size: 28px; }
	.omr-hero p { font-size: 16px; }
	.omr-content h2, .omr-blog-head h1, .omr-single-head h1, .omr-cta-band h2, .omr-compare-h { font-size: 23px; }
	.omr-content h3 { font-size: 17px; }
	.omr-content p, .omr-content { font-size: 16px; }
	.omr-tool { padding: 18px 16px; }
	.omr-tool h2 { font-size: 21px; }
	.omr-cta { flex-direction: column; }
	.omr-cta .omr-btn { width: 100%; box-sizing: border-box; text-align: center; }
	.omr-actions { gap: 8px; }
	.omr-actions .omr-btn { flex: 1 1 100%; text-align: center; box-sizing: border-box; }
	.omr-section-head { flex-direction: column; align-items: flex-start; gap: 4px; }
	.omr-table { font-size: 13px; }
	.omr-table th, .omr-table td { padding: 8px 9px; }
	.omr-price { font-size: 26px; }
	.omr-summary { grid-template-columns: repeat(2, 1fr); }
	.omr-cta-band { padding: 30px 18px; }
}

/* Tap targets a touch bigger on touch devices */
@media (hover: none) {
	.omr-btn { padding: 13px 22px; }
}

/* Print: keep generated previews clean */
@media print {
	.omr-site-header, .omr-site-footer, .omr-navtoggle, .omr-skip, .omr-actions, .omr-presets { display: none !important; }
	body.omr { background: #fff; }
	.omr-tool { box-shadow: none; border: none; padding: 0; }
}
