/* ============================================================
   Funkmesh Deutschland — osTicket Client Frontend Theme
   Geladen NACH dem gebündelten osTicket-CSS. Überschreibt
   nur das Client-Frontend (Backend bleibt unangetastet).
   ============================================================ */

:root {
  --fm-bg: #f7fbfb;
  --fm-surface: #ffffff;
  --fm-surface-alt: #f0f6f6;
  --fm-text: #0b2424;
  --fm-muted: #4a6464;
  --fm-border: #d8e4e4;
  --fm-accent: #0f766e;
  --fm-accent-strong: #0d645d;
  --fm-accent-soft: #14b8a6;
  --fm-accent-2: #5eead4;
  --fm-shadow: 0 8px 24px -8px rgba(15, 118, 110, 0.18), 0 2px 6px rgba(11, 36, 36, 0.05);
  --fm-shadow-sm: 0 1px 2px rgba(15, 118, 110, 0.06);
  --fm-radius: 14px;
  --fm-radius-sm: 10px;
  --fm-grad: linear-gradient(135deg, #14b8a6 0%, #0f766e 100%);
  --fm-grad-bg: radial-gradient(circle at 0% 0%, rgba(94, 234, 212, 0.45) 0%, rgba(94, 234, 212, 0) 55%),
                radial-gradient(circle at 100% 100%, rgba(20, 184, 166, 0.32) 0%, rgba(20, 184, 166, 0) 55%),
                linear-gradient(180deg, #ffffff 0%, #ecfaf8 100%);
  --fm-maxw: 1180px;
  --fm-gutter: clamp(1rem, 3vw, 2rem);
}

/* ===== Base ===== */
html, body {
  background: var(--fm-bg) !important;
  color: var(--fm-text) !important;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  -webkit-font-smoothing: antialiased;
  margin: 0 !important; padding: 0 !important;
}
body { min-height: 100vh; display: flex; flex-direction: column; }

a { color: var(--fm-accent); text-decoration: none; }
a:hover { color: var(--fm-accent-strong); }

/* Container: full width with internal padding */
#container,
.container {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: 1;
}

/* ============== Header (Funkmesh brand bar) ============== */
#header {
  background: var(--fm-grad-bg) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--fm-border) !important;
  padding: 18px max(var(--fm-gutter), calc((100vw - var(--fm-maxw)) / 2)) !important;
  color: var(--fm-text) !important;
  position: relative; overflow: hidden;
  display: flex; flex-direction: row-reverse;
  align-items: center; justify-content: space-between; gap: 16px;
  min-height: 76px;
}
#header::after {
  content: ''; position: absolute; inset: auto 0 0 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(20, 184, 166, 0.5), transparent);
}

/* Replace default osTicket logo with our brand mark + wordmark */
#header #logo {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  gap: 14px;
  height: auto !important;
  text-decoration: none !important;
  float: none !important;
}
#header #logo img { display: none !important; }
#header #logo .valign-helper { display: none !important; }
#header #logo::before {
  content: '';
  width: 44px; height: 44px; flex: 0 0 44px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'><defs><linearGradient id='g' x1='0' y1='0' x2='1' y2='1'><stop offset='0%25' stop-color='%2314b8a6'/><stop offset='100%25' stop-color='%230f766e'/></linearGradient></defs><circle cx='24' cy='24' r='22' fill='url(%23g)'/><g fill='white' stroke='white' stroke-width='2'><circle cx='24' cy='24' r='3'/><circle cx='12' cy='14' r='2.5'/><circle cx='36' cy='14' r='2.5'/><circle cx='12' cy='34' r='2.5'/><circle cx='36' cy='34' r='2.5'/></g><g fill='none' stroke='white' stroke-width='2' stroke-linecap='round'><line x1='24' y1='24' x2='12' y2='14'/><line x1='24' y1='24' x2='36' y2='14'/><line x1='24' y1='24' x2='12' y2='34'/><line x1='24' y1='24' x2='36' y2='34'/></g></svg>");
  background-size: contain; background-repeat: no-repeat; background-position: center;
}
#header #logo::after {
  content: 'Funkmesh Deutschland';
  font-weight: 800; font-size: 1.15rem; letter-spacing: -0.01em; color: var(--fm-text);
  line-height: 1.1;
}

/* Right-side user info */
#header .pull-right.flush-right {
  text-align: right; color: var(--fm-muted); font-size: 0.92rem;
  float: none !important;
}
#header .pull-right p { margin: 0; }
#header .pull-right a {
  color: var(--fm-accent-strong); font-weight: 600;
  padding: 4px 8px; border-radius: 6px;
}
#header .pull-right a:hover { background: rgba(20, 184, 166, 0.12); }

