/* ============================================================
   Natureza Cura — Member area design system (conta.html)
   Ported from the React prototype into plain CSS. Self-contained:
   conta.html does NOT load Tailwind; everything it needs is here.
   ============================================================ */

:root {
  /* Forest green */
  --color-green-900: #0F2219;
  --color-green-800: #1A3C34;
  --color-green-700: #214d42;
  --color-green-600: #2B6355;
  --color-green-200: #A8C5BC;
  --color-green-100: #D4E5E0;
  --color-green-050: #EBF3F0;
  /* Warm ivory */
  --color-ivory-900: #3A3830;
  --color-ivory-700: #6B6B67;
  --color-ivory-500: #9C9A94;
  --color-ivory-300: #C8C6BE;
  --color-ivory-100: #F2F0E6;
  --color-ivory-050: #FAF9F6;
  --color-white: #FFFFFF;
  /* Accents */
  --color-terra: #8B6E52;
  --color-sage: #7A9E8A;
  --color-border: rgba(26, 60, 52, 0.15);
  --color-border-strong: rgba(26, 60, 52, 0.30);
  /* Radius */
  --radius-sm: 0.5rem;
  --radius-md: 0.75rem;
  --radius-lg: 1.25rem;
  --radius-xl: 1.5rem;
  --radius-2xl: 2rem;
  /* Shadow */
  --shadow-xs: 0 1px 2px rgba(15, 34, 25, 0.05);
  --shadow-sm: 0 2px 8px rgba(15, 34, 25, 0.08);
  --shadow-md: 0 4px 20px rgba(15, 34, 25, 0.10);
  --shadow-lg: 0 8px 32px rgba(15, 34, 25, 0.12);
  --shadow-xl: 0 16px 48px rgba(15, 34, 25, 0.14);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  background: var(--color-ivory-100);
  color: var(--color-ivory-700);
  font-family: 'Inter', system-ui, sans-serif;
  min-height: 100vh;
}
button, input, select { font-family: 'Inter', sans-serif; }
.font-serif { font-family: 'Cormorant Garamond', Georgia, serif; }
a { color: inherit; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(26, 60, 52, 0.18); border-radius: 4px; }

.nc-hidden { display: none !important; }

/* ── Typography helpers ── */
.nc-label { font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500; color: var(--color-sage); }
.nc-h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 4vw, 46px); font-weight: 400; line-height: 1.08; color: var(--color-green-800); margin: 0; }
.nc-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; color: var(--color-green-800); margin: 0; }
.nc-lead { font-weight: 300; font-size: 15.5px; line-height: 1.65; color: var(--color-ivory-700); }

/* ── Buttons ── */
.nc-btn-filled, .nc-btn-outline, .nc-btn-light, .nc-btn-ghost-light {
  display: inline-flex; align-items: center; gap: 9px; justify-content: center;
  font-size: 12.5px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  cursor: pointer; border-radius: 9999px; padding: 13px 26px; border: 1px solid transparent;
  transition: background 300ms ease, color 300ms ease, opacity 300ms ease; white-space: nowrap;
}
.nc-btn-filled { background: var(--color-green-800); color: var(--color-ivory-100); }
.nc-btn-filled:hover { opacity: 0.88; }
.nc-btn-filled:disabled { opacity: 0.55; cursor: default; }
.nc-btn-outline { background: transparent; color: var(--color-green-800); border-color: var(--color-border-strong); }
.nc-btn-outline:hover { background: var(--color-green-800); color: var(--color-ivory-100); }
.nc-btn-light { background: var(--color-ivory-100); color: var(--color-green-800); }
.nc-btn-light:hover { opacity: 0.9; }
.nc-btn-ghost-light { background: transparent; color: var(--color-ivory-100); border-color: rgba(242, 240, 230, 0.3); }
.nc-btn-ghost-light:hover { background: rgba(242, 240, 230, 0.1); }

/* ── Inputs ── */
.nc-input, .nc-select {
  width: 100%; font-size: 14.5px; color: var(--color-green-800);
  background: var(--color-ivory-050); border: 1px solid rgba(26, 60, 52, 0.14);
  border-radius: 12px; padding: 13px 15px; outline: none;
  transition: border-color 200ms ease, background 200ms ease;
}
.nc-input:focus, .nc-select:focus { border-color: var(--color-sage); background: #fff; }
.nc-input:read-only { background: rgba(26, 60, 52, 0.05); color: var(--color-ivory-700); }
.nc-select:disabled { opacity: 0.6; }
.nc-field-label { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-ivory-500); display: block; margin-bottom: 7px; }

