/* Contag Call — Mockup Styles (v1.0)
 * HIG 기반 iOS 앱 화면 + 웹 레이아웃 공용
 */

@import url("./brand.css");

/* Reset & Base */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html,
body {
  font-family: var(--cc-font);
  font-size: var(--cc-text-body);
  color: var(--cc-label);
  background: var(--cc-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
button {
  font: inherit;
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
}
input,
textarea,
select {
  font: inherit;
}
a {
  color: var(--cc-primary);
  text-decoration: none;
}
img,
svg {
  display: block;
  max-width: 100%;
}

/* ===== iPhone Frame Container ===== */
.iphone-frame {
  width: var(--ios-width);
  height: var(--ios-height);
  background: var(--cc-bg);
  border-radius: 55px;
  border: 3px solid #1a1a1a;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.25),
    inset 0 0 0 8px #000;
  position: relative;
  overflow: hidden;
  margin: 40px auto;
}

.iphone-screen {
  position: absolute;
  inset: 12px;
  background: var(--cc-bg);
  border-radius: 48px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* Dynamic Island */
.dynamic-island {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: 125px;
  height: 37px;
  background: #000;
  border-radius: 20px;
  z-index: 100;
}

/* ===== Status Bar (54pt with Dynamic Island) ===== */
.status-bar {
  height: var(--ios-status-bar);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 16px 24px 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--cc-label);
  flex-shrink: 0;
  background: var(--cc-bg);
  position: relative;
  z-index: 10;
}
.status-bar .time {
  min-width: 60px;
}
.status-bar .indicators {
  display: flex;
  gap: 6px;
  align-items: center;
  min-width: 60px;
  justify-content: flex-end;
}
.status-bar .indicators::after {
  content: "📶 📶 🔋";
  letter-spacing: -2px;
  font-size: 12px;
}

/* ===== Navigation Bar (44pt) ===== */
.nav-bar {
  height: var(--ios-nav-bar);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  background: var(--cc-bg);
  flex-shrink: 0;
  position: relative;
}
.nav-bar .nav-title {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--cc-text-headline);
  font-weight: var(--cc-weight-semibold);
}
.nav-bar .nav-btn {
  color: var(--cc-primary);
  font-size: var(--cc-text-body);
  padding: 8px 4px;
  min-height: 44px;
  display: flex;
  align-items: center;
}
.nav-bar .nav-btn.primary {
  font-weight: var(--cc-weight-semibold);
}

/* Large Title (iOS 13+) */
.large-title {
  font-size: var(--cc-text-large);
  font-weight: var(--cc-weight-bold);
  padding: 8px 16px 16px;
  background: var(--cc-bg);
}

/* ===== Content ===== */
.ios-content {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* ===== Tab Bar (49pt + 34pt safe area = 83pt) ===== */
.tab-bar {
  height: var(--ios-tab-total);
  padding-bottom: var(--ios-home-ind);
  background: rgba(249, 249, 249, 0.94);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 0.5px solid var(--cc-divider);
  display: flex;
  flex-shrink: 0;
  position: relative;
}
.tab-bar .tab-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 2px;
  padding-top: 6px;
  color: var(--cc-label-2);
  font-size: 10px;
  font-weight: var(--cc-weight-medium);
}
.tab-bar .tab-item .tab-icon {
  font-size: 24px;
  line-height: 1;
}
.tab-bar .tab-item.active {
  color: var(--cc-primary);
}

/* Home Indicator */
.home-indicator {
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 134px;
  height: 5px;
  background: var(--cc-label);
  border-radius: 3px;
}

/* ===== iOS List / Row ===== */
.ios-list {
  background: var(--cc-card);
  border-radius: var(--radius-lg);
  margin: 16px;
  overflow: hidden;
}
.ios-list-row {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  min-height: 44px;
  border-bottom: 0.5px solid var(--cc-divider);
  gap: 12px;
}
.ios-list-row:last-child {
  border-bottom: none;
}
.ios-list-row .row-icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  border-radius: 6px;
}
.ios-list-row .row-label {
  flex: 1;
  font-size: var(--cc-text-body);
}
.ios-list-row .row-value {
  color: var(--cc-label-2);
  font-size: var(--cc-text-body);
}
.ios-list-row .row-chevron {
  color: var(--cc-label-3);
  font-size: 14px;
}

/* List Group Header */
.ios-list-header {
  font-size: var(--cc-text-footnote);
  color: var(--cc-label-2);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  padding: 16px 32px 6px;
}

