/* ===========================================================
   Arhive GMR — Shop online
   Design system: institutional, clean, B2B, document-security
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Source+Serif+4:opsz,wght@8..60,400;8..60,600;8..60,700&display=swap');

:root{
  /* Brand */
  --navy:#0E2A47;
  --navy-600:#163a5e;
  --navy-400:#345f8a;
  --navy-100:#e8eef5;
  --gold:#C2A14D;          /* restrained archival accent */
  --gold-soft:#f3ecd8;

  /* Ink + neutrals */
  --ink:#16202e;
  --slate:#46546a;
  --muted:#7a879b;
  --line:#e3e8f0;
  --line-strong:#cdd6e2;
  --bg:#f4f7fa;
  --card:#ffffff;

  /* Status */
  --ok:#1f7a4d;   --ok-bg:#e7f3ec;
  --warn:#946200; --warn-bg:#f7eed6;
  --info:#1d5fa8; --info-bg:#e6eff7;
  --danger:#b4232a; --danger-bg:#fbe9e9;
  --done:#2c3e50; --done-bg:#e9edf2;

  /* Form */
  --radius:7px;
  --radius-lg:12px;
  --shadow-sm:0 1px 2px rgba(14,42,71,.06);
  --shadow:0 6px 24px -12px rgba(14,42,71,.28);
  --ring:0 0 0 3px rgba(52,95,138,.22);

  --maxw:1120px;
  --font-body:'Public Sans', system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-head:'Source Serif 4', Georgia, 'Times New Roman', serif;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--navy-600);text-decoration:none;}
a:hover{color:var(--navy);}
img{max-width:100%;display:block;}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--navy);line-height:1.18;margin:0;font-weight:600;letter-spacing:-.01em;}
p{margin:0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ----------------------------------------------------------
   Buttons
   ---------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;line-height:1;
  padding:.78em 1.3em;border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;text-decoration:none;
  transition:background .15s,border-color .15s,color .15s,transform .05s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy);}
