 /* =========================================
   InSite — Landing + Portal (colorful + dark)
   ========================================= */

/* ---------- THEME ---------- */
:root {
  --bg:#f3f6fd; --bg2:#eef2fb; --text:#101828; --muted:#667085;
  --card:#ffffff; --border:#e5e7f1; --shadow:0 10px 28px rgba(16,24,40,.08);
  --accent:#3b82f6; --accent-600:#2563eb; --accent-50:#eef2ff;
  --accent-2:#22c55e; --danger:#ef4444;
  --btn-bg:#f1f5ff; --btn-text:#0f172a; --btn-border:#cfe0ff;
  --table-head:#f7f9ff; --tab-inactive:#e9eefb;
  --input:#fff; --radius:12px;
}
[data-theme="dark"]{
  --bg:#0f1726; --bg2:#0b1422; --text:#eaf0ff; --muted:#9fb0c7;
  --card:#121a2a; --border:#1f2a41; --shadow:0 12px 28px rgba(0,0,0,.35);
  --btn-bg:#1b2640; --btn-text:#eaf0ff; --btn-border:#2b3a5a;
  --table-head:#14203a; --tab-inactive:#15213b; --input:#0f1726;
}

/* Lessen hero text shadow in dark mode so text stays bright */
[data-theme="dark"] #landing-view .hero-title, [data-theme="dark"] #landing-view .hero-sub {
  text-shadow: 0 2px 6px rgba(0,0,0,0.35);
}

/* In dark mode use the theme text color for hero to ensure contrast */
[data-theme="dark"] #landing-view .hero-title, [data-theme="dark"] #landing-view .hero-sub { color: var(--text); }

/* ---------- GLOBAL ---------- */
*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 10% -10%, var(--bg2), transparent 60%),
    radial-gradient(900px 500px at 120% 0%, var(--accent-50), transparent 50%),
    var(--bg);
  transition: background .25s ease, color .25s ease;
}

/* Opt-in full-viewport hero background for landing view only.
   Add class `hero-full` to <body> to enable. No parallax, just fixed background. */
body.hero-full::before{
  content:'';
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.45)),
    url('dubaiskyline.jpeg') center/cover no-repeat;
}

@media (max-width:720px){
  body.hero-full::before{ background-attachment:scroll; background-position:center top; }
}

/* Fix: ensure topbar controls remain readable when the landing full-viewport image is active
   but only in light mode (dark mode already has good contrast). This forces light text and
   adjusts borders/backgrounds so buttons and the language select are visible over the image. */
:html:not([data-theme="dark"]) body.hero-full .topbar,
html:not([data-theme="dark"]) body.hero-full .topbar .brand,
html:not([data-theme="dark"]) body.hero-full .topbar .brand *{
  color: #fff !important;
}
html:not([data-theme="dark"]) body.hero-full .topbar .btn{
  color:#fff !important; border-color: rgba(255,255,255,0.22) !important; background: transparent !important;
}
html:not([data-theme="dark"]) body.hero-full .topbar .btn.primary{
  background: rgba(255,255,255,0.06) !important; color:#fff !important; border-color: rgba(255,255,255,0.06) !important;
}
html:not([data-theme="dark"]) body.hero-full .topbar .lang-switch select{
  color:#fff !important; background: rgba(255,255,255,0.06) !important; border-color: rgba(255,255,255,0.16) !important;
}
 
a{ color:inherit; text-decoration:none; }
.hidden{ display:none; }
.app{ max-width:1100px; margin:24px auto; padding:0 16px; }

/* ---------- TOP BAR ---------- */
.topbar{ display:flex; align-items:center; justify-content:space-between; padding:10px 0 0; position:relative; z-index:60; }
.brand-btn{ background:none; border:none; cursor:pointer; padding:0; }
.brand #app-title{
  font-weight:800; letter-spacing:.2px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  font-size:1.25rem;
}
.topbar-controls{ display:flex; align-items:center; gap:10px; }
.lang-switch select{
  background:var(--card); color:var(--text); border:1px solid var(--border);
  padding:8px 10px; border-radius:10px;
}
#theme-toggle{ border-radius:10px; }

