/* =================================================================
   GeneralATM — UI mockup components for the Product Tour.
   Faithful recreations of the REAL production UI, rebuilt from the
   live v1 stylesheet (main.less) + markup (blocks.php).
   Real design tokens:
     @accent #2189AD · @accent2 #c7e1e2 · @accent3 #eaf6f7
     @light #F0F0F0 · @green #14c130 · @red #9B0303 · @highlight #fffecf
     font: Open Sans 14px · dense flat gray admin UI, white teal-bordered boxes
   The MOBILE app is a separate modern Solid/Tailwind app, so .m* stays clean.
   ================================================================= */

:root{
  --g-accent:#2189AD; --g-accent2:#c7e1e2; --g-accent3:#eaf6f7;
  --g-light:#F0F0F0; --g-green:#14c130; --g-red:#9B0303; --g-hi:#fffecf; --g-grey:#293033;
  /* fallbacks for tokens used by mobile/tour helpers (kept self-contained) */
  --shadow-lg:0 18px 50px rgba(15,25,30,.16); --slate:#46535a; --green-700:#0f7d23; --green:#14c130; --blue:#1f7f9e;
}

/* ---- window / device chrome ---- */
.frame { border-radius: 10px; overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--line); background: #fff; }
.frame__bar { display: flex; align-items: center; gap: .5rem; padding: .5rem .8rem; background: #e9edee; border-bottom: 1px solid #d6dee0; }
.frame__bar i { width: 10px; height: 10px; border-radius: 999px; background: #c7cfd1; }
.frame__bar i:nth-child(1){ background:#ff5f57;} .frame__bar i:nth-child(2){ background:#febc2e;} .frame__bar i:nth-child(3){ background:#28c840;}
.frame__url { margin-left: .6rem; font-size: .72rem; color: #6b777c; background: #fff; border: 1px solid #d6dee0; border-radius: 4px; padding: .18rem .6rem; flex: 1; max-width: 360px; }

/* ===== REAL WEB CONSOLE (dense, gray, Open Sans, teal accents) ===== */
.gatm{ font-family:"Open Sans","Inter",sans-serif; font-size:13px; color:#000; background:var(--g-light); }
.gatm *{ box-sizing:border-box; }
/* top bar — the real app header is light with a teal logo + dark links */
/* real header: company-name logo (top-left) that drops a nav menu when clicked */
.gatm__top{ position:relative; display:flex; align-items:center; gap:.7rem; background:#fff; border-bottom:1px solid var(--g-accent2); padding:.5rem .9rem; }
.gatm__brand{ position:relative; }
.gatm__name{ font-family:"Open Sans","Inter",sans-serif; font-weight:700; color:var(--g-grey); font-size:.92rem; display:inline-flex; align-items:center; gap:.35rem; cursor:pointer; white-space:nowrap; }
.gatm__name .car{ color:var(--g-accent); font-size:.62rem; }
.gatm__menu{ position:absolute; top:150%; left:0; background:#fff; border:1px solid var(--g-accent2); border-radius:6px; box-shadow:0 10px 22px rgba(20,30,35,.16); min-width:158px; padding:4px; z-index:6; }
.gatm__menu a{ display:block; padding:7px 12px; font-size:.78rem; color:var(--g-grey); border-radius:4px; }
.gatm__menu a.on{ background:var(--g-accent3); color:var(--g-accent); font-weight:700; }
.gatm__search{ flex:1; max-width:190px; font-size:.72rem; color:#9aa3a6; background:var(--g-light); border:1px solid var(--g-accent2); border-radius:13px; padding:.24rem .7rem; }
.gatm__create{ font-size:.74rem; color:var(--g-accent); font-weight:600; white-space:nowrap; }
.gatm__top .r{ margin-left:auto; display:flex; align-items:center; gap:.55rem; font-size:.72rem; color:#888; }
.gatm__bell{ width:23px;height:23px;border-radius:50%;background:var(--g-light);display:grid;place-items:center;color:var(--g-accent);font-size:.62rem;border:1px solid var(--g-accent2); }
.gatm__acct{ width:23px;height:23px;border-radius:50%;background:linear-gradient(135deg,var(--g-accent),#0f7d23);color:#fff;display:grid;place-items:center;font-size:.6rem;font-weight:700; }

/* the 770 + 300 two-column layout, scaled into the frame */
.gatm__wrap{ display:grid; grid-template-columns:1fr 230px; gap:14px; padding:14px; }
@media (max-width:560px){ .gatm__wrap{ grid-template-columns:1fr; } }

/* white teal-bordered box (.box) */
.gbox{ background:#fff; border:1px solid var(--g-accent2); border-radius:10px; padding:14px; margin-bottom:14px; }
.gbox:last-child{ margin-bottom:0; }

/* ticket group card */
.gcase__h{ display:flex; align-items:flex-start; justify-content:space-between; gap:.5rem; }
.gcase__title{ font-size:15px; font-weight:700; color:#000; }
.gcase__title a{ color:#000; }
.gsel{ font-size:11px; border:1px solid var(--g-accent2); border-radius:4px; padding:.2rem .5rem; color:#000; background:#fff; }
.gcase__details{ font-size:13px; color:#333; padding:8px 0; }
.gsublinks{ display:flex; flex-wrap:wrap; gap:.9rem; font-size:11px; color:#888; border-top:1px solid var(--g-light); padding-top:8px; margin-top:4px; }
.gsublinks b{ color:var(--g-accent); }
.gtags{ display:flex; flex-wrap:wrap; gap:5px; margin:6px 0; }
.gtag{ font-size:11px; color:#000; background:var(--g-accent3); border:1px solid var(--g-accent2); border-radius:3px; padding:.1rem .45rem; }
.gtag b{ color:var(--g-accent); }

/* comment / message: white box, log-icon hanging left, gray timestamp */
.gmsg{ position:relative; background:#fff; border:1px solid var(--g-accent2); border-radius:8px; padding:9px 10px 9px 14px; margin:0 0 26px 34px; font-size:12.5px; color:#333; }
.gmsg__ic{ position:absolute; left:-34px; top:4px; width:24px; height:24px; border-radius:50%; background:var(--g-light); border:1px solid var(--g-accent2); display:grid; place-items:center; color:var(--g-accent); font-size:.7rem; }
.gmsg b{ color:#000; }
.gmsg__ts{ position:absolute; bottom:-19px; left:6px; font-size:11px; color:#a5b1b6; }
.gmsg__imgs{ display:flex; gap:5px; margin-top:7px; }
.gmsg__imgs span{ width:46px; height:46px; border-radius:4px; background:linear-gradient(135deg,#cdd6da,#eef2f3); border:1px solid var(--g-accent2); display:block; }
.greply{ display:flex; gap:6px; margin-top:6px; }
.greply input{ flex:1; border:1px solid var(--g-accent2); border-radius:4px; padding:.35rem .5rem; font:inherit; font-size:12px; color:#888; background:#fff; }

/* button — flat teal uppercase */
.gbtn{ display:inline-block; background:var(--g-accent); color:#fff; text-transform:uppercase; font-size:11px; letter-spacing:.03em; border:none; border-radius:4px; padding:.4rem .7rem; cursor:pointer; }
.gbtn--green{ background:var(--g-green); }
.gbtn--grey{ background:var(--g-light); color:#000; }

/* sidebar status feed */
.gside h4{ font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:#888; margin:0 0 8px; }
.gfeedrow{ display:flex; gap:7px; align-items:flex-start; font-size:11.5px; color:#555; padding:5px 0; border-bottom:1px solid var(--g-light); }
.gfeedrow .gi{ width:18px;height:18px;border-radius:50%;background:var(--g-light);display:grid;place-items:center;color:var(--g-accent);font-size:.6rem;flex:none; }

/* task preview rows (under a ticket group) */
.gtasks{ list-style:none; padding:0; margin:8px 0 0; font-size:12px; }
.gtask{ background:var(--g-light); border-radius:4px; padding:6px 8px; margin:3px 0; display:flex; align-items:center; gap:.5rem; }
.gtask .gnum{ color:#888; font-weight:700; }
.gtask .gpill{ margin-left:auto; }

/* status pills (text labels used in feed/dashboard) */
.gpill{ font-size:10px; font-weight:700; text-transform:uppercase; padding:.12rem .45rem; border-radius:3px; }
.gpill--open{ background:var(--g-accent3); color:var(--g-accent); }
.gpill--assigned{ background:#dff7e2; color:#0c8420; }
.gpill--closed{ background:#ececec; color:#888; }
.gpill--inv{ background:#efe7fb; color:#6b3fa0; }
.gpill--risk{ background:#f7dcdc; color:var(--g-red); }
.gpill--resolved{ background:var(--g-green); color:#06270d; }

/* ---- routing / dispatch: tech headers + dense gray tasklists + map ---- */
.gdispatch{ display:grid; grid-template-columns:280px 1fr; }
@media (max-width:560px){ .gdispatch{ grid-template-columns:1fr; } }
.gboard{ padding:0; border-right:1px solid var(--g-accent2); background:#fff; }
.gtech__h{ display:flex; align-items:center; gap:.5rem; background:#ddd; padding:8px 10px; font-size:11px; font-weight:700; color:#000; border-top:1px solid var(--g-grey); }
.gtech__h.open{ background:#fff; color:var(--g-accent); }
.gtech__h .sw{ width:10px; height:10px; border-radius:2px; }
.gtech__h .cnt{ margin-left:auto; background:#fff; border:1px solid var(--g-accent2); color:#888; font-size:10px; border-radius:12px; padding:0 7px; }
.grlist{ list-style:none; margin:0; padding:5px; font-size:11px; }
.grlist li{ background:var(--g-light); margin:2px 0; padding:6px 8px; border-radius:3px; position:relative; display:flex; gap:.5rem; align-items:center; }
.grlist li.sel{ background:var(--g-green); color:#06270d; }
.grlist li.link{ background:var(--g-hi); }
.grlist .gnum{ width:16px; height:16px; border-radius:3px; background:var(--g-grey); color:#fff; display:grid; place-items:center; font-size:9px; font-weight:700; flex:none; }
.grlist .grip{ margin-left:auto; color:#b9c0c3; }
.gmap{ position:relative; background:#e9eef0; min-height:320px; }
.gmap svg{ position:absolute; inset:0; width:100%; height:100%; }
.gmap__pin{ font:700 10px/1 "Inter",sans-serif; fill:#fff; }

/* ---- cash management dashboard (faithful: #EBEEF1 report grid, 'Jost' labels) ---- */
.cmrep{ background:#fff; border-radius:10px 10px 0 0; box-shadow:-4px 4px 8px #d7d7d7; overflow:hidden; font-size:12px; }
.cmrep__head{ display:grid; grid-template-columns:20% 24% 23% 23% 10%; background:#EBEEF1; font-family:"Jost","Inter",sans-serif; font-weight:500; font-size:13px; border-radius:10px 10px 0 0; }
.cmrep__head>div{ border-right:1px solid rgb(189,175,175); padding:11px 0 11px 14px; }
.cmrep__head>div:last-child{ border-right:0; }
.cmrep__row{ display:grid; grid-template-columns:20% 24% 23% 23% 10%; border-top:1px solid rgb(189,175,175); }
.cmrep__row:last-child{ border-bottom:1px solid rgb(189,175,175); }
.cmrep__row.today{ box-shadow:inset 5px 0 0 #BB2526; }
.cmcol{ border-right:1px solid rgb(189,175,175); padding:9px 12px; min-height:104px; }
.cmcol.td{ background:#EBEEF1; }
.cmcol:last-child{ border-right:0; }
.cmr{ display:flex; gap:6px; font-size:11px; line-height:18px; color:#333; }
.cmr .w{ width:13px; text-align:center; flex:none; }
.cmr .l{ font-weight:600; color:#000; }
.cmtid{ font-weight:700; color:#000; font-size:13px; margin-bottom:2px; }
.cm-ok{ color:green; } .cm-warn{ color:#FBA919; } .cm-err{ color:#BB2526; }
.cmnoreq{ display:grid; place-items:center; height:100%; font-style:italic; color:#c7c7c7; font-size:17px; font-weight:500; }
.cmmsel{ font-size:9px; border:1px solid #c7c7c7; border-radius:3px; color:#555; padding:1px 3px; }
.cmaxn{ display:grid; place-items:center; color:rgba(128,128,128,.7); font-size:13px; }

/* ---- forecast chart (white, real palette lines) ---- */
.gchart{ border:1px solid var(--g-accent2); border-radius:8px; padding:12px; background:#fff; }
.gchart .lg{ display:flex; gap:.9rem; font-size:11px; color:#555; margin-bottom:6px; flex-wrap:wrap; }
.gchart .lg i{ display:inline-block; width:16px; height:3px; border-radius:2px; margin-right:4px; vertical-align:middle; }
.gchart__wrap{ height:170px; }
.gchart__wrap svg{ width:100%; height:100%; }

/* ---- cash order cart ---- */
.gcart{ border:1px solid var(--g-accent2); border-radius:8px; overflow:hidden; background:#fff; }
.gcart__h{ display:flex; justify-content:space-between; align-items:center; padding:8px 11px; background:var(--g-accent3); font-size:12.5px; }
.gcart__h b{ color:#000; }
.gentry{ padding:8px 11px; border-top:1px solid var(--g-light); }
.gentry__t{ display:flex; justify-content:space-between; font-size:12px; }
.gentry__t b{ color:var(--g-accent); }
.gdenoms{ display:grid; grid-template-columns:repeat(4,1fr); gap:5px; margin-top:6px; }
.gdenom{ border:1px solid var(--g-accent2); border-radius:4px; padding:4px; text-align:center; }
.gdenom small{ display:block; font-size:9px; color:#888; }
.gdenom span{ font-size:12px; font-weight:700; color:#000; }

/* ===== MOBILE app (modern Solid/Tailwind — kept clean) ===== */
.phone { width: 290px; max-width: 100%; margin-inline: auto; border-radius: 34px; background: #11171a; padding: 10px; box-shadow: var(--shadow-lg); }
.phone__screen { background: #fff; border-radius: 26px; overflow: hidden; font-family:"Inter",sans-serif; }
.phone__notch { height: 20px; display: flex; justify-content: center; }
.phone__notch::after { content: ""; width: 100px; height: 16px; background: #11171a; border-radius: 0 0 14px 14px; }
.m { font-size: .8rem; }
.m__top { display: flex; align-items: center; justify-content: space-between; padding: .7rem .9rem; border-bottom: 1px solid #eef1f2; }
.m__top b { font-family:"Manrope",sans-serif; }
.m__date { display: flex; align-items: center; justify-content: center; gap: 1rem; padding: .5rem; font-size: .78rem; color: var(--slate); border-bottom: 1px solid #eef1f2; }
.mtask { padding: .65rem .9rem; border-bottom: 1px solid #eef1f2; border-left: 3px solid transparent; }
.mtask--active { border-left-color: #14c130; }
.mtask__t { display: flex; justify-content: space-between; align-items: center; }
.mtask__t b { font-family:"Manrope",sans-serif; font-size: .8rem; }
.mtask__sub { font-size: .68rem; color: var(--muted); margin-top: .15rem; }
.mtimer { text-align: center; padding: 1rem; }
.mtimer__t { font-family:"Manrope",sans-serif; font-weight: 800; font-size: 2rem; color: #14c130; }
.mbtn { display: block; text-align: center; margin: .6rem .9rem; padding: .6rem; border-radius: 10px; background: #14c130; color: #06270d; font-family:"Manrope",sans-serif; font-weight: 700; font-size: .8rem; }
.mbtn--ghost { background: transparent; border: 1.5px solid #e4e8ea; color: var(--slate); }
.mtabs { display: flex; border-top: 1px solid #eef1f2; }
.mtab { flex: 1; text-align: center; padding: .55rem; font-size: .62rem; color: var(--muted); }
.mtab.on { color: #0c8420; }
.mpill{ font-size:10px;font-weight:700;padding:.12rem .45rem;border-radius:3px;background:#eaf6f7;color:#2189AD; }
.mthumbs{ display:flex; gap:.3rem; } .mthumbs span{ width:42px;height:42px;border-radius:7px;background:linear-gradient(135deg,#cdd6da,#eef2f3);border:1px solid #e4e8ea;display:block; }

/* ---- tour layout helpers ---- */
.tour-screen { margin-block: clamp(2.5rem, 6vw, 4.5rem); }
.tour-screen .split { align-items: center; }
.kbd { font-size: .7rem; font-weight: 700; color: var(--green-700); background: rgba(20,193,48,.1); border: 1px solid rgba(20,193,48,.25); border-radius: 6px; padding: .12rem .45rem; }
.callouts { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .55rem; }
.callouts li { font-size: .92rem; color: var(--slate); padding-left: 1.6rem; position: relative; }
.callouts li::before { content: ""; position: absolute; left: 0; top: .3rem; width: 1rem; height: 1rem; border-radius: 999px; background: linear-gradient(135deg,var(--green),var(--blue)); }
.now-tag { display:inline-block; font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:.18rem .55rem; border-radius:999px; }
.now-tag--live { background: rgba(20,193,48,.15); color: var(--green-700); }
.now-tag--soon { background: #eef0f1; color: var(--muted); }
