:root{
  --forest:#1A4D3A; --deep:#0C1F17; --gold:#C9A84C; --cream:#F7F3EA;
  --ivory:#FFFDF8; --text:#14261E; --muted:#5C6B63; --border:#D8D0C1;
  --danger:#A53A32; --warning:#8A6510; --success:#1A4D3A;
  --shadow:0 8px 30px rgba(12,31,23,.08);
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:Manrope,system-ui,sans-serif;background:var(--cream);color:var(--text)}
.font-serif{font-family:"Cormorant Garamond",serif}
.app{position:relative;z-index:5;min-height:100vh;min-height:100dvh}

.btn{border:none;cursor:pointer;border-radius:999px;padding:12px 18px;font:600 14px Manrope,sans-serif;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
.btn-primary{background:var(--forest);color:white}
.btn-primary:hover{background:#245e48}
.btn-primary:disabled{opacity:.55;cursor:not-allowed}
.btn-ghost{background:white;border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--cream)}
.btn-link{background:transparent;color:var(--forest);padding:0;border:none;cursor:pointer;font:600 14px Manrope,sans-serif}
.btn-danger{background:var(--danger);color:white}
.btn-sm{padding:8px 14px;font-size:13px}

.card{background:white;border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow)}

.tag{display:inline-flex;align-items:center;border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700}
.tag-green{background:#eef7f1;color:var(--forest)}
.tag-amber{background:#f6efe0;color:var(--warning)}
.tag-red{background:#fdf3f1;color:var(--danger)}

.shell{display:flex;min-height:100vh;min-height:100dvh}
.sidebar{width:280px;background:var(--deep);color:white;padding:20px;border-right:1px solid rgba(216,208,193,.15)}
.brand-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:20px;border-radius:28px}
.nav{margin-top:20px;display:grid;gap:8px}
.nav button{background:transparent;color:rgba(255,255,255,.82);border:none;text-align:left;border-radius:18px;padding:14px 16px;font:500 14px Manrope,sans-serif;cursor:pointer}
.nav button.active{background:white;color:var(--deep);font-weight:700}
.nav button:hover:not(.active){background:rgba(255,255,255,.08)}

.main{flex:1;min-width:0}
.topbar{position:sticky;top:0;z-index:30;background:rgba(247,243,234,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:16px 24px;display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}
.profile-wrap{position:relative}
.profile-btn{background:white;border:1px solid var(--border);border-radius:999px;padding:8px 12px;display:flex;gap:10px;align-items:center;cursor:pointer;box-shadow:var(--shadow)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--forest);color:white;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.menu{position:absolute;right:0;top:56px;width:280px;background:white;border:1px solid var(--border);border-radius:24px;box-shadow:0 20px 40px rgba(12,31,23,.14);padding:8px;display:none;z-index:40}
.menu.open{display:block}
.menu .meta{padding:14px 16px}
.menu a,.menu button{width:100%;display:block;border:none;background:transparent;text-align:left;padding:14px 16px;border-radius:18px;font:500 14px Manrope,sans-serif;color:var(--text);text-decoration:none;cursor:pointer}
.menu a:hover,.menu button:hover{background:var(--cream)}
.menu .danger:hover{background:#fdf3f1;color:var(--danger)}

.content{padding:24px}
.trust{padding:20px;border-radius:28px}

.grid{display:grid;gap:16px}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}

.stat{padding:20px}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#7a6d58}
.stat .value{font-size:32px;font-weight:700;margin-top:8px}

.section{padding:20px}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}

.tbl-wrap{overflow:auto}
table{width:100%;min-width:720px;border-collapse:collapse}
th{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7a6d58;text-align:left;padding:12px}
td{padding:12px;border-top:1px solid #f0ebe1;font-size:14px;color:#203328;vertical-align:top}

.asset-grid,.task-grid{display:grid;gap:16px}
.asset-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.task-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.mini-card{background:var(--ivory);border:1px solid #e7e0d4;border-radius:24px;padding:16px}

.empty{border:1px dashed var(--border);border-radius:28px;padding:36px;background:var(--ivory);text-align:center}
.empty h4{margin:0 0 8px 0;font-size:20px}

/* Login */
.login-layout{max-width:1180px;margin:0 auto;display:grid;gap:24px;grid-template-columns:1.1fr .9fr;align-items:center;min-height:100vh;min-height:100dvh;padding:40px 24px}
.login-left{background:var(--deep);color:white;padding:32px}
.login-right{padding:32px}
.pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:10px 16px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.08);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.82)}
.feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:28px}
.feature{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:16px}
.auth-links{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:14px}