/* ---------- HAMBURGER MENU ---------- */
.hamburger{ display:flex; align-items:center; gap:8px; font-weight:800; }
.menu-list{ list-style:none; margin:0; padding:8px; position:absolute; background:var(--card); border:1px solid var(--border); box-shadow:var(--shadow); border-radius:10px; min-width:160px; z-index:48; transform-origin:top right; opacity:0; transform:translateY(-6px) scale(.98); transition:opacity .18s ease, transform .18s ease; pointer-events:none; }
.menu-list.visible{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.menu-list.hidden{ display:block; }
.tabs{ position:relative; }
.menu-item{ display:block; width:100%; text-align:left; padding:8px 10px; background:transparent; border:none; color:var(--text); border-radius:8px; cursor:pointer; font-weight:700; }
.menu-item:hover, .menu-item:focus{ background:color-mix(in srgb, var(--accent-50) 12%, var(--card)); outline:none; }

/* Ensure menu stacks well on small screens */
@media (max-width:720px){
  .topbar-controls{ gap:8px; }
  .menu-list{ right:8px; left:auto; }
}

/* ---------- CARDS ---------- */
.card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  padding:20px; margin:16px 0; box-shadow:var(--shadow);
}
.dashboard-header{ display:flex; align-items:center; justify-content:space-between; }
.subtitle{ color:var(--muted); }
.hint{ color:var(--muted); }
.error{ color:var(--danger); }