/* ── Cards ── */
.nc-card { background: var(--color-white); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm); padding: 28px; border: 1px solid rgba(26, 60, 52, 0.06); }

/* ── App layout ── */
.nc-app { min-height: 100vh; }
.nc-sidebar {
  position: fixed; top: 0; left: 0; width: 264px; height: 100vh; z-index: 60;
  background: var(--color-green-800); display: flex; flex-direction: column; transition: transform 320ms ease;
}
.nc-main { margin-left: 264px; min-height: 100vh; display: flex; flex-direction: column; }
.nc-content { padding: clamp(28px, 4vw, 56px); max-width: 1180px; width: 100%; }
.nc-topbar { display: none; }
.nc-sb-backdrop { position: fixed; inset: 0; background: rgba(15, 34, 25, 0.45); z-index: 55; }

.nc-nav-item {
  display: flex; align-items: center; gap: 13px; width: 100%; text-align: left;
  background: transparent; border: none; cursor: pointer; padding: 11px 14px; border-radius: 12px;
  transition: background 200ms ease, color 200ms ease;
}
.nc-nav-item:hover { background: rgba(242, 240, 230, 0.07); }

/* ── View switching ── */
.nc-view { display: none; }
.nc-view.nc-view-active { display: block; animation: nc-fade 320ms ease; }
@keyframes nc-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.nc-pagehead { margin-bottom: 36px; }

/* ── Profile / settings grids ── */
.nc-prof-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.25fr); gap: 28px; align-items: start; }
.nc-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px 28px; }
.nc-birth-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.nc-set-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.nc-cal-grid { display: grid; grid-template-columns: minmax(0, 1.7fr) minmax(0, 1fr); gap: 28px; align-items: start; }

/* ── Ebook rows ── */
.nc-ebook-row {
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  background: var(--color-white); border: 1px solid rgba(26, 60, 52, 0.08);
  border-radius: var(--radius-lg); padding: 20px 22px;
}

/* ── Empty / "Em breve" states ── */
.nc-empty {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 64px 28px; background: var(--color-ivory-050);
  border: 1px dashed rgba(26, 60, 52, 0.16); border-radius: var(--radius-2xl);
}
.nc-empty i { font-size: 30px; color: var(--color-sage); margin-bottom: 18px; }

/* ── Login split ── */
.nc-login { min-height: 100vh; display: grid; grid-template-columns: 1.05fr 1fr; }
.nc-login-brand {
  background: var(--color-green-800); color: var(--color-ivory-100); padding: clamp(40px, 6vw, 80px);
  display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden;
}
.nc-login-form-wrap { background: var(--color-ivory-100); display: flex; align-items: center; justify-content: center; padding: clamp(32px, 5vw, 64px); }

/* ── Banner ── */
.nc-banner {
  display: flex; align-items: center; gap: 14px; background: #FBF3DC; border: 1px solid #ECD9A6;
  color: #7A5E1E; border-radius: var(--radius-lg); padding: 16px 20px; margin-bottom: 28px;
}

/* ── Responsive ── */
@media (max-width: 1000px) {
  .nc-cal-grid, .nc-prof-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .nc-sidebar { transform: translateX(-100%); box-shadow: 0 0 60px rgba(15, 34, 25, 0.4); }
  .nc-sidebar.nc-sb-open { transform: translateX(0); }
  .nc-main { margin-left: 0; }
  .nc-topbar {
    display: flex; align-items: center; justify-content: space-between; padding: 14px 20px;
    background: rgba(242, 240, 230, 0.9); backdrop-filter: blur(10px); position: sticky; top: 0; z-index: 50;
    border-bottom: 1px solid rgba(26, 60, 52, 0.08);
  }
  .nc-login { grid-template-columns: 1fr; }
  .nc-login-brand { display: none; }
}
@media (max-width: 620px) {
  .nc-info-grid, .nc-set-grid, .nc-birth-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Lunar calendar (Calendário view) — astrological month grid
   ============================================================ */
.cal2-head{text-align:center;position:relative;margin-bottom:22px}
.cal2-month{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,7vw,64px);font-weight:400;color:var(--color-green-800);line-height:1}
.cal2-year{font-size:13px;letter-spacing:0.3em;color:var(--color-ivory-500);margin-top:6px}
.cal2-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(17px,2.4vw,21px);color:var(--color-terra);margin-top:10px}
.cal2-nav{position:absolute;top:14px;display:flex;gap:8px}
.cal2-nav.left{left:0}.cal2-nav.right{right:0}
.cal2-navbtn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(26,60,52,0.15);background:var(--color-white);color:var(--color-green-800);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.cal2-navbtn:hover{background:rgba(26,60,52,0.06)}

