:root{
  --orange:#ef7f1a;
  --orange-deep:#cb5d00;
  --yellow:#f4c400;
  --yellow-soft:#fff1a3;
  --ink:#1d2433;
  --muted:#61708a;
  --line:#e5d7c8;
  --line-strong:#d6bfa4;
  --surface:#ffffff;
  --surface-soft:#fff8ef;
  --surface-cream:#fffaf4;
  --dark:#17120e;
  --success:#15803d;
  --danger:#b91c1c;
  --warning:#b45309;
  --info:#0f6fbf;
  --shadow:0 18px 40px rgba(26,23,19,.08);
  --shadow-strong:0 24px 60px rgba(26,23,19,.14);
  --radius-xl:30px;
  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:12px;
  --max:1220px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(244,196,0,.12), transparent 28%),
    radial-gradient(circle at top right, rgba(239,127,26,.10), transparent 25%),
    linear-gradient(180deg,#fffdf9,#fff7ee 54%,#fffaf3 100%);
}
body.role-admin{
  background:
    radial-gradient(circle at top left, rgba(111,143,182,.15), transparent 24%),
    radial-gradient(circle at top right, rgba(239,127,26,.10), transparent 24%),
    linear-gradient(180deg,#fffdf9,#f9fbff 52%,#fff8ef 100%);
}
body.role-owner{
  background:
    radial-gradient(circle at top left, rgba(239,127,26,.12), transparent 24%),
    radial-gradient(circle at top right, rgba(111,143,182,.10), transparent 28%),
    linear-gradient(180deg,#fffdf9,#fffaf2 52%,#fff9f1 100%);
}
body.role-tenant{
  background:
    radial-gradient(circle at top left, rgba(111,143,182,.16), transparent 25%),
    radial-gradient(circle at top right, rgba(244,196,0,.12), transparent 26%),
    linear-gradient(180deg,#fdfefe,#f8fbff 54%,#fff9f2 100%);
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
strong{font-weight:800}
.container{width:min(var(--max),calc(100% - 34px));margin:0 auto}
.main-content{padding:34px 0 68px}

.site-header{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(255,252,247,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(203,93,0,.10);
  box-shadow:0 8px 28px rgba(35,22,10,.04);
}
.topbar{
  min-height:84px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  font-weight:900;
  letter-spacing:.02em;
}
.brand img{width:260px;height:auto}
.brand-mark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--orange),var(--yellow));
  color:#fff;
  box-shadow:var(--shadow);
}
.nav{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
}
.nav a{
  padding:11px 15px;
  border-radius:999px;
  color:#58432c;
  font-weight:700;
  transition:.18s ease;
}
.nav a:hover,.nav a.active{
  background:#fff0d9;
  color:var(--orange-deep);
  box-shadow:inset 0 0 0 1px rgba(203,93,0,.08);
}
.user-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:11px 15px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(214,191,164,.7);
  color:#493928;
  box-shadow:var(--shadow);
  font-size:.96rem;
  font-weight:700;
}
.user-badge::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--yellow));
}