/* ---------- LANDING ---------- */
.landing .hero{ text-align:center; padding:16px 8px 6px; }
.hero-title{ font-size:2.25rem; margin:2px 0 6px; font-weight:900; }
.brand-gradient{ background:linear-gradient(90deg, var(--accent), var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-sub{ color:var(--muted); margin:0 0 16px; }
.hero-ctas{ display:flex; justify-content:center; gap:10px; margin-bottom:8px; }

/* Make landing card translucent so the full-bleed image shows through while keeping content readable */
.landing.card{ background: linear-gradient(180deg, rgba(18,26,42,0.72), rgba(18,26,42,0.62)); border-color: rgba(255,255,255,0.06); box-shadow:none; backdrop-filter: blur(4px); color: #f6f9ff; }
.landing .feature-card{ background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.06); }

/* ---------- ABOUT PAGE ---------- */
.about-page .about-hero{ position:relative; overflow:hidden; border-radius:12px; margin-bottom:16px; }
.about-page .about-hero img{ width:100%; height:220px; object-fit:cover; display:block; filter:brightness(.6); }
.about-page .about-hero-text{ position:absolute; left:20px; bottom:18px; color:#fff; }
.about-page .about-hero-text h1{ margin:0 0 6px; font-size:1.8rem; }
.about-content{ display:grid; grid-template-columns:2fr 1fr; gap:16px; }
.about-content .team .team-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.team-member{ text-align:center; padding:12px; border-radius:10px; background:var(--card); border:1px solid var(--border); }
.team-member img{ width:72px; height:72px; border-radius:50%; object-fit:cover; background:var(--input); display:block; margin:0 auto 8px; }
.avatar{ width:72px; height:72px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#fff; font-weight:800; font-size:1.05rem; margin:0 auto 8px; }
.team-member h3{ margin:8px 0 6px; }
.about-page .about-hero-text p{ margin:0; font-size:1rem; opacity:.95; }
.about-content .card h2{ margin-top:0; }
.about-content .team .team-grid{ gap:18px; }
.about-content .links ul{ margin:0; padding-left:18px; }
.about-content .links li{ margin:8px 0; }
.about-content .legal{ font-size:.95rem; color:var(--muted); }

@media (max-width:980px){ .about-content{ grid-template-columns:1fr; } .about-page .about-hero img{ height:180px; } .about-page .about-hero-text{ left:12px; bottom:12px; } }

.features{
  display:grid;
  /* responsive: fit as many 220px columns as possible */
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:20px; margin-top:18px; align-items:start; max-width:1100px; margin-left:auto; margin-right:auto;
}
.feature-card{
  border-radius:12px; padding:20px; display:flex; flex-direction:column; justify-content:flex-start;
  min-height:220px; transition:transform .22s cubic-bezier(.2,.9,.2,1), box-shadow .22s ease, background .18s ease;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border:1px solid rgba(255,255,255,0.04);
  box-shadow: 0 8px 20px rgba(2,6,23,0.12);
  display:flex; gap:12px; padding:18px;
}
.feature-card h3{ margin:0 0 6px; font-size:1.08rem; }
.feature-card p{ margin:0 0 10px; color:var(--muted); font-size:0.98rem; line-height:1.35; }
.feature-card:hover{ transform:translateY(-8px) scale(1.01); box-shadow:0 22px 44px rgba(2,6,23,0.22); }

/* Icon style similar to Zoho cards: circular, colorful */
.feature-icon{ width:48px; height:48px; border-radius:12px; display:inline-grid; place-items:center; background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#fff; flex-shrink:0; }
.feature-icon svg{ width:20px; height:20px; stroke:#fff; }

/* Content layout: keep list and CTA tidy */
.feature-card ul{ margin:8px 0 0 0; padding:0; list-style:none; color:var(--muted); }
.feature-card li{ margin:8px 0; padding-left:22px; position:relative; font-size:0.95rem; }
.feature-card li::before{ content:''; position:absolute; left:6px; top:10px; width:8px; height:8px; background:rgba(255,255,255,0.14); border-radius:50%; box-shadow:0 0 0 4px rgba(255,255,255,0.02) inset; }

.feature-cta{ margin-top:auto; width:100%; display:flex; justify-content:flex-start; }
.feature-cta .btn{ padding:8px 12px; font-weight:700; border-radius:8px; }

/* Make icons and heading align horizontally on wide cards */
.feature-card > .feature-icon + h3{ margin-left:8px; }
.feature-card-header{ display:flex; gap:12px; align-items:center; }

@media (max-width:720px){
  .features{ grid-template-columns: 1fr; }
  .feature-card{ min-height:auto; }
  .feature-card li::before{ left:0; top:9px; }
}

/* Make sure cards remain readable over the translucent hero */
.landing .feature-card{ background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02)); border-color: rgba(255,255,255,0.06); }
.feature-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  padding: 1.25rem;
  border-radius: 12px;
  min-height: 120px;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  transition: transform 220ms ease, box-shadow 220ms ease;
  will-change: transform;
  box-shadow: 0 1px 0 rgba(255,255,255,0.02) inset;
}

/* Icon inside feature cards */
.feature-icon {
  color: var(--muted-1, #cbd5e1);
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  background: rgba(255,255,255,0.02);
  border-radius: 8px;
  padding: 4px;
}
.feature-icon svg { display: block; width: 22px; height: 22px; }

/* Entrance animation */
.feature-card.animated { opacity: 0; transform: translateY(8px) scale(0.995); }
.feature-card.visible { opacity: 1; transform: none; }
.feature-card[data-dir="left"].animated { transform: translateX(-28px) scale(0.995); }
.feature-card[data-dir="right"].animated { transform: translateX(28px) scale(0.995); }
.feature-card[data-dir="up"].animated { transform: translateY(18px) scale(0.995); }
.features[data-animate="stagger"] .feature-card { transition: opacity 420ms cubic-bezier(.2,.9,.2,1), transform 420ms cubic-bezier(.2,.9,.2,1); }

/* Stagger helpers (JS will set inline style --delay) */
.features[data-animate="stagger"] .feature-card { transition-delay: var(--delay, 0ms); }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .feature-card.animated, .features[data-animate="stagger"] .feature-card { transition: none !important; transform: none !important; opacity: 1 !important; }
}

/* pop-on-reveal */
.feature-card.visible{ transform: translateY(0) scale(1); box-shadow:0 26px 52px rgba(2,6,23,0.24); }

/* On narrow screens prefer vertical reveal to avoid horizontal clipping */
@media (max-width:720px){
  .feature-card[data-dir="left"].animated,
  .feature-card[data-dir="right"].animated { transform: translateY(12px) scale(0.995); }
}

/* Typography tweaks for a stronger visual identity */
h1, h2, h3 { font-weight: 600; letter-spacing: -0.01em; }
body { font-weight: 400; }
.landing .hero-title { font-size: clamp(1.4rem, 3.5vw, 2.25rem); line-height: 1.05; font-weight: 700; }
.feature-card h3 { font-size: 1.05rem; }
.feature-card p { color: var(--muted-2, #9aa4b2); font-size: 0.95rem; }

@media (max-width:980px){
  .features{ gap:12px; }
  .feature-card{ padding:16px; min-height:110px; }
}
@media (max-width:600px){
  .features{ grid-template-columns:1fr; gap:12px; }
  .hero-title{ font-size:1.6rem; }
  .feature-card{ padding:14px; min-height:100px; }
}

/* ---------- BUTTONS ---------- */
.btn{
  background:var(--btn-bg); color:var(--btn-text); border:1px solid var(--btn-border);
  border-radius:10px; padding:10px 14px; cursor:pointer; font-weight:700;
  transition: transform .1s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover{ transform:translateY(-1px); box-shadow:0 8px 16px rgba(0,0,0,.06); }
.btn.primary{ background:var(--accent); color:#fff; border-color:transparent; }
.btn.primary:hover{ background:var(--accent-600); }
.btn.ghost{ background:transparent; color:var(--text); border:1px solid var(--btn-border); }
.btn.danger{ background:transparent; color:var(--danger); border-color:var(--danger); }

/* ---------- TABS ---------- */
.tab-panel.hidden{ display:none; }

/* ---------- FORMS ---------- */
.form-grid{
  display:grid; grid-template-columns:1fr 1fr; column-gap:14px; row-gap:12px; align-items:center;
}
.form-grid label{ color:var(--muted); font-weight:600; }
.form-grid input, .form-grid select{
  background:var(--input); color:var(--text); border:1px solid var(--border);
  border-radius:10px; padding:10px 12px; font-size:.95rem; width:100%;
  transition:border-color .15s, box-shadow .15s, background .25s ease;
}
.form-grid input:focus, .form-grid select:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(59,130,246,.25);
}
.form-actions{ grid-column:1 / -1; display:flex; justify-content:flex-end; gap:10px; margin-top:2px; }

/* Login single column */
#login-form.form-grid{ grid-template-columns:1fr; }
#btn-signin{ justify-self:end; }

/* ROI helper alignment */
#calc-price-eur-note{ grid-column:2 / 3; justify-self:start; margin-top:-6px; color:var(--muted); font-size:.9rem; }

/* ---------- TABLES ---------- */
.table-scroll{ overflow-x:auto; border:1px solid var(--border); border-radius:12px; }
table{ width:100%; border-collapse:collapse; }
thead th{ background:var(--table-head); color:var(--muted); padding:12px; text-align:left; border-bottom:1px solid var(--border); font-weight:700; }
tbody td{ padding:12px; border-bottom:1px solid var(--border); }
tbody tr:last-child td{ border-bottom:none; }
.actions-col{ width:280px; }
.client-price{ color:var(--accent-600); font-weight:800; white-space:nowrap; }

/* ---------- SUGGESTIONS ---------- */
.suggestions{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:12px; }
.suggest-card{ border:1px solid var(--border); border-radius:12px; padding:14px;
  background:linear-gradient(180deg, var(--card), color-mix(in srgb, var(--accent-50) 14%, var(--card))); }
.suggest-title{ font-weight:800; margin-bottom:6px; }
.suggest-meta{ color:var(--muted); }
.suggest-cta{ display:flex; gap:8px; margin-top:10px; }

/* ---------- SNAPSHOT ---------- */
.snapshot{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:12px; }
.snap-card{ border:1px solid var(--border); border-radius:12px; padding:14px;
  background:linear-gradient(180deg, var(--card), color-mix(in srgb, var(--accent-50) 10%, var(--card))); }
.snap-label{ color:var(--muted); font-weight:600; }
.snap-value{ font-weight:900; font-size:1.15rem; }
.snap-value.small{ font-weight:700; font-size:1rem; }

/* ---------- DATETIME INPUT ---------- */
input[type="datetime-local"]{ font-variant-numeric:tabular-nums; letter-spacing:.2px; }
input[type="datetime-local"]::-webkit-datetime-edit-fields-wrapper{ padding:0 3px; }
input[type="datetime-local"]::-webkit-calendar-picker-indicator{ filter:invert(.2); opacity:.75; cursor:pointer; }
[data-theme="dark"] input[type="datetime-local"]::-webkit-calendar-picker-indicator{ filter:invert(1) brightness(1.2); opacity:.85; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px){
  .features{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .suggestions, .snapshot{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 720px){
  .form-grid{ grid-template-columns:1fr; }
  #calc-price-eur-note{ grid-column:1 / -1; }
  .features, .suggestions, .snapshot{ grid-template-columns:1fr; }
}
/* Enforce dark-only appearance without editing HTML: */
/* Hide the theme toggle UI if present and ensure dark tokens are used by default */
#theme-toggle { display:none !important; }
/* Force dark color variables as a safety net so the site renders dark even if data-theme isn't set */
:root {
  --bg:#0f1726; --bg2:#0b1422; --text:#eaf0ff; --muted:#9fb0c7;
  --card:#121a2a; --border:#1f2a41; --shadow:0 12px 28px rgba(0,0,0,.35);
  --btn-bg:#1b2640; --btn-text:#eaf0ff; --btn-border:#2b3a5a;
  --table-head:#14203a; --tab-inactive:#15213b; --input:#0f1726;
}

/* Zoho-like split showcase */
.fea-slide-main{ display:flex; gap:28px; align-items:stretch; margin-top:28px; }
.feature-l{ flex:1.2; position:relative; min-height:320px; }
.feature-r{ flex:1; display:flex; flex-direction:column; gap:12px; }
.featured-img{ position:relative; width:100%; height:100%; border-radius:12px; overflow:hidden; background:linear-gradient(180deg,#071025, #0f1726); }
.featured-comb{ position:relative; width:100%; height:100%; }
.featured-comb .bg-pattern img{ width:120%; height:120%; object-fit:cover; opacity:0.14; filter:grayscale(.2) brightness(.6); transform:translate(-6%, -6%); }
.fimg{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:0; transform:translateY(12px) scale(.98); transition:opacity .5s ease, transform .5s cubic-bezier(.2,.9,.2,1); }
.fimg img{ max-width:82%; height:auto; display:block; }
.fimg.active{ opacity:1; transform:none; }

.feature-r .feature-item{ background:transparent; padding:12px 10px; border-radius:10px; cursor:pointer; transition:transform .22s ease, background .18s ease; opacity:0.9; }
.feature-r .feature-item .item-content h3{ margin:0 0 6px; font-size:1.05rem; }
.feature-r .feature-item .item-content p{ margin:0; color:var(--muted); }
.feature-r .feature-item.active{ background: linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)); transform:translateX(0); box-shadow: 0 18px 36px rgba(2,6,23,0.16); }
.feature-r .feature-item:not(.active){ transform:translateX(-12px); }

@media (max-width:980px){ .fea-slide-main{ flex-direction:column; } .feature-l{ order:2; } .feature-r{ order:1; } .fimg img{ max-width:100%; } }

@media (prefers-reduced-motion: reduce){ .fimg, .feature-r .feature-item { transition:none !important; transform:none !important; opacity:1 !important; } }