/* Clear */
#container > .clear { display: none !important; }

/* ============== Nav (Tabs) ============== */
#nav {
  list-style: none;
  background: var(--fm-surface) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--fm-border) !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 6px max(var(--fm-gutter), calc((100vw - var(--fm-maxw)) / 2)) !important;
  box-shadow: 0 1px 2px rgba(15, 118, 110, 0.06);
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  height: auto !important;
}
#nav li {
  list-style: none; margin: 0 !important; padding: 0 !important;
  background: transparent !important;
  border: 0 !important; float: none !important;
}
#nav li a {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  background: transparent !important;
  color: var(--fm-text) !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  padding: 10px 16px !important;
  border-radius: var(--fm-radius-sm) !important;
  border: 0 !important;
  text-decoration: none !important;
  transition: background .15s ease, color .15s ease;
}
#nav li a:hover {
  background: var(--fm-surface-alt) !important;
  color: var(--fm-accent-strong) !important;
}
#nav li a.active {
  background: rgba(20, 184, 166, 0.12) !important;
  color: var(--fm-accent-strong) !important;
  font-weight: 600 !important;
  box-shadow: none !important;
}

/* ============== Content ============== */
#content {
  background: var(--fm-surface) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: var(--fm-radius) !important;
  box-shadow: var(--fm-shadow);
  padding: clamp(20px, 3vw, 32px) !important;
  margin: 28px max(var(--fm-gutter), calc((100vw - var(--fm-maxw)) / 2)) 28px !important;
  width: auto !important;
  max-width: none !important;
}

#content h1, #content h2, #content h3 {
  color: var(--fm-text);
  letter-spacing: -0.01em;
}
#content h1 { font-weight: 800; font-size: 1.6rem; margin: 0 0 16px; }
#content h2 { font-weight: 700; font-size: 1.35rem; margin: 0 0 14px; }
#content h3 { font-weight: 700; font-size: 1.1rem; }
#content ul { padding-left: 1.3em; margin: 0 0 16px; }
#content li { margin-bottom: 6px; }
#content p { margin: 0 0 12px; }

/* Landing page layout (#landing_page) */
#landing_page {
  display: flex;
  flex-direction: row-reverse;
  gap: 32px;
  align-items: flex-start;
}
#landing_page .main-content {
  flex: 1 1 auto;
  min-width: 0;
}
#landing_page .sidebar.pull-right {
  float: none !important;
  width: 280px !important;
  flex: 0 0 280px;
  display: flex; flex-direction: column; gap: 12px;
  margin: 0 !important;
}
#landing_page .sidebar .content { display: none !important; }
#landing_page .front-page-button {
  display: flex; flex-direction: column; gap: 12px;
  margin: 0 !important;
}
#landing_page .front-page-button p { margin: 0; }
#landing_page .front-page-button .button,
#landing_page .button {
  display: block !important;
  width: 100%;
  text-align: center;
}

/* ============== Buttons ============== */
.button, button,
input[type="submit"], input[type="button"],
.cta, a.button {
  background: var(--fm-grad) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--fm-radius-sm) !important;
  font-weight: 600 !important;
  font-size: 0.97rem !important;
  padding: 11px 22px !important;
  box-shadow: 0 6px 16px -4px rgba(15, 118, 110, 0.4);
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center; justify-content: center;
  line-height: 1.2 !important;
  font-family: inherit !important;
}
.button:hover, button:hover,
input[type="submit"]:hover, input[type="button"]:hover,
a.button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px -6px rgba(15, 118, 110, 0.5);
  color: #fff !important;
}

/* Secondary buttons (Reset, Cancel) */
input[type="reset"],
button.cancel, input.cancel,
input[value="Reset"], input[value="Zurücksetzen"], input[value="Cancel"], input[value="Abbrechen"] {
  background: var(--fm-surface-alt) !important;
  color: var(--fm-text) !important;
  box-shadow: none !important;
  border: 1px solid var(--fm-border) !important;
  font-weight: 600 !important;
}
input[type="reset"]:hover,
button.cancel:hover, input.cancel:hover,
input[value="Reset"]:hover, input[value="Zurücksetzen"]:hover, input[value="Cancel"]:hover, input[value="Abbrechen"]:hover {
  background: #e6efef !important;
  color: var(--fm-text) !important;
  transform: none;
}