.hero-home-shell{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:stretch;
  padding:26px 0 8px;
}
.hero-panel{
  position:relative;
  overflow:hidden;
  min-height:520px;
  border-radius:36px;
  padding:42px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,249,239,.78)),
    url('/assets/img/space-home.png') center/cover no-repeat;
  border:1px solid rgba(255,255,255,.65);
  box-shadow:var(--shadow-strong);
}
.hero-panel::after{
  content:"";
  position:absolute;
  inset:auto -50px -55px auto;
  width:220px;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(244,196,0,.38), transparent 68%);
}
.hero-copy{
  max-width:720px;
  position:relative;
  z-index:1;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,243,217,.92);
  border:1px solid rgba(203,93,0,.08);
  color:#9c5700;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:.82rem;
}
.eyebrow::before{
  content:"";
  width:9px;
  height:9px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--yellow));
}
h1,h2,h3,h4{margin:0;color:var(--ink)}
h1{
  font-size:clamp(2.6rem,5vw,4.7rem);
  line-height:1.02;
  margin:18px 0 18px;
  letter-spacing:-.03em;
}
.script-title{
  font-family:"Brush Script MT","Segoe Script","Apple Chancery",cursive;
  font-weight:600;
}
h2{
  font-size:clamp(1.7rem,2.8vw,2.7rem);
  line-height:1.08;
  margin-bottom:14px;
  letter-spacing:-.02em;
}
h3{
  font-size:1.18rem;
  margin-bottom:10px;
}
h4{
  font-size:1rem;
  margin-bottom:8px;
}
p{
  margin:0 0 14px;
  line-height:1.68;
  color:#3f4758;
}
.hero-lead{
  font-size:1.08rem;
  max-width:650px;
}
.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}
.btn{
  appearance:none;
  border:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:13px 20px;
  border-radius:16px;
  font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg,var(--orange),var(--yellow));
  box-shadow:0 18px 30px rgba(239,127,26,.24);
}
.btn-secondary{
  color:#47341f;
  background:#fff;
  border:1px solid rgba(214,191,164,.85);
  box-shadow:var(--shadow);
}
.btn-success{color:#fff;background:linear-gradient(135deg,#1b8a4b,#54b66f)}
.btn-danger{color:#fff;background:linear-gradient(135deg,#ba2235,#d74d4d)}
.btn-small{padding:10px 14px;border-radius:12px;font-size:.92rem}

.hero-side{
  display:grid;
  gap:18px;
}
.glass-card,.card{
  background:rgba(255,255,255,.95);
  border:1px solid rgba(214,191,164,.72);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  padding:24px;
}
.glass-card{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,249,241,.90));
}
.section{margin:32px 0}
.section-header{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.section-kicker{
  color:#976028;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:.8rem;
  margin-bottom:8px;
}
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.stack{display:grid;gap:16px}
.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.kpi{
  padding:22px;
  border-radius:24px;
  border:1px solid rgba(214,191,164,.8);
  background:linear-gradient(180deg,#fff,#fff4e4);
  box-shadow:var(--shadow);
}
.kpi .value{
  font-size:2rem;
  font-weight:900;
  color:#7c4200;
  letter-spacing:-.02em;
}
.kpi .label{
  display:block;
  margin-top:6px;
  font-weight:800;
  color:#594027;
}
.kpi .sub{
  display:block;
  margin-top:6px;
  color:#7b6b5b;
  font-size:.92rem;
}
.metric-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.mini-stat{
  padding:16px 18px;
  border-radius:18px;
  background:var(--surface-soft);
  border:1px solid rgba(214,191,164,.62);
}
.mini-stat .figure{
  display:block;
  font-size:1.2rem;
  font-weight:900;
  color:#1e2738;
}
.mini-stat .caption{
  display:block;
  font-size:.92rem;
  color:#6a7082;
  margin-top:4px;
}
.card-soft{
  background:linear-gradient(180deg,#fff,#fff8ed);
}
.feature-card{
  position:relative;
  overflow:hidden;
  padding:26px;
  border-radius:24px;
  border:1px solid rgba(214,191,164,.68);
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,249,240,.92));
  box-shadow:var(--shadow);
}
.feature-card::after{
  content:"";
  position:absolute;
  inset:auto -20px -30px auto;
  width:100px;
  height:100px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(244,196,0,.22), transparent 72%);
}
.quick-link{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(214,191,164,.7);
  background:linear-gradient(180deg,#fff,#fff8ef);
  transition:.18s ease;
}
.quick-link:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow);
}
.quick-link strong{
  display:block;
  margin-bottom:6px;
  color:#2a2a2a;
}
.quick-link span{
  color:#6d7484;
  font-size:.95rem;
}
.quick-link-badge{
  display:inline-flex;
  min-width:44px;
  height:44px;
  border-radius:14px;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:#fff;
  background:linear-gradient(135deg,var(--orange),var(--yellow));
  box-shadow:0 16px 26px rgba(239,127,26,.2);
}

.page-intro{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:26px;
  align-items:stretch;
}
.page-copy{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,250,244,.88));
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow);
  border:1px solid rgba(214,191,164,.68);
}
.visual-card{
  min-height:260px;
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow-strong);
  border:1px solid rgba(255,255,255,.58);
  background-size:cover;
  background-position:center;
}
.space-home{background-image:url('/assets/img/space-home.png')}
.space-owner{background-image:url('/assets/img/space-owner.png')}
.space-tenant{background-image:url('/assets/img/space-tenant.png')}
.space-admin{background-image:url('/assets/img/space-admin.png')}
.space-subscription{background-image:url('/assets/img/space-subscription.png')}
.space-docs{background-image:url('/assets/img/space-documents.png')}