/* Forms (shared) */
.field{display:grid;gap:6px}
.field label,.field-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  width:100%;border:1px solid var(--border);background:var(--ivory);border-radius:14px;
  padding:12px 14px;font:500 15px Manrope,sans-serif;color:var(--text)
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px rgba(26,77,58,.12)}
.field textarea{min-height:80px;resize:vertical;font-family:Manrope,sans-serif}
.field .hint{font-size:12px;color:var(--muted)}
.field .err{font-size:12px;color:var(--danger)}
.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;flex-wrap:wrap}

.notice{padding:14px 16px;border-radius:18px;font-size:14px;line-height:1.5}
.notice.error{background:#fdf3f1;color:var(--danger)}
.notice.ok{background:#eef7f1;color:var(--forest)}
.notice.warn{background:#f6efe0;color:var(--warning)}

.entry-note{background:#fff8e8;border:1px solid #ead7a4;color:#5b4a1f;border-radius:18px;padding:12px 14px;font-size:13px;line-height:1.6}
.error-box{background:#fdf3f1;border:1px solid #efc7c2;color:#8d2f28;border-radius:18px;padding:14px 16px;font-size:13px;line-height:1.6;margin-top:14px;white-space:pre-wrap}

/* Toasts */
.toast-host{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{background:var(--deep);color:white;border-radius:16px;padding:14px 20px;font:500 14px Manrope,sans-serif;box-shadow:0 12px 30px rgba(12,31,23,.3);max-width:360px;pointer-events:auto;animation:toast-in .25s cubic-bezier(.2,.9,.3,1) both}
.toast.ok{background:var(--forest)}
.toast.error{background:var(--danger)}
.toast.out{animation:toast-out .25s ease-in both}
@keyframes toast-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes toast-out{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}

/* Modal */
.modal-host{position:fixed;inset:0;z-index:90;pointer-events:none}
.modal-host.open{pointer-events:auto}
.modal-backdrop{position:absolute;inset:0;background:rgba(12,31,23,.55);opacity:0;transition:opacity .2s}
.modal-host.open .modal-backdrop{opacity:1}
.modal{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:white;border-radius:28px;padding:28px;max-width:460px;width:calc(100% - 40px);box-shadow:0 30px 60px rgba(12,31,23,.4)}
.modal h3{margin:0 0 10px 0;font-size:22px;font-family:"Cormorant Garamond",serif}
.modal p{margin:0 0 20px 0;color:var(--muted);font-size:15px;line-height:1.5}
.modal .form-actions{justify-content:flex-end}

.mobile-nav{display:none}

@media (max-width: 1100px){
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .asset-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 900px){
  .sidebar{display:none}
  .mobile-nav{display:flex;gap:8px;overflow-x:auto;padding:0 16px 10px;-webkit-overflow-scrolling:touch}
  .mobile-nav::-webkit-scrollbar{display:none}
  .mobile-nav button{white-space:nowrap;border-radius:999px;padding:10px 14px;border:1px solid var(--border);background:white;cursor:pointer;font:500 13px Manrope,sans-serif;flex-shrink:0}
  .mobile-nav button.active{background:var(--forest);color:white;border-color:var(--forest)}
  .login-layout,.grid-2,.grid-3,.grid-4,.asset-grid,.task-grid{grid-template-columns:1fr}
  .topbar{padding:12px 16px}
  .topbar .tag{display:none}
  .hide-mobile{display:none !important}
  .content{padding:12px}
  .feature-grid{grid-template-columns:1fr}
  .login-left,.login-right{padding:20px}
  .card{border-radius:20px}
  .section{padding:14px}
  .trust{padding:14px;border-radius:20px}
  .mini-card{border-radius:18px;padding:14px}
  .stat .value{font-size:26px}

  /* Tables → stacked cards on mobile */
  .tbl-wrap{overflow:visible}
  table{min-width:0}
  table thead{display:none}
  table tbody tr{display:grid;gap:6px;padding:14px;margin-bottom:10px;background:var(--ivory);border:1px solid #e7e0d4;border-radius:18px}
  table td{padding:4px 0;border:none;font-size:13px;display:flex;gap:8px;align-items:flex-start}
  table td::before{content:attr(data-label);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);min-width:90px;flex-shrink:0}

  /* Touch-friendly form inputs */
  .field input,.field select,.field textarea{padding:14px 16px;font-size:16px;border-radius:16px}
  .btn{padding:14px 20px;font-size:15px}
  .btn-sm{padding:10px 16px;font-size:14px}
  .form-actions{flex-direction:column}
  .form-actions .btn{width:100%}

  /* Toast positioning for mobile */
  .toast-host{bottom:16px;left:16px;right:16px}
  .toast{max-width:none}

  /* Modal fullscreen on mobile */
  .modal{top:auto;bottom:0;left:0;right:0;transform:none;width:100%;max-width:100%;border-radius:28px 28px 0 0;max-height:85vh;overflow-y:auto}

  /* Calendar compact mode */
  .cal-cell{min-height:54px;padding:4px}
  .cal-dow{font-size:8px;padding:4px 2px;letter-spacing:.05em}
  .cal-bar{font-size:8px;padding:1px 3px}
  .cal-day-num{font-size:10px}
  .cal-grid{gap:2px;padding:2px;border-radius:12px}

  /* Checklist touch targets */
  .checklist-item{padding:14px 16px;gap:14px}
  .checklist-item input[type="checkbox"]{width:24px;height:24px;min-width:24px}

  /* Task action buttons full width */
  .task-actions{flex-direction:column}
  .task-actions .btn-sm{min-width:0}

  /* Photo picker mobile */
  .photo-thumb{max-width:none;width:100%}

  /* Profile menu */
  .menu{width:calc(100vw - 32px);max-width:320px;right:-8px}

  /* Degraded banner */
  .degraded-banner{padding:10px 16px;font-size:12px;flex-direction:column;text-align:center}

  /* Asset detail header */
  .font-serif{font-size:clamp(24px, 5vw, 40px) !important}
}

/* Extra small phones (< 400px) */
@media (max-width: 400px){
  .content{padding:8px}
  .section{padding:10px}
  .topbar{padding:10px 12px}
  .mobile-nav{padding:0 12px 8px}
  .stat .value{font-size:22px}
  .eyebrow{font-size:10px}
}

@keyframes spin{to{transform:rotate(360deg)}}
.spinner{width:18px;height:18px;border:3px solid #d8d0c1;border-top-color:#1A4D3A;border-radius:50%;animation:spin 1s linear infinite;display:inline-block;vertical-align:middle}

/* Degraded banner */
.degraded-banner{background:#fff4d6;border-bottom:1px solid #e5cf91;color:#5b4a1f;padding:10px 24px;font-size:13px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.degraded-banner .btn-link{color:#5b4a1f;font-size:13px;font-weight:700}

/* Photo picker */
.photo-picker{display:flex;flex-direction:column;gap:12px}
.photo-thumbs{display:flex;flex-wrap:wrap;gap:8px}
.photo-thumb{position:relative;background:white;border:1px solid var(--border);border-radius:12px;padding:10px 36px 10px 12px;font-size:12px;max-width:240px}
.photo-thumb-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.photo-thumb-size{color:var(--muted);margin-top:2px}
.photo-thumb-remove{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;border:none;background:#f0ebe1;color:#5b4a1f;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center}
.photo-thumb-remove:hover{background:var(--danger);color:white}

/* Task card buttons */
.task-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.task-actions .btn-sm{flex:1;min-width:100px}

/* Checklist */
.checklist{display:grid;gap:8px}
.checklist-item{display:flex;align-items:center;gap:12px;background:var(--ivory);padding:12px 14px;border-radius:14px;border:1px solid #e7e0d4}
.checklist-item input[type="checkbox"]{width:20px;height:20px;cursor:pointer}
.checklist-item.done{opacity:.6}
.checklist-item.done .item-name{text-decoration:line-through}
.item-name{flex:1;font-size:14px;font-weight:500}

/* Calendar grid */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;background:#eadfcf;border-radius:16px;padding:4px}
.cal-dow{background:var(--deep);color:rgba(255,255,255,.82);padding:8px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;text-align:center;border-radius:10px}
.cal-cell{background:white;min-height:110px;padding:6px 8px;border-radius:10px;display:flex;flex-direction:column;gap:3px;position:relative}
.cal-cell-other{background:#faf7ef;opacity:.55}
.cal-cell-today{outline:2px solid var(--forest);outline-offset:-2px}
.cal-day-num{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:2px}
.cal-cell-today .cal-day-num{color:var(--forest)}
.cal-bar{color:white;font-size:11px;padding:3px 6px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.cal-overflow{font-size:10px;color:var(--muted);padding:2px 6px}
@media (max-width:900px){
  .cal-cell{min-height:54px;padding:4px}
  .cal-dow{font-size:8px;padding:4px 2px;letter-spacing:.05em}
  .cal-bar{font-size:8px;padding:1px 3px}
  .cal-day-num{font-size:10px}
  .cal-grid{gap:2px;padding:2px;border-radius:12px}
}
@media (max-width:500px){
  /* On phones, hide booking text in calendar bars, just show colored dots */
  .cal-bar{font-size:0;height:6px;border-radius:3px;min-height:6px;padding:0}
  .cal-cell{min-height:42px;gap:2px}
  .cal-overflow{font-size:8px}
}
