/*
    File: css/style.css
    Date: 01 May 2026 23:34 AEST
    Version: v01
*/
:root{
  --glass-dark: rgba(10,25,41,.25);
  --glass-light: rgba(255,255,255,.40);
  --border-dark: rgba(255,255,255,.22);
  --border-light: rgba(0,0,0,.22);
  --text-light:#f0f8ff; --text-dark:#222;
  --radius:18px; --pad:1.25rem;
  --primary-accent: #3b82f6;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100dvh;
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text-light);
  background:#0b1727 url('/images/hero/background2-3.webp') center/cover no-repeat fixed;
}
body.light{color:var(--text-dark)}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:.15em}
a strong, strong a{font-weight:700}
p{line-height:1.7}
h2,h3{margin-bottom:.5rem}

.veil{position:fixed;inset:0;pointer-events:none;z-index:-1;transition:background .3s}
.veil{background:rgba(0,0,0,.40)}
body.light .veil{background:rgba(255,255,255,.30)}

.page{position:relative;z-index:1;max-width:960px;margin:0 auto;padding: clamp(.75rem,2vw,1.25rem)}
.logo{width: clamp(220px,42vw,360px);height:auto;display:block;margin: .75rem auto}

.card{
  border:1px solid var(--border-dark);border-radius:var(--radius);
  background:var(--glass-dark);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  padding:var(--pad)
}
body.light .card{background:var(--glass-light);border-color:var(--border-light)}

.toggle-theme{
  position:fixed;top:1rem;right:1rem;z-index:1002;
  display:flex;align-items:center;gap:.55rem;
  padding:.55rem 1rem;border-radius:9999px;border:1px solid var(--border-dark);
  background:rgba(255,255,255,.10);backdrop-filter:blur(10px);cursor:pointer
}
body.light .toggle-theme{background:rgba(0,0,0,.08);border-color:var(--border-light)}

.floating-btn{
    position:fixed; z-index:1001;
    background: rgba(30, 41, 59, 0.7);
    border: 1px solid rgba(255,255,255,0.2);
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.floating-btn.top-left{top:1rem;left:1rem}
.floating-btn.bottom-left{bottom:1rem;left:1rem}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:12px 18px;border-radius:9999px;border:1px solid var(--border-dark);
  background:rgba(255,255,255,.12);backdrop-filter:blur(10px);
  font-weight:700;color:inherit;transition:transform .2s;
}
.btn:hover{transform:translateY(-1px); text-decoration: none;}
.btn.primary{background:rgba(0,132,255,.35);border-color:rgba(0,132,255,.55)}
body.light .btn{background:rgba(0,0,0,.08);border-color:var(--border-light)}
body.light .btn.primary{background:rgba(0,132,255,.28);color:#fff}

.hero {
    position: relative;
    padding-top: clamp(80px, 12vw, 120px); /* Space for portrait to overlap from top */
}
.portrait {
    position: absolute;
    top: 0;
    left: clamp(1rem, 3vw, 2rem);
    width: clamp(180px, 22vw, 260px);
    height: auto;
    transform: translateY(-50%); /* Lifts the portrait higher */
    z-index: 1; /* Sits behind the card */
    filter: drop-shadow(0 10px 22px rgba(0,0,0,.35));
}
.hero-card {
    position: relative;
    z-index: 2; /* Sits on top of the portrait */
    text-align: center;
    padding: clamp(16px,3vw,26px);
}
.hero-intro{font-size: clamp(1rem,2.2vw,1.2rem);line-height:1.7}

main{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.25rem}

.timeline{margin-top:.5rem}
.timeline h2{margin-bottom:.25rem}
.journey-item{display:flex;flex-wrap:wrap;gap:1.25rem;align-items:flex-start;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-dark);}
body.light .journey-item{border-top:1px solid var(--border-light)}
.journey-item:first-of-type{margin-top:0;padding-top:0;border-top:none}
.journey-text{flex:3;min-width:280px}
.gallery{flex:1;min-width:240px;display:flex;flex-direction:column;gap:.75rem}
.thumb{display:block;border-radius:14px;overflow:hidden;}
.thumb.clickable{cursor:pointer}
.thumb img{display:block;width:100%;height:auto}
.links-grid { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: .5rem; }

footer{margin: clamp(18px,3vw,30px) 0;text-align:center;opacity:.9}

/* Modals */
.modal{
    display:none;position:fixed;inset:0;z-index:1003;
    background:rgba(0,0,0,.75);align-items:center;justify-content:center;
    padding:1rem
}
.modal.open{display:flex}
.modal .frame{
    max-width:min(92vw,1400px);max-height:90vh;
    background:var(--glass-dark);border:1px solid var(--border-dark);
    border-radius:18px;padding:1rem;backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px)
}
body.light .modal .frame{background:var(--glass-light);border-color:var(--border-light)}
.modal img{display:block;max-width:100%;max-height:calc(90vh - 2rem);border-radius:12px}
.form-modal-content{max-width:500px;width:90%;}
.form-group label { display: block; margin-bottom: 0.5rem; font-weight: bold;}
.form-group input, .form-group textarea, .form-group select {
    background-color: rgba(255, 255, 255, 0.1); border: 1px solid; color: inherit;
    padding: 12px; border-radius: var(--radius); font-size: 1rem; width: 100%;
    transition: border-color 0.3s, box-shadow 0.3s;
}
 body.dark .form-group input, body.dark .form-group textarea, body.dark .form-group select {
    border-color: var(--border-dark); color: var(--text-light);
}
body.light .form-group input, body.light .form-group textarea, body.light .form-group select {
    background-color: rgba(255, 255, 255, 0.7);
    border-color: var(--border-light); color: var(--text-dark);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
    outline: none; border-color: var(--primary-accent);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.4);
}
#formatted-enquiry { white-space: pre-wrap; word-wrap: break-word; background-color: rgba(0,0,0,0.1); padding: 1rem; border-radius: var(--radius); margin-bottom: 1.5rem; text-align: left; }

.video-container {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 Aspect Ratio */
    height: 0;
    overflow: hidden;
    margin-top: 1rem;
    border-radius: var(--radius);
}
.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

@media (max-width:720px){
  .portrait{display:none;} 
  .hero{padding-top:0}
}