.auth-shell{
  display:grid;
  grid-template-columns:1.03fr .97fr;
  gap:26px;
  align-items:stretch;
}
.auth-visual{
  min-height:420px;
  border-radius:30px;
  box-shadow:var(--shadow-strong);
  background-size:cover;
  background-position:center;
}
.auth-panel{
  background:linear-gradient(180deg,#fff,#fff7ee);
  border:1px solid rgba(214,191,164,.7);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow);
}
.info-banner{
  padding:18px 20px;
  border-radius:18px;
  border:1px solid rgba(237,196,128,.85);
  background:linear-gradient(180deg,#fff7e9,#fff2db);
  color:#6b4519;
}
.tip-grid{
  display:grid;
  gap:12px;
}
.tip{
  padding:16px 18px;
  border-radius:18px;
  border:1px solid rgba(214,191,164,.58);
  background:#fff;
}

form{display:grid;gap:14px}
label{
  display:block;
  margin-bottom:7px;
  font-weight:800;
  color:#5b4630;
}
input,select,textarea{
  width:100%;
  padding:13px 14px;
  border-radius:14px;
  border:1px solid #dccab8;
  background:#fff;
  color:#1e2430;
  font:inherit;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.03);
}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:#e58d28;
  box-shadow:0 0 0 4px rgba(239,127,26,.12);
}
textarea{min-height:130px;resize:vertical}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-help{font-size:.92rem;color:#6d7484}
.fieldset{
  margin:0;
  padding:18px;
  border:1px solid rgba(214,191,164,.72);
  border-radius:20px;
  background:#fffdfa;
}
.fieldset legend{
  padding:0 10px;
  font-weight:900;
  color:#7c4200;
}
.inline-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
hr.separator{
  border:none;
  border-top:1px solid rgba(214,191,164,.72);
  margin:8px 0;
}

.table-wrap{
  overflow:auto;
  background:#fff;
  border-radius:22px;
  border:1px solid rgba(214,191,164,.8);
  box-shadow:var(--shadow);
}
table{
  width:100%;
  border-collapse:collapse;
  min-width:760px;
}
th,td{
  padding:14px 16px;
  border-bottom:1px solid #f0e1d3;
  vertical-align:top;
  text-align:left;
}
thead th{
  position:sticky;
  top:0;
  background:#fff7eb;
  color:#7e4b10;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.03em;
}
tbody tr:hover td{background:#fffdf9}
tbody tr:last-child td{border-bottom:none}
.status{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:.85rem;
  font-weight:900;
  line-height:1;
}
.status::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:currentColor;
}
.status-active,.status-paid{background:#dcfce7;color:#166534}
.status-pending,.status-partial{background:#fef3c7;color:#92400e}
.status-cancelled,.status-expired,.status-overdue,.status-suspended{background:#fee2e2;color:#991b1b}
.status-issued,.status-prospect{background:#dbeafe;color:#1d4ed8}
.status-inactive{background:#e5e7eb;color:#374151}

.flash{
  padding:15px 17px;
  border-radius:16px;
  margin:0 0 18px;
  border:1px solid;
  box-shadow:var(--shadow);
}
.flash-success{background:#effcf3;border-color:#b8ebc5;color:#166534}
.flash-error{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.flash-warning{background:#fff7ed;border-color:#fed7aa;color:#9a3412}

.empty{
  padding:28px 22px;
  text-align:center;
  border-radius:20px;
  border:2px dashed rgba(214,191,164,.82);
  background:#fffdf9;
  color:#72695d;
}
.pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:#fff4df;
  color:#8c4f00;
  font-weight:800;
  font-size:.88rem;
}
.list-check{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.list-check li{
  position:relative;
  padding-left:28px;
  color:#445065;
}
.list-check li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:#bb6b08;
  font-weight:900;
}
.message-box{
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(214,191,164,.72);
  background:linear-gradient(180deg,#fff,#fffaf2);
  margin-bottom:14px;
}
.message-meta{
  margin-bottom:8px;
  font-size:.9rem;
  color:#70798b;
}
.split-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.panel-note{
  padding:14px 16px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(214,191,164,.72);
}
.site-footer{
  background:linear-gradient(180deg,#1f1712,#1a120d);
  color:#faead8;
  margin-top:36px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr .8fr 1fr;
  gap:24px;
  padding:40px 0;
}
.footer-logo{width:240px;margin-bottom:14px}
.site-footer p,.site-footer a,.site-footer li{color:#faead8}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.muted{color:#6d7484}
.small{font-size:.92rem}

.receipt{
  max-width:980px;
  margin:0 auto;
  padding:32px;
  border-radius:30px;
  background:#fff;
  box-shadow:var(--shadow-strong);
  border:1px solid rgba(214,191,164,.72);
}
.receipt-header{
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-bottom:2px solid #f2dfcb;
  padding-bottom:20px;
  margin-bottom:24px;
}
.print-bar{
  display:flex;
  justify-content:flex-end;
  margin-bottom:16px;
}
.overview-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
}
.timeline{
  display:grid;
  gap:12px;
}
.timeline-item{
  padding:16px 18px;
  border-radius:18px;
  border:1px solid rgba(214,191,164,.72);
  background:#fff;
}
.timeline-date{
  color:#8a5a25;
  font-weight:800;
  font-size:.9rem;
  margin-bottom:6px;
}

@media (max-width:1080px){
  .hero-home-shell,.page-intro,.auth-shell,.overview-grid,.footer-grid,.grid-4,.grid-3,.grid-2,.stat-grid,.metric-row{grid-template-columns:1fr}
  .topbar{flex-wrap:wrap;padding:14px 0}
  .nav{justify-content:flex-start}
}
@media (max-width:720px){
  .container{width:min(var(--max),calc(100% - 20px))}
  .hero-panel,.page-copy,.auth-panel,.card,.feature-card,.kpi{padding:20px}
  .brand img{width:220px}
  .form-grid{grid-template-columns:1fr}
  th,td{padding:12px 13px}
  .hero-panel{min-height:auto}
}
@media print{
  .site-header,.site-footer,.print-bar,.flash,.btn{display:none !important}
  body{background:#fff}
  .main-content{padding:0}
  .receipt{box-shadow:none;border:none;max-width:100%;padding:0}
}
