:root {
  --bg: #f5f7fb;
  --panel: #ffffff;
  --panel-2: #eef2f9;
  --text: #0f172a;
  --muted: #5b6475;
  --border: #d9e0ec;
  --brand: #4f46e5;
  --brand-2: #06b6d4;
  --ok: #0f766e;
  --danger: #dc2626;
  --shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

:root[data-theme="dark"] {
  --bg: #0b1220;
  --panel: #121b2d;
  --panel-2: #19243a;
  --text: #e7edf8;
  --muted: #9ca8be;
  --border: #28344c;
  --brand: #818cf8;
  --brand-2: #22d3ee;
  --ok: #2dd4bf;
  --danger: #f87171;
  --shadow: 0 14px 38px rgba(0, 0, 0, 0.35);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { font-size: 17px; }
body { font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; font-size: 1rem; background: radial-gradient(circle at top right, rgba(79,70,229,.08), transparent 35%), var(--bg); color: var(--text); line-height: 1.7; }
a { color: inherit; }
.container { width: min(1120px, calc(100% - 2rem)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 20; border-bottom: 1px solid var(--border); background: color-mix(in oklab, var(--panel) 85%, transparent); backdrop-filter: blur(10px); }
.nav-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .85rem 0; }
.brand { font-weight: 800; letter-spacing: .2px; text-decoration: none; background: linear-gradient(90deg, var(--brand), var(--brand-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
nav { display: flex; gap: .35rem; flex-wrap: wrap; align-items: center; }
nav a { text-decoration: none; color: var(--muted); padding: .5rem .8rem; border-radius: 9px; font-size: .97rem; }
nav a:hover { background: var(--panel-2); color: var(--text); }
main { padding: 1.5rem 0 2.5rem; }

.card { background: var(--panel); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow); padding: 1.1rem; }
.hero { display: grid; gap: 1rem; background: linear-gradient(145deg, color-mix(in oklab, var(--brand) 13%, var(--panel)), var(--panel)); border: 1px solid var(--border); border-radius: 22px; box-shadow: var(--shadow); padding: 1.7rem; }
.hero h1 { margin: 0; font-size: clamp(1.75rem, 3.5vw, 2.45rem); line-height: 1.22; }
.hero p { margin: 0; color: var(--muted); font-size: 1.02rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.btn { appearance: none; border: 0; cursor: pointer; border-radius: 12px; padding: .72rem 1.05rem; font-size: .96rem; font-weight: 650; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; transition: .2s ease; }
.btn-primary { background: linear-gradient(90deg, var(--brand), var(--brand-2)); color: #fff; }
.btn-muted { background: var(--panel-2); color: var(--text); }
.btn:hover { transform: translateY(-1px); opacity: .95; }
.menu-toggle { display: none; }
.theme-icon { color: #fbbf24; font-size: 1.1rem; }
h1, h2, h3 { line-height: 1.25; }
h2 { font-size: clamp(1.24rem, 2.1vw, 1.55rem); }
h3 { font-size: clamp(1.1rem, 1.8vw, 1.25rem); }
h2.section-title { margin-top: 1.6rem; }
.meta { color: var(--muted); font-size: .98rem; }

form { background: var(--panel); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow); padding: 1rem; }
label { display: block; font-size: .96rem; color: var(--muted); margin: .8rem 0 .4rem; }
input, textarea, select { width: 100%; border: 1px solid var(--border); background: var(--panel-2); color: var(--text); border-radius: 10px; padding: .72rem .8rem; font: inherit; font-size: 1rem; }
textarea { resize: vertical; min-height: 110px; }
.form-actions { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: 1rem; }
.list-clean { list-style: none; padding: 0; margin: .4rem 0; }
.list-clean li { border: 1px solid var(--border); border-radius: 10px; padding: .7rem .8rem; background: var(--panel-2); margin-bottom: .55rem; }
.feature-list { margin: .5rem 0 1rem 1.2rem; padding-left: .6rem; }
.feature-list li { margin-bottom: .4rem; }
.instruction-list { margin: .5rem 0 1rem 1.25rem; padding-left: .6rem; }
.instruction-list li { margin-bottom: .45rem; }
.inline-item { display: flex; gap: .45rem; align-items: center; margin-top: .5rem; }
.inline-item .x { border: 0; border-radius: 8px; width: 32px; height: 32px; background: color-mix(in oklab, var(--danger) 22%, var(--panel)); color: var(--danger); cursor: pointer; }
.site-footer { border-top: 1px solid var(--border); padding: 1.2rem 0 2rem; color: var(--muted); }
.footer-grid { display: grid; gap: 1rem; grid-template-columns: 1.3fr 1fr 1fr; }
.footer-brand { margin: 0 0 .35rem; font-weight: 800; color: var(--text); }
.footer-title { margin: 0 0 .4rem; font-weight: 700; color: var(--text); }
.tag { display: inline-flex; align-items: center; gap: .35rem; background: var(--panel-2); border: 1px solid var(--border); padding: .35rem .6rem; border-radius: 999px; font-size: .83rem; }
.notice { border-left: 4px solid var(--danger); padding: .6rem .75rem; background: color-mix(in oklab, var(--danger) 10%, var(--panel)); border-radius: 8px; }
.ok-msg { border-left: 4px solid var(--ok); padding: .6rem .75rem; background: color-mix(in oklab, var(--ok) 12%, var(--panel)); border-radius: 8px; color: var(--text); }
.form-msg { margin-top: .85rem; }
label.checkline { display: flex !important; align-items: flex-start; gap: .55rem; margin-top: .55rem; cursor: pointer; }
.checkline-box { flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; margin-top: .12rem; }
label.checkline input[type="checkbox"] { width: 18px; height: 18px; margin: 0; flex: 0 0 auto; }
label.checkline > span:last-child { line-height: 1.45; }
.status-pill { display: inline-flex; padding: .42rem .7rem; border-radius: 999px; font-weight: 700; }
.status-pill.success { background: color-mix(in oklab, var(--ok) 18%, var(--panel)); color: var(--ok); border: 1px solid color-mix(in oklab, var(--ok) 50%, var(--border)); }
.status-pill.warning { background: color-mix(in oklab, #f59e0b 18%, var(--panel)); color: #b45309; border: 1px solid color-mix(in oklab, #f59e0b 55%, var(--border)); }
.ok { color: var(--ok); }
.disclaimer { color: var(--muted); font-size: .92rem; }
.feature-image { width: 100%; border-radius: 14px; border: 1px solid var(--border); margin: .8rem 0; }
.split-hero { grid-template-columns: 1.25fr .85fr; align-items: start; }
.section-block { margin-top: 1.25rem; }
.tight li { margin-bottom: .4rem; }
.testimonial .stars { color: #f59e0b; letter-spacing: .08rem; font-size: 1.05rem; }
.table-wrap { overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { border: 1px solid var(--border); padding: .55rem; vertical-align: top; }
.table th { background: var(--panel-2); text-align: left; }
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:9999;padding:16px}
.modal .modal-inner{max-width:760px;width:100%;max-height:90vh;overflow:auto}
.video-wrap { position: relative; width: 100%; height: 400px; border-radius: 12px; overflow: hidden; border: 1px solid var(--border); }
.video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.prose p { margin: 0 0 .8rem; }

@media (max-width: 920px) {
  .grid-3, .grid-2, .split-hero { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  html { font-size: 16px; }
  .container { width: min(1120px, calc(100% - 1rem)); }
  .hero { padding: 1.15rem; }
  .menu-toggle { display: inline-flex; }
  nav#main-nav { display: none; }
  nav#main-nav.open { display: flex; }
}

.share-row{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center;margin:.8rem 0;position:relative}
.share-row-links{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center}
.share-row a{padding:.35rem .55rem;border:1px solid var(--border);border-radius:8px;background:var(--panel-2);text-decoration:none}
.share-row i{margin-right:.35rem}
.share-menu-toggle{display:none;padding:.35rem .65rem;border:1px solid var(--border);border-radius:8px;background:var(--panel-2);color:var(--text);font:inherit}

@media (max-width: 768px){
  .share-menu-toggle{display:inline-flex;align-items:center;gap:.35rem}
  .share-row-links{display:none;position:absolute;top:calc(100% + .35rem);left:0;right:0;z-index:20;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:.45rem;box-shadow:var(--shadow);flex-direction:column;align-items:stretch}
  .share-row.open .share-row-links{display:flex}
  .share-row.open .share-row-links a{display:flex;align-items:center}
}
.menu-backdrop{display:none}
.menu-close{display:none}
@media (max-width:760px){
  .menu-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:29;display:none}
  .menu-backdrop.open{display:block}
  nav#main-nav{position:fixed;left:.75rem;right:.75rem;top:.75rem;z-index:30;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:.8rem;max-height:calc(100vh - 1.5rem);overflow:auto;box-shadow:var(--shadow);gap:.35rem;align-items:stretch}
  nav#main-nav a, nav#main-nav button{width:100%}
  .menu-close{display:inline-flex;align-self:flex-end;width:auto}
}
.video-wrap{max-width:min(960px,100%);margin:0 auto 1.25rem}

@media (max-width: 920px) {
  .footer-grid { grid-template-columns: 1fr; }
}

.otp-resend-btn[disabled] { opacity: .65; cursor: not-allowed; }

.service-announcement{background:#dc2626;color:#fff;padding:.55rem .7rem;border-radius:10px;text-align:center;font-weight:700;margin:.7rem 0}
.service-hidden-cover{background:rgba(15,23,42,.86);color:#fff;padding:1.1rem;border-radius:12px;text-align:center;font-weight:700;margin:.8rem 0}
.service-content.is-covered{position:relative;filter:grayscale(.2);opacity:.05;pointer-events:none;user-select:none}
.feature-image{max-height:500px;object-fit:contain;background:var(--panel-2)}
#issue-modal .modal-inner{max-width:860px}

.my-services-tabs { display: flex; gap: .6rem; flex-wrap: wrap; margin-bottom: .8rem; }
.my-services-tabs .btn.active { background: linear-gradient(90deg, var(--brand), var(--brand-2)); color: #fff; }
.my-services-grid { display: grid; gap: .85rem; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); margin-top: .8rem; }
.my-service-card h3 { margin: 0 0 .2rem; font-size: 1rem; }
.my-service-card .form-actions { margin-top: .5rem; }

.my-service-card, .service-list-card { border-radius: 14px; }
.my-service-card h3, .service-list-card h2 { margin: 0 0 .35rem; line-height: 1.35; }
.my-service-card .meta, .service-list-card .meta { margin: 0 0 .6rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.my-service-card .tag { margin: 0 0 .6rem; }
#services-app .grid-2 { margin-top: .6rem; }
#services-pagination .btn[disabled], #my-services-pagination .btn[disabled] { opacity: .6; cursor: not-allowed; }

/* End-user listing polish */
.services-shell, .my-services-shell { padding: 1.25rem; border-radius: 18px; }
.services-search-form, .my-services-search-form { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: .7rem; }
.services-search-form input, .my-services-search-form input { width: min(560px, 100%); }

.services-grid, .my-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
  margin-top: .95rem;
}

.service-list-card, .my-service-card {
  border: 1px solid color-mix(in oklab, var(--border) 80%, var(--brand) 20%);
  border-radius: 16px;
  padding: 1rem;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.service-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.service-card-link:hover h2,
.service-card-link:hover h3 {
  color: var(--brand);
}

.service-list-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel-2);
  margin: 0 0 .65rem;
}
.service-list-card:hover, .my-service-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--brand) 45%, var(--border) 55%);
  box-shadow: 0 14px 28px rgba(15,23,42,.12);
}

.service-mini-label {
  margin: 0 0 .45rem;
  font-size: .72rem;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--brand);
  font-weight: 700;
}

.my-service-card h3, .service-list-card h2, .service-list-card h3 {
  margin: 0 0 .45rem;
  font-size: clamp(1rem, 1.5vw, 1.12rem);
}
.my-service-card .meta, .service-list-card .meta {
  margin: 0 0 .7rem;
  color: var(--muted);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.my-services-tabs {
  background: var(--panel-2);
  padding: .4rem;
  border-radius: 14px;
  gap: .45rem;
}
.my-services-tabs .btn {
  border-radius: 10px;
}
.my-services-tabs .btn.active {
  box-shadow: 0 8px 18px rgba(79,70,229,.28);
}

.services-pagination, .my-services-pagination {
  justify-content: center;
  margin-top: 1rem;
  gap: .8rem;
}

@media (max-width: 760px) {
  .services-shell, .my-services-shell { padding: 1rem; }
  .services-grid, .my-services-grid { grid-template-columns: 1fr; }
}


.password-field { display: flex; gap: .55rem; align-items: center; }
.password-field input { flex: 1 1 auto; }
.password-field .btn { flex: 0 0 auto; min-width: 72px; }

.cookie-consent {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 20000;
}
.cookie-consent-inner {
  max-width: 960px;
  margin: 0 auto;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: .9rem;
  box-shadow: var(--shadow);
}
.cookie-consent-title {
  margin: 0 0 .35rem;
  font-weight: 700;
}
.cookie-consent-actions {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-top: .65rem;
}

.admin-hide-check { margin-top: .9rem !important; background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; padding: .55rem .65rem; }

.admin-services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: .85rem; margin-top: .8rem; }
.admin-service-card p { margin: .25rem 0; word-break: break-word; }
.admin-service-card strong { color: var(--text); }


.service-tool-label { text-align: center; margin: .35rem 0 .55rem; font-weight: 600; }
.service-tool-launcher { margin: 0 auto 1rem; display: flex; justify-content: center; }
.btn-tool-launch { background: linear-gradient(90deg, #0ea5e9, #2563eb); color: #fff; padding-inline: 1.35rem; }
.service-tool-stage[hidden] { display: none !important; }
.service-tool-stage { position: fixed; inset: 0; z-index: 12000; display: grid; }
.service-tool-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.service-tool-shell { position: relative; z-index: 1; width: min(1200px, calc(100% - 1rem)); margin: .5rem auto; background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: .6rem; display: flex; flex-direction: column; min-height: calc(100vh - 1rem); }
.service-tool-host { width: 100%; flex: 1 1 auto; border: 1px solid var(--border); border-radius: 12px; background: var(--bg); color: var(--text); padding: .75rem; overflow: auto; }
.service-tool-stage[data-theme="dark"] .service-tool-host,
.service-tool-host[data-theme="dark"] { background: #0f172a; color: #e5e7eb; }
.service-tool-stage[data-theme="light"] .service-tool-host,
.service-tool-host[data-theme="light"] { background: #ffffff; color: #0f172a; }
.gw-tool-theme-root { min-height: 100%; background: inherit; color: inherit; }
.service-tool-close { position: sticky; top: 8px; left: 50%; transform: translateX(-50%); z-index: 12; margin: 0 auto .65rem; box-shadow: var(--shadow); }