.btn-primary:hover{background:var(--navy-600);color:#fff;}
.btn-ghost{background:#fff;color:var(--navy);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--navy-400);background:var(--navy-100);color:var(--navy);}
.btn-gold{background:var(--gold);color:#3a2f10;border-color:var(--gold);}
.btn-gold:hover{filter:brightness(.96);color:#3a2f10;}
.btn-lg{font-size:1.02rem;padding:.95em 1.6em;}
.btn-block{display:flex;width:100%;}
.btn-link{background:none;border:none;color:var(--navy-600);font-weight:600;padding:.4em .2em;cursor:pointer;}

/* ----------------------------------------------------------
   Top accent + Header
   ---------------------------------------------------------- */
.brandbar{height:3px;background:linear-gradient(90deg,var(--gold) 0%,var(--gold) 60%,var(--navy-400) 100%);}
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px;}
.logo{display:flex;align-items:center;gap:12px;color:var(--navy);}
.logo .mark{width:38px;height:38px;flex:none;}
.logo .name{font-family:var(--font-head);font-weight:700;font-size:1.28rem;letter-spacing:.01em;line-height:1;}
.logo .name span{display:block;font-family:var(--font-body);font-weight:500;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:4px;}
.header-nav{display:flex;align-items:center;gap:8px;}
.header-nav a.navlink{color:var(--slate);font-weight:500;font-size:.92rem;padding:.55em .8em;border-radius:6px;}
.header-nav a.navlink:hover{color:var(--navy);background:var(--navy-100);}

/* ----------------------------------------------------------
   Hero
   ---------------------------------------------------------- */
.hero{background:
    radial-gradient(120% 140% at 85% -20%, rgba(52,95,138,.10), transparent 55%),
    linear-gradient(180deg,#fff 0%,var(--bg) 100%);
  border-bottom:1px solid var(--line);}
.hero .wrap{padding-top:64px;padding-bottom:56px;}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-size:.74rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block;}
.hero h1{font-size:clamp(2rem,4.4vw,3.15rem);max-width:18ch;margin:18px 0 0;}
.hero .lead{font-size:1.2rem;color:var(--slate);max-width:54ch;margin-top:18px;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:26px;margin-top:38px;padding-top:26px;border-top:1px solid var(--line);}
.hero-trust .item{display:flex;align-items:center;gap:10px;color:var(--slate);font-size:.92rem;font-weight:500;}
.hero-trust .item svg{color:var(--navy-400);flex:none;}

/* ----------------------------------------------------------
   Section scaffolding
   ---------------------------------------------------------- */
.section{padding:64px 0;}
.section.alt{background:#fff;border-block:1px solid var(--line);}
.section-head{max-width:62ch;margin-bottom:36px;}
.section-head h2{font-size:clamp(1.6rem,2.8vw,2.2rem);}
.section-head p{color:var(--slate);font-size:1.08rem;margin-top:12px;}

/* ----------------------------------------------------------
   Service grid
   ---------------------------------------------------------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px 24px 24px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  transition:border-color .15s,box-shadow .15s,transform .15s;position:relative;overflow:hidden;}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--gold);
  opacity:0;transition:opacity .15s;}
.svc-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-3px);}
.svc-card:hover::before{opacity:1;}
.svc-ico{width:46px;height:46px;border-radius:10px;background:var(--navy-100);color:var(--navy);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.svc-card h3{font-size:1.22rem;}
.svc-card .desc{color:var(--slate);font-size:.96rem;margin-top:10px;flex:1;}
.svc-price{display:flex;align-items:baseline;gap:8px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line);}
.svc-price .amount{font-family:var(--font-head);font-weight:700;font-size:1.5rem;color:var(--navy);white-space:nowrap;}
.svc-price .unit{color:var(--muted);font-size:.92rem;font-weight:500;white-space:nowrap;}
.svc-card .btn{margin-top:18px;}
.tag-variable{display:inline-block;font-size:.72rem;font-weight:600;color:var(--info);background:var(--info-bg);
  padding:.25em .6em;border-radius:5px;margin-top:14px;letter-spacing:.02em;}
.svc-card h3 a{color:inherit;}
.svc-card h3 a:hover{color:var(--navy-600);}
.svc-actions{display:flex;gap:10px;margin-top:18px;}
.svc-actions .btn{flex:1;}

/* ----------------------------------------------------------
   Service detail page (service.php)
   ---------------------------------------------------------- */
.svc-hero{background:
    radial-gradient(120% 140% at 88% -30%, rgba(52,95,138,.10), transparent 55%),
    linear-gradient(180deg,#fff 0%,var(--bg) 100%);
  border-bottom:1px solid var(--line);padding:26px 0 56px;}
.svc-hero .breadcrumb{margin-bottom:26px;}
.svc-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.svc-hero-text h1{font-size:clamp(1.9rem,3.6vw,2.85rem);margin:16px 0 0;max-width:16ch;}
.svc-hero-text .lead{font-size:1.16rem;color:var(--slate);margin-top:18px;max-width:46ch;}
.svc-hero-price{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:26px;
  padding-top:22px;border-top:1px solid var(--line);}
.svc-hero-price .ph-amount{display:flex;align-items:baseline;gap:8px;white-space:nowrap;}
.svc-hero-price .amount{font-family:var(--font-head);font-weight:700;font-size:2rem;color:var(--navy);white-space:nowrap;}
.svc-hero-price .unit{color:var(--muted);font-size:1rem;font-weight:500;white-space:nowrap;}
.svc-hero-price .tag-variable{margin-top:0;}
.svc-hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px;}

/* Photo / placeholder */
.svc-photo{margin:0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:#fff;aspect-ratio:4/3;}
.svc-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.svc-photo.is-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  background:
    radial-gradient(120% 120% at 30% 0%, rgba(255,255,255,.06), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 2px, transparent 2px 12px),
    linear-gradient(150deg,var(--navy) 0%, #0b2238 100%);
  color:rgba(255,255,255,.55);border:1px solid var(--navy-600);}
.svc-photo.is-placeholder .ph-ico{width:108px;height:108px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--gold);
  background:rgba(255,255,255,.05);border:1px solid rgba(194,161,77,.4);}
.svc-photo.is-placeholder .ph-tag{font-family:var(--font-body);font-size:.7rem;font-weight:600;
  letter-spacing:.26em;text-transform:uppercase;color:rgba(159,180,204,.8);}

/* Body: description + includes */
.svc-body-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start;}
.svc-body-text h2{font-size:clamp(1.5rem,2.6vw,2rem);margin-bottom:16px;}
.svc-body-text p{color:var(--slate);font-size:1.06rem;margin-bottom:16px;max-width:62ch;}
.svc-body-text p:last-child{margin-bottom:0;}
.svc-includes{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);padding:26px 26px 24px;position:sticky;top:96px;}
.svc-includes h3{font-size:1.18rem;margin-bottom:16px;}
.check-list{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:12px;}
.check-list li{display:flex;align-items:flex-start;gap:11px;color:var(--ink);font-size:.96rem;line-height:1.45;}
.check-list li svg{flex:none;margin-top:2px;color:var(--ok);background:var(--ok-bg);border-radius:50%;padding:3px;width:22px;height:22px;}
.svc-includes-note{font-size:.82rem;color:var(--muted);line-height:1.5;margin-top:14px;}

/* ----------------------------------------------------------
   How it works
   ---------------------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.step{position:relative;padding-top:14px;}
.step .num{font-family:var(--font-head);font-weight:700;font-size:1.05rem;color:var(--gold);
  width:38px;height:38px;border:1.5px solid var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;background:var(--gold-soft);margin-bottom:16px;}
.step h4{font-size:1.06rem;}
.step p{color:var(--slate);font-size:.94rem;margin-top:8px;}

/* ----------------------------------------------------------
   CTA / volume mare
   ---------------------------------------------------------- */
.cta-band{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:42px 44px;
  display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;
  background-image:radial-gradient(120% 160% at 90% 10%, rgba(194,161,77,.18), transparent 55%);}
.cta-band h2{color:#fff;font-size:1.7rem;}
.cta-band p{color:#c3d2e3;margin-top:12px;max-width:52ch;}
.cta-band .right{flex:none;}

/* ----------------------------------------------------------
   Footer
   ---------------------------------------------------------- */
.site-footer{background:#0b2238;color:#aebed1;padding:52px 0 28px;font-size:.92rem;}
.site-footer a{color:#cdd9e6;}
.site-footer a:hover{color:#fff;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;}
.footer-grid h5{color:#fff;font-family:var(--font-body);font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;margin:0 0 14px;font-weight:600;}
.footer-grid ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;}
.footer-brand .logo .name{color:#fff;}
.footer-brand p{color:#90a3b8;margin-top:14px;max-width:34ch;}
.footer-bottom{margin-top:38px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:#7e93a9;font-size:.86rem;}

/* ----------------------------------------------------------
   Order page layout
   ---------------------------------------------------------- */
.page-head{background:#fff;border-bottom:1px solid var(--line);padding:30px 0;}
.breadcrumb{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:.9rem;margin-bottom:10px;}
.breadcrumb a{color:var(--slate);}
.breadcrumb span{color:var(--line-strong);}
.page-head h1{font-size:clamp(1.7rem,3vw,2.3rem);}
.page-head .sub{color:var(--slate);margin-top:8px;}

.order-layout{display:grid;grid-template-columns:1fr 360px;gap:36px;align-items:start;padding:44px 0 72px;}

/* Form */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);overflow:hidden;}
.fieldset{padding:28px 30px;border-bottom:1px solid var(--line);}
.fieldset:last-child{border-bottom:none;}
.fieldset > legend, .fs-title{font-family:var(--font-head);font-weight:600;color:var(--navy);
  font-size:1.12rem;margin:0 0 4px;padding:0;display:flex;align-items:center;gap:10px;}
.fs-title .step-dot{width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;
  font-family:var(--font-body);font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex:none;}
.fs-sub{color:var(--muted);font-size:.9rem;margin:0 0 20px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px;}
.field:last-child{margin-bottom:0;}
.field.col-2{grid-column:span 2;}
label{font-size:.9rem;font-weight:600;color:var(--ink);}
label .req{color:var(--danger);margin-left:2px;}
label .opt{color:var(--muted);font-weight:500;font-size:.82rem;margin-left:6px;}
.hint{font-size:.82rem;color:var(--muted);}
input[type=text],input[type=email],input[type=tel],input[type=number],input[type=date],input[type=file],select,textarea{
  font-family:var(--font-body);font-size:.96rem;color:var(--ink);background:#fff;
  border:1px solid var(--line-strong);border-radius:var(--radius);padding:.7em .85em;width:100%;
  transition:border-color .15s,box-shadow .15s;}
textarea{min-height:96px;resize:vertical;line-height:1.55;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--navy-400);box-shadow:var(--ring);}
input.invalid,select.invalid,textarea.invalid{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-bg);}
.field .err{font-size:.82rem;color:var(--danger);display:none;}
.field.has-error .err{display:block;}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2346546a' stroke-width='2.4'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right .85em center;padding-right:2.4em;}

/* radio / segmented */
.choice-row{display:flex;gap:10px;flex-wrap:wrap;}
.choice{position:relative;}
.choice input{position:absolute;opacity:0;inset:0;cursor:pointer;}
.choice span{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-strong);
  border-radius:var(--radius);padding:.6em 1em;font-size:.92rem;font-weight:500;color:var(--slate);cursor:pointer;
  transition:.15s;}
.choice input:checked + span{border-color:var(--navy);background:var(--navy-100);color:var(--navy);font-weight:600;}
.choice input:focus-visible + span{box-shadow:var(--ring);}

/* consent */
.consent{display:flex;gap:12px;align-items:flex-start;background:var(--bg);border:1px solid var(--line);
  border-radius:var(--radius);padding:16px 18px;}
.consent input{width:18px;height:18px;margin-top:3px;flex:none;accent-color:var(--navy);}
.consent label{font-weight:500;color:var(--slate);font-size:.9rem;line-height:1.5;}

/* Summary sidebar */
.summary{position:sticky;top:96px;}
.summary-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;}
.summary-card .sc-head{background:var(--navy);color:#fff;padding:20px 22px;}
.summary-card .sc-head .ey{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.summary-card .sc-head h3{color:#fff;font-size:1.18rem;margin-top:6px;}
.summary-card .sc-body{padding:20px 22px;}
.sumrow{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:11px 0;
  border-bottom:1px dashed var(--line);font-size:.94rem;}
.sumrow:first-child{padding-top:0;}
.sumrow .k{color:var(--slate);}
.sumrow .v{font-weight:600;color:var(--ink);text-align:right;}
.sumrow.qty-row .v{display:flex;align-items:center;gap:0;}
.qty-stepper{display:inline-flex;align-items:center;border:1px solid var(--line-strong);border-radius:var(--radius);overflow:hidden;}
.qty-stepper button{width:32px;height:34px;border:none;background:#fff;color:var(--navy);font-size:1.1rem;cursor:pointer;line-height:1;}
.qty-stepper button:hover{background:var(--navy-100);}
.qty-stepper input{width:54px;height:34px;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);
  text-align:center;border-radius:0;padding:0;font-weight:600;}
.qty-stepper input:focus{box-shadow:none;}
.sumrow.total{border-bottom:none;border-top:2px solid var(--navy);margin-top:6px;padding-top:16px;}
.sumrow.total .k{font-weight:600;color:var(--navy);font-size:1rem;}
.sumrow.total .v{font-family:var(--font-head);font-weight:700;font-size:1.55rem;color:var(--navy);white-space:nowrap;}
.summary-note{font-size:.82rem;color:var(--muted);line-height:1.5;margin-top:16px;padding:14px;
  background:var(--gold-soft);border-radius:var(--radius);border:1px solid #e7dcbd;}
.summary-card .sc-foot{padding:0 22px 22px;}

/* ----------------------------------------------------------
   Alerts / validation summary
   ---------------------------------------------------------- */
.alert{border-radius:var(--radius);padding:14px 18px;font-size:.92rem;margin-bottom:22px;border:1px solid;}
.alert-danger{background:var(--danger-bg);border-color:#f0c2c4;color:#7d1a20;}
.alert-danger ul{margin:8px 0 0;padding-left:18px;}

/* ----------------------------------------------------------
   Thank you
   ---------------------------------------------------------- */
.thanks{max-width:660px;margin:64px auto;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;text-align:center;}
.thanks .top{background:var(--navy);padding:44px 36px 38px;color:#fff;}
.thanks .check{width:68px;height:68px;border-radius:50%;background:rgba(255,255,255,.12);
  border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;color:var(--gold);}
.thanks .top h1{color:#fff;font-size:1.9rem;}
.thanks .top .oid{display:inline-block;margin-top:14px;font-family:var(--font-body);font-size:.86rem;
  letter-spacing:.05em;color:#c3d2e3;background:rgba(255,255,255,.08);padding:.4em .9em;border-radius:6px;}
.thanks .body{padding:34px 40px 40px;}
.thanks .body p{color:var(--slate);font-size:1.05rem;}
.thanks .recap{text-align:left;margin:26px 0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.thanks .recap .r{display:flex;justify-content:space-between;padding:13px 18px;border-bottom:1px solid var(--line);font-size:.94rem;}
.thanks .recap .r:last-child{border-bottom:none;}
.thanks .recap .r .k{color:var(--muted);}
.thanks .recap .r .v{font-weight:600;}
.thanks .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:8px;}

/* ----------------------------------------------------------
   Status badges
   ---------------------------------------------------------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;
  padding:.32em .7em;border-radius:20px;letter-spacing:.01em;white-space:nowrap;}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;}
.badge.s-noua{color:var(--info);background:var(--info-bg);}
.badge.s-contactat{color:var(--warn);background:var(--warn-bg);}
.badge.s-programata{color:#6b3fa0;background:#efe7f8;}
.badge.s-in-lucru{color:#0a6a72;background:#dcf1f3;}
.badge.s-finalizata{color:var(--ok);background:var(--ok-bg);}
.badge.s-anulata{color:var(--danger);background:var(--danger-bg);}

/* ===========================================================
   ADMIN
   =========================================================== */
.admin-body{background:var(--bg);}
.admin-shell{display:flex;min-height:100vh;}
.admin-side{width:236px;flex:none;background:#0b2238;color:#aebed1;padding:24px 18px;display:flex;flex-direction:column;}
.admin-side .brand{display:flex;align-items:center;gap:10px;color:#fff;padding:6px 8px 22px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:18px;}
.admin-side .brand .name{font-family:var(--font-head);font-weight:700;font-size:1.08rem;line-height:1.1;}
.admin-side .brand .name span{display:block;font-family:var(--font-body);font-size:.62rem;letter-spacing:.14em;color:#7e93a9;text-transform:uppercase;font-weight:500;margin-top:3px;}
.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1;}
.admin-nav a{display:flex;align-items:center;gap:11px;color:#aebed1;padding:.7em .8em;border-radius:7px;font-size:.93rem;font-weight:500;}
.admin-nav a:hover{background:rgba(255,255,255,.06);color:#fff;}
.admin-nav a.active{background:var(--navy-600);color:#fff;}
.admin-side .side-foot{border-top:1px solid rgba(255,255,255,.1);padding-top:14px;font-size:.82rem;}
.admin-side .side-foot .who{color:#cdd9e6;font-weight:600;margin-bottom:8px;}
.admin-main{flex:1;min-width:0;}
.admin-topbar{background:#fff;border-bottom:1px solid var(--line);height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:10;}
.admin-topbar h1{font-size:1.3rem;}
.admin-content{padding:30px 32px 60px;}

/* stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-bottom:30px;}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);}
.stat .lab{font-size:.8rem;color:var(--muted);font-weight:600;letter-spacing:.03em;text-transform:uppercase;}
.stat .val{font-family:var(--font-head);font-weight:700;font-size:2rem;color:var(--navy);margin-top:8px;line-height:1;}
.stat .val.money{font-size:1.7rem;}
.stat.accent{border-top:3px solid var(--gold);}

/* filters */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap;}
.filter-pills{display:flex;gap:8px;flex-wrap:wrap;}
.filter-pills a{font-size:.86rem;font-weight:500;color:var(--slate);padding:.42em .85em;border:1px solid var(--line-strong);border-radius:20px;background:#fff;}
.filter-pills a:hover{border-color:var(--navy-400);}
.filter-pills a.active{background:var(--navy);color:#fff;border-color:var(--navy);}

/* table */
.table-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;}
table.data{width:100%;border-collapse:collapse;font-size:.9rem;}
table.data th{text-align:left;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  font-weight:700;padding:14px 16px;border-bottom:1px solid var(--line);background:#fafbfd;white-space:nowrap;}
table.data td{padding:14px 16px;border-bottom:1px solid var(--line);color:var(--slate);vertical-align:middle;}
table.data tr:last-child td{border-bottom:none;}
table.data tbody tr:hover{background:#fafbfd;}
table.data .oid{font-family:var(--font-head);font-weight:700;color:var(--navy);}
table.data .who{color:var(--ink);font-weight:600;}
table.data .who small{display:block;color:var(--muted);font-weight:500;font-size:.82rem;}
table.data .money{font-weight:700;color:var(--navy);white-space:nowrap;}
.table-empty{padding:54px 20px;text-align:center;color:var(--muted);}

/* reports + settings */
.report-filter{display:flex;align-items:center;justify-content:space-between;gap:16px 24px;flex-wrap:wrap;margin-bottom:22px;}
.rf-pills{display:flex;gap:8px;flex-wrap:wrap;}
.rf-pills a{font-size:.86rem;font-weight:500;color:var(--slate);padding:.42em .85em;border:1px solid var(--line-strong);border-radius:20px;background:#fff;}
.rf-pills a:hover{border-color:var(--navy-400);}
.rf-pills a.active{background:var(--navy);color:#fff;border-color:var(--navy);}
.rf-custom{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;}
.rf-custom label{display:flex;flex-direction:column;gap:5px;font-size:.78rem;color:var(--muted);font-weight:600;}
.rf-custom input[type=date]{width:auto;padding:.5em .7em;font-size:.9rem;}
.rf-custom .btn{padding:.6em 1.1em;font-size:.88rem;}
.report-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);
  padding:16px 22px;margin-bottom:24px;}
.report-period{font-family:var(--font-head);font-weight:600;color:var(--navy);font-size:1.12rem;margin-top:3px;}
.report-period .sep{color:var(--line-strong);margin:0 4px;}
.report-stats{grid-template-columns:repeat(5,1fr);}
.stat .val.small-txt{font-size:1.05rem;line-height:1.25;font-family:var(--font-body);}
.report-cols{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;margin-bottom:24px;align-items:start;}

/* bar chart */
.bar-chart{display:flex;align-items:flex-end;gap:10px;height:200px;padding-top:10px;overflow-x:auto;}
.bc-col{flex:1;min-width:34px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:6px;height:100%;}
.bc-bar{width:60%;max-width:34px;min-height:4px;background:linear-gradient(180deg,var(--navy-400),var(--navy));border-radius:5px 5px 0 0;transition:filter .15s;}
.bc-col:hover .bc-bar{filter:brightness(1.12);}
.bc-val{font-size:.7rem;font-weight:600;color:var(--slate);white-space:nowrap;}
.bc-lab{font-size:.72rem;color:var(--muted);white-space:nowrap;}

/* mini status table */
table.data.mini td{padding:11px 14px;}
table.data.mini tr:hover{background:transparent;}

/* revenue bars in service table */
.rev-bar-row{display:flex;align-items:center;gap:14px;}
.rev-bar{flex:1;height:9px;background:var(--navy-100);border-radius:6px;overflow:hidden;min-width:60px;}
.rev-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),#d8bd72);border-radius:6px;}
.rev-amt{white-space:nowrap;min-width:80px;text-align:right;}
table.data tfoot td{padding:14px 16px;border-top:2px solid var(--navy);font-weight:700;color:var(--navy);background:#fafbfd;}

/* settings */
.settings-cols{grid-template-columns:1.6fr 1fr;}
.smtp-log{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.8rem;line-height:1.5;
  color:var(--slate);background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;max-height:280px;overflow:auto;white-space:pre-wrap;margin:0;}

.table-empty.spaced{padding:54px 20px;}

/* admin detail */
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start;}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:24px;}
.panel .ph{padding:16px 22px;border-bottom:1px solid var(--line);font-family:var(--font-head);font-weight:600;color:var(--navy);font-size:1.06rem;background:#fafbfd;}
.panel .pb{padding:22px;}
.kv{display:grid;grid-template-columns:180px 1fr;gap:10px 18px;font-size:.93rem;}
.kv dt{color:var(--muted);font-weight:500;}
.kv dd{margin:0;color:var(--ink);font-weight:500;}
.kv-divide{grid-column:1/-1;border-top:1px dashed var(--line);margin:6px 0;}
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:
  radial-gradient(120% 120% at 50% -10%, rgba(52,95,138,.16), transparent 60%),var(--navy);padding:24px;}
.login-card{background:#fff;border-radius:var(--radius-lg);box-shadow:0 30px 70px -30px rgba(0,0,0,.5);width:100%;max-width:404px;overflow:hidden;}
.login-card .lc-head{padding:34px 36px 0;text-align:center;}
.login-card .lc-head .mark{width:46px;height:46px;margin:0 auto 14px;}
.login-card .lc-head h1{font-size:1.4rem;}
.login-card .lc-head p{color:var(--muted);font-size:.9rem;margin-top:6px;}
.login-card form{padding:28px 36px 34px;}

/* utilities */
.muted{color:var(--muted);}
.mt-0{margin-top:0;} .mb-0{margin-bottom:0;}
.text-c{text-align:center;}
.nowrap{white-space:nowrap;}
.divider{height:1px;background:var(--line);margin:22px 0;border:none;}
.notes-area{min-height:120px;}

/* ----------------------------------------------------------
   Responsive
   ---------------------------------------------------------- */
@media (max-width:980px){
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);}
  .order-layout{grid-template-columns:1fr;}
  .svc-hero-grid{grid-template-columns:1fr;gap:32px;}
  .svc-hero-text h1{max-width:none;}
  .svc-body-grid{grid-template-columns:1fr;gap:32px;}
  .svc-includes{position:static;}
  .summary{position:static;}
  .detail-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:26px;}
  .stat-grid{grid-template-columns:repeat(2,1fr);}
  .report-cols,.settings-cols{grid-template-columns:1fr;}
  .report-stats{grid-template-columns:repeat(2,1fr);}
  .admin-side{display:none;}
}
@media (max-width:620px){
  .wrap{padding:0 18px;}
  .svc-grid,.steps,.grid-2{grid-template-columns:1fr;}
  .header-nav .navlink{display:none;}
  .header-nav .navlink.keep{display:inline-flex;}
  .cta-band{padding:30px 26px;}
  .footer-grid{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .fieldset{padding:22px 20px;}
}