/* ===== iOS Buttons ===== */
.ios-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  padding: 0 20px;
  border-radius: var(--radius-lg);
  font-size: var(--cc-text-body);
  font-weight: var(--cc-weight-semibold);
  min-width: 44px;
}
.ios-btn-primary {
  background: var(--cc-primary);
  color: #fff;
}
.ios-btn-primary:disabled,
.ios-btn-primary[aria-disabled="true"] {
  background: var(--cc-fill-2);
  color: var(--cc-label-3);
}
.ios-btn-secondary {
  background: var(--cc-fill-3);
  color: var(--cc-primary);
}
.ios-btn-destructive {
  background: var(--cc-error);
  color: #fff;
}
.ios-btn-plain {
  color: var(--cc-primary);
  background: transparent;
}

/* ===== iOS Card ===== */
.ios-card {
  background: var(--cc-card);
  border-radius: var(--radius-lg);
  margin: 16px;
  padding: 16px;
  box-shadow: var(--shadow-ios-card);
}

/* ===== iOS Text Field ===== */
.ios-input {
  width: 100%;
  height: 44px;
  padding: 0 16px;
  background: var(--cc-card);
  border: 1px solid var(--cc-border);
  border-radius: var(--radius-md);
  font-size: var(--cc-text-body);
  color: var(--cc-label);
  outline: none;
}
.ios-input:focus {
  border-color: var(--cc-primary);
}
.ios-input::placeholder {
  color: var(--cc-placeholder);
}

/* ===== Web Layout Containers ===== */
.web-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px;
}
.web-hero {
  text-align: center;
  padding: 60px 24px;
}
.web-hero h1 {
  font-size: 48px;
  font-weight: var(--cc-weight-bold);
  margin-bottom: 16px;
}
.web-hero p {
  font-size: 20px;
  color: var(--cc-label-2);
  margin-bottom: 32px;
}

/* ===== Phone mockup (viewport mode) ===== */
.sender-mobile {
  width: 393px;
  min-height: 852px;
  background: var(--cc-bg);
  margin: 40px auto;
  border-radius: 55px;
  border: 3px solid #1a1a1a;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.25),
    inset 0 0 0 8px #000;
  padding: 12px;
  overflow: hidden;
  position: relative;
}

/* ===== Dial Pad ===== */
.dial-pad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 320px;
  margin: 0 auto;
}
.dial-key {
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--cc-fill-3);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  font-weight: var(--cc-weight-regular);
  color: var(--cc-label);
  transition: background 0.15s;
}
.dial-key:hover {
  background: var(--cc-fill);
}
.dial-key .dial-letters {
  font-size: 10px;
  font-weight: var(--cc-weight-medium);
  color: var(--cc-label-2);
  letter-spacing: 1px;
  margin-top: -4px;
}

/* ===== Utilities ===== */
.flex {
  display: flex;
}
.flex-col {
  flex-direction: column;
}
.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
.items-center {
  align-items: center;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-1 {
  gap: 4px;
}
.gap-2 {
  gap: 8px;
}
.gap-3 {
  gap: 12px;
}
.gap-4 {
  gap: 16px;
}
.gap-6 {
  gap: 24px;
}
.p-2 {
  padding: 8px;
}
.p-4 {
  padding: 16px;
}
.p-6 {
  padding: 24px;
}
.mt-2 {
  margin-top: 8px;
}
.mt-4 {
  margin-top: 16px;
}
.mb-2 {
  margin-bottom: 8px;
}
.mb-4 {
  margin-bottom: 16px;
}
.text-center {
  text-align: center;
}
.text-primary {
  color: var(--cc-primary);
}
.text-secondary {
  color: var(--cc-label-2);
}
.text-error {
  color: var(--cc-error);
}
.text-success {
  color: var(--cc-success);
}
.font-semibold {
  font-weight: var(--cc-weight-semibold);
}
.font-bold {
  font-weight: var(--cc-weight-bold);
}
.w-full {
  width: 100%;
}
.hidden {
  display: none;
}

/* ===== Mockup Page Wrapper ===== */
.mockup-page {
  min-height: 100vh;
  background: #e5e5ea;
  padding: 40px 20px;
}
.mockup-page .mockup-header {
  max-width: 800px;
  margin: 0 auto 24px;
  background: white;
  padding: 16px 24px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.mockup-page .mockup-header h1 {
  font-size: var(--cc-text-title-2);
  font-weight: var(--cc-weight-bold);
}
.mockup-page .mockup-header .breadcrumb {
  color: var(--cc-label-2);
  font-size: var(--cc-text-footnote);
  margin-top: 4px;
}
.mockup-page .mockup-header a {
  color: var(--cc-primary);
  font-size: var(--cc-text-footnote);
  margin-right: 12px;
}
