/* ============================================================
   Client Suite — login + dashboard
   ============================================================ */

/* ===== Login ===== */
.login-page{background:var(--paper)}
.login-split{display:grid;grid-template-columns:1.1fr 1fr;min-height:100vh}
.login-visual{position:relative;background:linear-gradient(160deg,#1d1e24,#2c2d35);overflow:hidden;padding:48px;display:flex;flex-direction:column;justify-content:space-between;color:#fff;
  background-image:linear-gradient(160deg,rgba(22,23,28,.82),rgba(28,29,36,.88)),url('../assets/loginbg.jpg');
  background-size:cover;background-position:center}
.login-visual-overlay{position:absolute;inset:0;background:radial-gradient(120% 80% at 20% 10%,rgba(200,164,93,.18),transparent 60%)}
.login-brand{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.login-quote{position:relative;z-index:2;max-width:420px}
.login-quote h2{color:#fff;font-size:clamp(2rem,3.4vw,3rem);margin-bottom:16px}
.login-quote p{color:rgba(255,255,255,.7)}
.login-peak{position:absolute;left:0;bottom:0;width:100%;height:200px;fill:rgba(255,255,255,.05);z-index:1}

.login-form-side{display:flex;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:400px}
.login-card h1{font-size:2.6rem;margin:6px 0 8px}
.login-sub{color:var(--ink-soft);margin-bottom:30px}
.login-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;font-size:.85rem}
.check{display:flex;align-items:center;gap:8px;color:var(--ink-soft);cursor:pointer}
.check input{accent-color:var(--gold-dark)}
.login-back{display:inline-block;margin-top:28px;color:var(--ink-soft);font-size:.85rem;transition:.3s}
.login-back:hover{color:var(--gold-dark)}

@media(max-width:820px){
  .login-split{grid-template-columns:1fr}
  .login-visual{min-height:38vh;padding:32px}
  .login-quote h2{font-size:1.8rem}
}

/* ===== Dashboard ===== */
.dash-body{background:var(--paper-2);color:var(--ink)}
.dash-side{position:fixed;top:0;left:0;width:260px;height:100vh;background:var(--ink);color:#fff;padding:30px 24px;display:flex;flex-direction:column;z-index:50;transition:transform .4s var(--ease)}
.dash-brand{display:flex;align-items:center;gap:12px;color:#fff;margin-bottom:46px}
.dash-brand .brand-text{color:#fff}
.dash-nav{display:flex;flex-direction:column;gap:6px;flex:1}
.dash-nav a{display:flex;align-items:center;gap:14px;padding:13px 16px;border-radius:6px;color:rgba(255,255,255,.66);font-size:.92rem;letter-spacing:.04em;transition:.3s}
.dash-nav a .i{color:var(--gold);font-size:.9rem;width:16px;text-align:center}
.dash-nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.dash-nav a.active{background:linear-gradient(120deg,rgba(200,164,93,.22),rgba(200,164,93,.06));color:#fff;border:1px solid rgba(200,164,93,.4)}
.dash-logout{color:rgba(255,255,255,.55);font-size:.88rem;padding:13px 16px;transition:.3s}
.dash-logout:hover{color:var(--gold)}

.dash-main{margin-left:260px;padding:40px clamp(24px,4vw,60px) 60px;max-width:1100px}
.dash-top{display:flex;align-items:center;gap:20px;margin-bottom:38px}
.dash-top h1{font-size:clamp(1.8rem,3vw,2.6rem)}
.dash-top > div:not(.dash-avatar){flex:1}
.dash-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(120deg,var(--gold-dark),var(--gold-light));display:grid;place-items:center;font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:#1c1605;flex:none}
.dash-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.dash-burger span{width:24px;height:2px;background:var(--ink)}

.dash-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px}
.dcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:22px 22px}
.dcard-label{display:block;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:8px}
.dcard strong{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500}
.dcard-gold{background:linear-gradient(140deg,#2a2b32,#1c1d22);color:#fff}
.dcard-gold .dcard-label{color:var(--gold-light)}
.dcard-link{display:inline-block;margin-top:10px;color:var(--gold);font-size:.82rem}

.dash-progress{background:#fff;border:1px solid var(--line);border-radius:10px;padding:24px 26px;margin-bottom:42px}
.dp-head{display:flex;justify-content:space-between;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:12px}
.dp-head span:last-child{color:var(--gold-dark);font-weight:600}
.dp-bar{height:8px;background:var(--paper-2);border-radius:6px;overflow:hidden}
.dp-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));border-radius:6px;animation:fillbar 2s var(--ease) forwards}
.dp-note{margin-top:12px;font-size:.88rem;color:var(--ink-soft)}

.dash-h2{font-size:1.9rem;margin-bottom:22px}
.dash-itinerary{margin-bottom:48px}
.day{background:#fff;border:1px solid var(--line);border-radius:12px;padding:26px 28px;margin-bottom:18px}
.day-head{display:flex;align-items:baseline;gap:16px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.day-no{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--gold-dark)}
.day-date{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.timeline{display:flex;flex-direction:column;gap:6px}
.tl-item{display:flex;gap:20px;padding:8px 0;position:relative}
.tl-time{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--gold-dark);min-width:54px;padding-top:2px}
.tl-card{flex:1;border-left:2px solid var(--line);padding:0 0 14px 20px;position:relative}
.tl-card::before{content:"";position:absolute;left:-7px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(200,164,93,.16)}
.tl-card b{font-size:1.02rem}
.tl-card p{font-size:.9rem;color:var(--ink-soft);margin:2px 0 8px}
.tl-tag{display:inline-block;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:20px}
.tl-tag.done{background:rgba(200,164,93,.14);color:var(--gold-dark)}
.tl-tag.pending{background:#fbeede;color:#a4651f}

.dash-docs{margin-bottom:48px}
.doc-list{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.doc{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px 20px;cursor:pointer;transition:.3s}
.doc:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow)}
.doc-ic{width:46px;height:46px;display:grid;place-items:center;border-radius:8px;background:var(--ink);color:var(--gold);font-size:.66rem;letter-spacing:.06em;flex:none}
.doc b{display:block;font-size:.96rem}
.doc em{font-size:.78rem;color:var(--ink-soft)}
.doc > div{flex:1}
.doc-dl{font-size:.78rem;color:var(--gold-dark);letter-spacing:.06em}

.conc-card{background:linear-gradient(140deg,#26272e,#16171c);color:#fff;border-radius:14px;padding:36px;display:flex;gap:28px;align-items:center}
.conc-avatar{width:84px;height:84px;border-radius:50%;background:linear-gradient(120deg,var(--gold-dark),var(--gold-light));display:grid;place-items:center;font-family:'Cormorant Garamond',serif;font-size:2rem;color:#1c1605;flex:none}
.conc-text h3{font-size:1.7rem;color:#fff;margin:2px 0 8px}
.conc-text p{color:rgba(255,255,255,.7);max-width:460px;margin-bottom:18px}
.conc-text .eyebrow{color:var(--gold-light)}
.conc-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-dark{border-color:rgba(255,255,255,.4);color:#fff}
.btn-dark:hover{background:rgba(255,255,255,.1)}

.dash-foot{text-align:center;color:var(--ink-soft);font-size:.8rem;margin-top:30px}

@media(max-width:920px){
  .dash-cards{grid-template-columns:1fr 1fr}
  .doc-list{grid-template-columns:1fr}
}
@media(max-width:760px){
  .dash-side{transform:translateX(-100%)}
  .dash-side.open{transform:none;box-shadow:var(--shadow)}
  .dash-main{margin-left:0}
  .dash-burger{display:flex}
  .conc-card{flex-direction:column;text-align:center}
}

/* ============================================================
   Admin
   ============================================================ */
.admin-body{background:var(--paper-2);color:var(--ink);min-height:100vh}
.admin-top{background:var(--ink);color:#fff;padding:16px 0}
.admin-top-inner{max-width:1100px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.admin-top .brand-logo{width:38px;height:38px}
.admin-brand{display:flex;align-items:center;gap:12px;color:#fff}
.admin-brand b{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:500}
.admin-brand span{font-size:.6rem;letter-spacing:.28em;color:var(--gold);display:block}
.admin-nav{display:flex;align-items:center;gap:20px}
.admin-nav a{color:rgba(255,255,255,.75);font-size:.85rem}
.admin-nav a:hover{color:var(--gold)}
.admin-logout{background:none;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:3px;cursor:pointer;font:inherit;font-size:.8rem}
.admin-logout:hover{border-color:var(--gold);color:var(--gold)}
.admin-wrap{max-width:1100px;margin:0 auto;padding:40px 28px 80px}
.admin-wrap h1{font-family:'Cormorant Garamond',serif;font-size:2.4rem;margin-bottom:6px}
.admin-sub{color:var(--ink-soft);margin-bottom:32px}
.admin-flash{background:rgba(200,164,93,.16);border:1px solid var(--gold);color:var(--gold-dark);padding:12px 18px;border-radius:4px;margin-bottom:24px;font-size:.9rem}
.admin-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:start}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:26px;margin-bottom:24px}
.admin-card h2{font-family:'Cormorant Garamond',serif;font-size:1.6rem;margin-bottom:18px}
.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}
.admin-table th{text-align:left;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);padding:8px 10px;border-bottom:1px solid var(--line)}
.admin-table td{padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:0}
.admin-table .ref{font-family:'Cormorant Garamond',serif;color:var(--gold-dark)}
.admin-actions{display:flex;gap:8px}
.btn-sm{padding:7px 14px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;border-radius:3px;border:1px solid var(--gold);color:var(--gold-dark);background:#fff;cursor:pointer;text-decoration:none;display:inline-block}
.btn-sm:hover{background:var(--gold);color:#1c1605}
.btn-sm.danger{border-color:#d8b4a8;color:#b4452f}
.btn-sm.danger:hover{background:#b4452f;color:#fff;border-color:#b4452f}
.admin-form .field{margin-bottom:14px}
.admin-form label{display:block;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
.admin-form input,.admin-form select,.admin-form textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:3px;font-family:inherit;font-size:.92rem;background:var(--paper)}
.admin-form input:focus,.admin-form select:focus,.admin-form textarea:focus{outline:none;border-color:var(--gold)}
.admin-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.admin-back{color:var(--gold-dark);font-size:.85rem;display:inline-block;margin-bottom:18px}
.pill{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:12px;background:var(--paper-2);color:var(--ink-soft)}
.pill.confirmed{background:rgba(200,164,93,.16);color:var(--gold-dark)}
.pill.pending{background:#fbeede;color:#a4651f}
@media(max-width:820px){.admin-grid{grid-template-columns:1fr}.admin-form .row2{grid-template-columns:1fr}}