.cal2-grid{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--color-border,rgba(26,60,52,0.12));border-left:1px solid var(--color-border,rgba(26,60,52,0.12));background:var(--color-white);border-radius:4px;overflow:hidden}
.cal2-wd{padding:12px 6px;text-align:center;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-ivory-500);border-right:1px solid rgba(26,60,52,0.10);border-bottom:1px solid rgba(26,60,52,0.10);background:var(--color-ivory-050)}
.cal2-cell{min-height:104px;padding:8px 9px;border-right:1px solid rgba(26,60,52,0.10);border-bottom:1px solid rgba(26,60,52,0.10);position:relative;display:flex;flex-direction:column;gap:3px}
.cal2-cell.empty{background:var(--color-ivory-050)}
.cal2-daynum{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--color-green-800);line-height:1}
.cal2-cell.today{outline:2px solid #3b82f6;outline-offset:-2px;border-radius:2px}
.cal2-line{font-size:11.5px;color:var(--color-ivory-700);line-height:1.3}
.cal2-sign{font-weight:600}
.cal2-time{font-size:11px;font-style:italic;color:var(--color-ivory-500)}
.cal2-glyph{position:absolute;top:9px;right:9px}
.cal2-phname{font-size:12px;font-weight:600;color:var(--color-green-800);line-height:1.2;margin-top:1px}
.cal2-super{display:inline-block;margin-top:4px;font-size:9px;font-weight:700;letter-spacing:0.1em;background:var(--color-green-800);color:var(--color-ivory-100);padding:2px 7px;border-radius:4px}
/* phase tints */
.cal2-cell.ph-minguante{background:rgba(122,158,138,0.16)}
.cal2-cell.ph-crescente{background:#e9e7f3}
.cal2-cell.ph-cheia{background:#f7efd6}
.cal2-cell.ph-nova{background:var(--color-green-800)}
.cal2-cell.ph-nova .cal2-daynum,.cal2-cell.ph-nova .cal2-phname,.cal2-cell.ph-nova .cal2-line{color:var(--color-ivory-100)}
.cal2-cell.ph-nova .cal2-time{color:rgba(242,240,230,0.6)}
.cal2-cell.ph-nova .cal2-super{background:var(--color-ivory-100);color:var(--color-green-800)}
/* element colors for signs */
.el-fogo{color:#b4541f}.el-terra{color:#5f7d57}.el-ar{color:#3f6f8f}.el-agua{color:#2f7a72}
.cal2-cell.ph-nova .el-fogo,.cal2-cell.ph-nova .el-terra,.cal2-cell.ph-nova .el-ar,.cal2-cell.ph-nova .el-agua{color:var(--color-ivory-100)}

/* legend */
.cal2-legend{margin-top:20px;background:var(--color-ivory-050);border:1px solid rgba(26,60,52,0.08);border-radius:14px;padding:18px 22px;display:flex;flex-wrap:wrap;gap:14px 30px}
.cal2-leg-item{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--color-ivory-700)}
.cal2-leg-item b{color:var(--color-green-800);font-weight:600}
.cal2-leg-super{font-size:11px;color:var(--color-terra);font-style:italic;margin-left:4px}

@media(max-width:700px){
  .cal2-cell{min-height:84px;padding:6px}
  .cal2-daynum{font-size:18px}
  .cal2-line{font-size:10px}
  .cal2-glyph{top:6px;right:6px;transform:scale(0.8)}
}