/* "Blue" and "green" button color classes used by osTicket landing buttons */
a.button.blue { background: var(--fm-grad) !important; color: #fff !important; }
a.button.green {
  background: #fff !important;
  color: var(--fm-accent-strong) !important;
  border: 1px solid var(--fm-border) !important;
  box-shadow: var(--fm-shadow-sm) !important;
}
a.button.green:hover {
  background: var(--fm-surface-alt) !important;
  border-color: var(--fm-accent) !important;
  color: var(--fm-accent-strong) !important;
}

/* ============== Forms ============== */
input[type="text"], input[type="email"], input[type="password"],
input[type="tel"], input[type="number"], input[type="url"],
textarea, select {
  border: 1px solid var(--fm-border) !important;
  border-radius: var(--fm-radius-sm) !important;
  padding: 10px 12px !important;
  font: inherit !important;
  background: #fff !important;
  color: var(--fm-text) !important;
  transition: border-color .15s ease, box-shadow .15s ease;
  width: auto;
  max-width: 100%;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="password"]:focus,
input[type="tel"]:focus, input[type="number"]:focus, textarea:focus, select:focus {
  outline: none !important;
  border-color: var(--fm-accent) !important;
  box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.15) !important;
}
label, strong.error { color: var(--fm-text); }
label { font-weight: 500; }

table.fixed {
  width: 100%;
  border-collapse: collapse;
}

/* Asterisk for required fields */
.error, strong.error { color: #b91c1c !important; }

/* ============== Messages ============== */
.msg, #msg_notice, #msg_warning, #msg_error,
.notice_bar, .warning_bar, .error_bar {
  border-radius: var(--fm-radius-sm) !important;
  border: 1px solid transparent !important;
  padding: 12px 14px !important;
  margin: 16px max(var(--fm-gutter), calc((100vw - var(--fm-maxw)) / 2)) !important;
}
#msg_notice, .notice_bar  { background: rgba(20, 184, 166, 0.08) !important; border-color: rgba(20, 184, 166, 0.3) !important; color: var(--fm-accent-strong) !important; }
#msg_warning, .warning_bar { background: #fff7ed !important; border-color: #fed7aa !important; color: #9a3412 !important; }
#msg_error, .error_bar { background: #fef2f2 !important; border-color: #fecaca !important; color: #991b1b !important; }

/* ============== Footer ============== */
#footer {
  background: #0b2424 !important;
  color: #b4d4d0 !important;
  border: 0 !important;
  padding: 24px max(var(--fm-gutter), calc((100vw - var(--fm-maxw)) / 2)) !important;
  margin: 0 !important;
  border-radius: 0 !important;
  text-align: center;
  font-size: 0.9rem;
}
#footer p { margin: 0; color: #b4d4d0 !important; }
#footer a { color: #fff !important; }
#footer #poweredBy,
#footer a[href*="osticket.com"],
.powered-by, .poweredBy {
  display: none !important;
}

/* ============== Misc cleanup ============== */
.pull-right { float: right; }
.pull-left { float: left; }
.flush-right { text-align: right; }
.flush-left { text-align: left; }

.thread-body { font-size: 1rem; line-height: 1.65; }

/* Form rows */
form .row, form fieldset { margin-bottom: 14px; }
fieldset { border: 1px solid var(--fm-border); border-radius: var(--fm-radius-sm); padding: 16px; }
fieldset legend { font-weight: 600; padding: 0 8px; }

/* Tables for ticket listings */
table.list, table.list2 {
  width: 100%; border-collapse: collapse;
  background: #fff; border-radius: var(--fm-radius-sm); overflow: hidden;
}
table.list th, table.list2 th {
  background: var(--fm-surface-alt) !important;
  color: var(--fm-text) !important;
  font-weight: 600; padding: 10px 12px; text-align: left;
  border-bottom: 1px solid var(--fm-border);
}
table.list td, table.list2 td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--fm-border);
}

/* ============== Responsive ============== */
@media (max-width: 880px) {
  #landing_page { grid-template-columns: 1fr; }
  #landing_page .sidebar.pull-right { order: 0; }
}
@media (max-width: 680px) {
  #header { flex-wrap: wrap; padding: 14px var(--fm-gutter) !important; min-height: 0; }
  #header #logo::after { font-size: 1rem; }
  #header #logo::before { width: 36px; height: 36px; flex-basis: 36px; }
  #header .pull-right { width: 100%; text-align: left; }
  #nav { padding: 4px var(--fm-gutter) !important; }
  #nav li a { padding: 9px 12px !important; }
  #content { margin: 16px var(--fm-gutter) !important; padding: 18px !important; }
  #footer { padding: 20px var(--fm-gutter) !important; }
}
